mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-01 18:30:59 +01:00
Use ApplicationSearch to manage DrydockLeases
Summary: Ref T2015. Applies ApplicationSearch to DrydockLease. This makes the left nav in Drydock a little funky. It will probably get worse for a bit before it gets better, since I want to bring everything to ApplicationSearch and then sort out the details. Test Plan: Queried leases in Drydock. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T2015 Differential Revision: https://secure.phabricator.com/D7827
This commit is contained in:
parent
6b2d480fe7
commit
70244d3a12
8 changed files with 162 additions and 55 deletions
|
@ -653,6 +653,7 @@ phutil_register_library_map(array(
|
||||||
'DrydockLeaseListController' => 'applications/drydock/controller/DrydockLeaseListController.php',
|
'DrydockLeaseListController' => 'applications/drydock/controller/DrydockLeaseListController.php',
|
||||||
'DrydockLeaseQuery' => 'applications/drydock/query/DrydockLeaseQuery.php',
|
'DrydockLeaseQuery' => 'applications/drydock/query/DrydockLeaseQuery.php',
|
||||||
'DrydockLeaseReleaseController' => 'applications/drydock/controller/DrydockLeaseReleaseController.php',
|
'DrydockLeaseReleaseController' => 'applications/drydock/controller/DrydockLeaseReleaseController.php',
|
||||||
|
'DrydockLeaseSearchEngine' => 'applications/drydock/query/DrydockLeaseSearchEngine.php',
|
||||||
'DrydockLeaseStatus' => 'applications/drydock/constants/DrydockLeaseStatus.php',
|
'DrydockLeaseStatus' => 'applications/drydock/constants/DrydockLeaseStatus.php',
|
||||||
'DrydockLeaseViewController' => 'applications/drydock/controller/DrydockLeaseViewController.php',
|
'DrydockLeaseViewController' => 'applications/drydock/controller/DrydockLeaseViewController.php',
|
||||||
'DrydockLocalCommandInterface' => 'applications/drydock/interface/command/DrydockLocalCommandInterface.php',
|
'DrydockLocalCommandInterface' => 'applications/drydock/interface/command/DrydockLocalCommandInterface.php',
|
||||||
|
@ -3046,10 +3047,19 @@ phutil_register_library_map(array(
|
||||||
'DrydockController' => 'PhabricatorController',
|
'DrydockController' => 'PhabricatorController',
|
||||||
'DrydockDAO' => 'PhabricatorLiskDAO',
|
'DrydockDAO' => 'PhabricatorLiskDAO',
|
||||||
'DrydockFilesystemInterface' => 'DrydockInterface',
|
'DrydockFilesystemInterface' => 'DrydockInterface',
|
||||||
'DrydockLease' => 'DrydockDAO',
|
'DrydockLease' =>
|
||||||
'DrydockLeaseListController' => 'DrydockController',
|
array(
|
||||||
'DrydockLeaseQuery' => 'PhabricatorOffsetPagedQuery',
|
0 => 'DrydockDAO',
|
||||||
|
1 => 'PhabricatorPolicyInterface',
|
||||||
|
),
|
||||||
|
'DrydockLeaseListController' =>
|
||||||
|
array(
|
||||||
|
0 => 'DrydockController',
|
||||||
|
1 => 'PhabricatorApplicationSearchResultsControllerInterface',
|
||||||
|
),
|
||||||
|
'DrydockLeaseQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
|
||||||
'DrydockLeaseReleaseController' => 'DrydockController',
|
'DrydockLeaseReleaseController' => 'DrydockController',
|
||||||
|
'DrydockLeaseSearchEngine' => 'PhabricatorApplicationSearchEngine',
|
||||||
'DrydockLeaseStatus' => 'DrydockConstants',
|
'DrydockLeaseStatus' => 'DrydockConstants',
|
||||||
'DrydockLeaseViewController' => 'DrydockController',
|
'DrydockLeaseViewController' => 'DrydockController',
|
||||||
'DrydockLocalCommandInterface' => 'DrydockCommandInterface',
|
'DrydockLocalCommandInterface' => 'DrydockCommandInterface',
|
||||||
|
|
|
@ -46,7 +46,7 @@ final class PhabricatorApplicationDrydock extends PhabricatorApplication {
|
||||||
'(?P<id>[1-9]\d*)/close/' => 'DrydockResourceCloseController',
|
'(?P<id>[1-9]\d*)/close/' => 'DrydockResourceCloseController',
|
||||||
),
|
),
|
||||||
'lease/' => array(
|
'lease/' => array(
|
||||||
'' => 'DrydockLeaseListController',
|
'(?:query/(?P<queryKey>[^/]+)/)?' => 'DrydockLeaseListController',
|
||||||
'(?P<id>[1-9]\d*)/' => 'DrydockLeaseViewController',
|
'(?P<id>[1-9]\d*)/' => 'DrydockLeaseViewController',
|
||||||
'(?P<id>[1-9]\d*)/release/' => 'DrydockLeaseReleaseController',
|
'(?P<id>[1-9]\d*)/release/' => 'DrydockLeaseReleaseController',
|
||||||
),
|
),
|
||||||
|
|
|
@ -10,16 +10,27 @@ final class DrydockLeaseStatus extends DrydockConstants {
|
||||||
const STATUS_EXPIRED = 4;
|
const STATUS_EXPIRED = 4;
|
||||||
|
|
||||||
public static function getNameForStatus($status) {
|
public static function getNameForStatus($status) {
|
||||||
static $map = array(
|
$map = array(
|
||||||
self::STATUS_PENDING => 'Pending',
|
self::STATUS_PENDING => pht('Pending'),
|
||||||
self::STATUS_ACQUIRING => 'Acquiring',
|
self::STATUS_ACQUIRING => pht('Acquiring'),
|
||||||
self::STATUS_ACTIVE => 'Active',
|
self::STATUS_ACTIVE => pht('Active'),
|
||||||
self::STATUS_RELEASED => 'Released',
|
self::STATUS_RELEASED => pht('Released'),
|
||||||
self::STATUS_BROKEN => 'Broken',
|
self::STATUS_BROKEN => pht('Broken'),
|
||||||
self::STATUS_EXPIRED => 'Expired',
|
self::STATUS_EXPIRED => pht('Expired'),
|
||||||
);
|
);
|
||||||
|
|
||||||
return idx($map, $status, 'Unknown');
|
return idx($map, $status, pht('Unknown'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function getAllStatuses() {
|
||||||
|
return array(
|
||||||
|
self::STATUS_PENDING,
|
||||||
|
self::STATUS_ACQUIRING,
|
||||||
|
self::STATUS_ACTIVE,
|
||||||
|
self::STATUS_RELEASED,
|
||||||
|
self::STATUS_BROKEN,
|
||||||
|
self::STATUS_EXPIRED,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,12 +2,17 @@
|
||||||
|
|
||||||
abstract class DrydockController extends PhabricatorController {
|
abstract class DrydockController extends PhabricatorController {
|
||||||
|
|
||||||
final protected function buildSideNav($selected) {
|
final protected function buildSideNav($selected = null) {
|
||||||
$nav = new AphrontSideNavFilterView();
|
$nav = new AphrontSideNavFilterView();
|
||||||
$nav->setBaseURI(new PhutilURI('/drydock/'));
|
$nav->setBaseURI(new PhutilURI('/drydock/'));
|
||||||
$nav->addFilter('blueprint', 'Blueprints');
|
$nav->addFilter('blueprint', 'Blueprints');
|
||||||
$nav->addFilter('resource', 'Resources');
|
$nav->addFilter('resource', 'Resources');
|
||||||
$nav->addFilter('lease', 'Leases');
|
|
||||||
|
id(new DrydockLeaseSearchEngine())
|
||||||
|
->setViewer($this->getRequest()->getUser())
|
||||||
|
->addNavigationItems($nav->getMenu(), pht('Leases'));
|
||||||
|
|
||||||
|
$nav->addLabel(pht('Logs'));
|
||||||
$nav->addFilter('log', 'Logs');
|
$nav->addFilter('log', 'Logs');
|
||||||
|
|
||||||
$nav->selectFilter($selected, 'resource');
|
$nav->selectFilter($selected, 'resource');
|
||||||
|
@ -80,11 +85,12 @@ abstract class DrydockController extends PhabricatorController {
|
||||||
protected function buildLeaseListView(array $leases) {
|
protected function buildLeaseListView(array $leases) {
|
||||||
assert_instances_of($leases, 'DrydockLease');
|
assert_instances_of($leases, 'DrydockLease');
|
||||||
|
|
||||||
$user = $this->getRequest()->getUser();
|
$viewer = $this->getRequest()->getUser();
|
||||||
$view = new PHUIObjectItemListView();
|
$view = new PHUIObjectItemListView();
|
||||||
|
|
||||||
foreach ($leases as $lease) {
|
foreach ($leases as $lease) {
|
||||||
$item = id(new PHUIObjectItemView())
|
$item = id(new PHUIObjectItemView())
|
||||||
|
->setUser($viewer)
|
||||||
->setHeader($lease->getLeaseName())
|
->setHeader($lease->getLeaseName())
|
||||||
->setHref($this->getApplicationURI('/lease/'.$lease->getID().'/'));
|
->setHref($this->getApplicationURI('/lease/'.$lease->getID().'/'));
|
||||||
|
|
||||||
|
@ -107,9 +113,7 @@ abstract class DrydockController extends PhabricatorController {
|
||||||
|
|
||||||
$status = DrydockLeaseStatus::getNameForStatus($lease->getStatus());
|
$status = DrydockLeaseStatus::getNameForStatus($lease->getStatus());
|
||||||
$item->addAttribute($status);
|
$item->addAttribute($status);
|
||||||
|
$item->setEpoch($lease->getDateCreated());
|
||||||
$date_created = phabricator_date($lease->getDateCreated(), $user);
|
|
||||||
$item->addAttribute(pht('Created on %s', $date_created));
|
|
||||||
|
|
||||||
if ($lease->isActive()) {
|
if ($lease->isActive()) {
|
||||||
$item->setBarColor('green');
|
$item->setBarColor('green');
|
||||||
|
|
|
@ -1,46 +1,34 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
final class DrydockLeaseListController extends DrydockController {
|
final class DrydockLeaseListController extends DrydockController
|
||||||
|
implements PhabricatorApplicationSearchResultsControllerInterface {
|
||||||
|
|
||||||
|
private $queryKey;
|
||||||
|
|
||||||
|
public function shouldAllowPublic() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function willProcessRequest(array $data) {
|
||||||
|
$this->queryKey = idx($data, 'queryKey');
|
||||||
|
}
|
||||||
|
|
||||||
public function processRequest() {
|
public function processRequest() {
|
||||||
$request = $this->getRequest();
|
$request = $this->getRequest();
|
||||||
$user = $request->getUser();
|
$controller = id(new PhabricatorApplicationSearchController($request))
|
||||||
|
->setQueryKey($this->queryKey)
|
||||||
|
->setSearchEngine(new DrydockLeaseSearchEngine())
|
||||||
|
->setNavigation($this->buildSideNav());
|
||||||
|
|
||||||
$nav = $this->buildSideNav('lease');
|
return $this->delegateToController($controller);
|
||||||
|
}
|
||||||
|
|
||||||
$pager = new AphrontPagerView();
|
public function renderResultsList(
|
||||||
$pager->setURI(new PhutilURI('/drydock/lease/'), 'offset');
|
array $leases,
|
||||||
$pager->setOffset($request->getInt('offset'));
|
PhabricatorSavedQuery $query) {
|
||||||
|
assert_instances_of($leases, 'DrydockLease');
|
||||||
$leases = id(new DrydockLeaseQuery())
|
|
||||||
->setViewer($user)
|
|
||||||
->executeWithOffsetPager($pager);
|
|
||||||
|
|
||||||
$title = pht('Leases');
|
|
||||||
|
|
||||||
$header = id(new PHUIHeaderView())
|
|
||||||
->setHeader($title);
|
|
||||||
|
|
||||||
$lease_list = $this->buildLeaseListView($leases);
|
|
||||||
|
|
||||||
$nav->appendChild(
|
|
||||||
array(
|
|
||||||
$header,
|
|
||||||
$lease_list,
|
|
||||||
$pager,
|
|
||||||
));
|
|
||||||
|
|
||||||
$crumbs = $this->buildApplicationCrumbs();
|
|
||||||
$crumbs->addTextCrumb($title, $request->getRequestURI());
|
|
||||||
$nav->setCrumbs($crumbs);
|
|
||||||
|
|
||||||
return $this->buildApplicationPage(
|
|
||||||
$nav,
|
|
||||||
array(
|
|
||||||
'device' => true,
|
|
||||||
'title' => $title,
|
|
||||||
));
|
|
||||||
|
|
||||||
|
return $this->buildLeaseListView($leases);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,7 @@ final class DrydockLeaseQuery
|
||||||
|
|
||||||
private $ids;
|
private $ids;
|
||||||
private $resourceIDs;
|
private $resourceIDs;
|
||||||
|
private $statuses;
|
||||||
|
|
||||||
public function withIDs(array $ids) {
|
public function withIDs(array $ids) {
|
||||||
$this->ids = $ids;
|
$this->ids = $ids;
|
||||||
|
@ -16,6 +17,11 @@ final class DrydockLeaseQuery
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function withStatuses(array $statuses) {
|
||||||
|
$this->statuses = $statuses;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function loadPage() {
|
public function loadPage() {
|
||||||
$table = new DrydockLease();
|
$table = new DrydockLease();
|
||||||
$conn_r = $table->establishConnection('r');
|
$conn_r = $table->establishConnection('r');
|
||||||
|
@ -67,6 +73,13 @@ final class DrydockLeaseQuery
|
||||||
$this->ids);
|
$this->ids);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->statuses) {
|
||||||
|
$where[] = qsprintf(
|
||||||
|
$conn_r,
|
||||||
|
'status IN (%Ld)',
|
||||||
|
$this->statuses);
|
||||||
|
}
|
||||||
|
|
||||||
$where[] = $this->buildPagingClause($conn_r);
|
$where[] = $this->buildPagingClause($conn_r);
|
||||||
|
|
||||||
return $this->formatWhereClause($where);
|
return $this->formatWhereClause($where);
|
||||||
|
|
81
src/applications/drydock/query/DrydockLeaseSearchEngine.php
Normal file
81
src/applications/drydock/query/DrydockLeaseSearchEngine.php
Normal file
|
@ -0,0 +1,81 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class DrydockLeaseSearchEngine
|
||||||
|
extends PhabricatorApplicationSearchEngine {
|
||||||
|
|
||||||
|
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
||||||
|
$saved = new PhabricatorSavedQuery();
|
||||||
|
|
||||||
|
$saved->setParameter(
|
||||||
|
'statuses',
|
||||||
|
$this->readListFromRequest($request, 'statuses'));
|
||||||
|
|
||||||
|
return $saved;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function buildQueryFromSavedQuery(PhabricatorSavedQuery $saved) {
|
||||||
|
$query = id(new DrydockLeaseQuery());
|
||||||
|
|
||||||
|
$statuses = $saved->getParameter('statuses', array());
|
||||||
|
if ($statuses) {
|
||||||
|
$query->withStatuses($statuses);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $query;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function buildSearchForm(
|
||||||
|
AphrontFormView $form,
|
||||||
|
PhabricatorSavedQuery $saved) {
|
||||||
|
|
||||||
|
$statuses = $saved->getParameter('statuses', array());
|
||||||
|
|
||||||
|
$status_control = id(new AphrontFormCheckboxControl())
|
||||||
|
->setLabel(pht('Status'));
|
||||||
|
foreach (DrydockLeaseStatus::getAllStatuses() as $status) {
|
||||||
|
$status_control->addCheckbox(
|
||||||
|
'statuses[]',
|
||||||
|
$status,
|
||||||
|
DrydockLeaseStatus::getNameForStatus($status),
|
||||||
|
in_array($status, $statuses));
|
||||||
|
}
|
||||||
|
|
||||||
|
$form
|
||||||
|
->appendChild($status_control);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getURI($path) {
|
||||||
|
return '/drydock/lease/'.$path;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getBuiltinQueryNames() {
|
||||||
|
$names = array(
|
||||||
|
'active' => pht('Active Leases'),
|
||||||
|
'all' => pht('All Leases'),
|
||||||
|
);
|
||||||
|
|
||||||
|
return $names;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function buildSavedQueryFromBuiltin($query_key) {
|
||||||
|
$query = $this->newSavedQuery();
|
||||||
|
$query->setQueryKey($query_key);
|
||||||
|
|
||||||
|
switch ($query_key) {
|
||||||
|
case 'active':
|
||||||
|
return $query->setParameter(
|
||||||
|
'statuses',
|
||||||
|
array(
|
||||||
|
DrydockLeaseStatus::STATUS_PENDING,
|
||||||
|
DrydockLeaseStatus::STATUS_ACQUIRING,
|
||||||
|
DrydockLeaseStatus::STATUS_ACTIVE,
|
||||||
|
));
|
||||||
|
case 'all':
|
||||||
|
return $query;
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::buildSavedQueryFromBuiltin($query_key);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -108,10 +108,10 @@ abstract class PhabricatorApplicationSearchEngine {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function addNavigationItems(PHUIListView $menu) {
|
public function addNavigationItems(PHUIListView $menu, $label = null) {
|
||||||
$viewer = $this->requireViewer();
|
$viewer = $this->requireViewer();
|
||||||
|
|
||||||
$menu->newLabel(pht('Queries'));
|
$menu->newLabel(coalesce($label, pht('Queries')));
|
||||||
|
|
||||||
$named_queries = $this->loadEnabledNamedQueries();
|
$named_queries = $this->loadEnabledNamedQueries();
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue