1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-19 19:21:10 +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:
epriestley 2013-12-26 10:42:00 -08:00
parent 6b2d480fe7
commit 70244d3a12
8 changed files with 162 additions and 55 deletions

View file

@ -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',

View file

@ -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',
), ),

View file

@ -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,
);
} }
} }

View file

@ -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');

View file

@ -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);
} }
} }

View file

@ -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);

View 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);
}
}

View file

@ -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();