mirror of
https://we.phorge.it/source/phorge.git
synced 2025-04-02 15:38:18 +02:00
Summary: Ref T10004. After D14804, we get this behavior by default and no longer need to set it explicitly. (If some endpoint did eventually need to set it explicitly, it could just change what it passes to `setHref()`, but I believe we currently have no such endpoints and do not foresee ever having any.) Test Plan: - As a logged out user, clicked various links in Differential, Maniphest, Files, etc., always got redirected to a sensible place after login. - Grepped for `setObjectURI()`, `getObjectURI()` (there are a few remaining callsites, but to a different method with the same name in Doorkeeper). Reviewers: chad Reviewed By: chad Subscribers: hach-que Maniphest Tasks: T10004 Differential Revision: https://secure.phabricator.com/D14805
149 lines
4.1 KiB
PHP
149 lines
4.1 KiB
PHP
<?php
|
|
|
|
final class ReleephBranchViewController extends ReleephBranchController {
|
|
|
|
public function shouldAllowPublic() {
|
|
return true;
|
|
}
|
|
|
|
public function handleRequest(AphrontRequest $request) {
|
|
$viewer = $request->getViewer();
|
|
$id = $request->getURIData('branchID');
|
|
$querykey = $request->getURIData('queryKey');
|
|
|
|
$branch = id(new ReleephBranchQuery())
|
|
->setViewer($viewer)
|
|
->withIDs(array($id))
|
|
->executeOne();
|
|
if (!$branch) {
|
|
return new Aphront404Response();
|
|
}
|
|
$this->setBranch($branch);
|
|
|
|
$controller = id(new PhabricatorApplicationSearchController())
|
|
->setPreface($this->renderPreface())
|
|
->setQueryKey($querykey)
|
|
->setSearchEngine($this->getSearchEngine())
|
|
->setNavigation($this->buildSideNavView());
|
|
|
|
return $this->delegateToController($controller);
|
|
}
|
|
|
|
|
|
public function buildSideNavView($for_app = false) {
|
|
$user = $this->getRequest()->getUser();
|
|
|
|
$nav = new AphrontSideNavFilterView();
|
|
$nav->setBaseURI(new PhutilURI($this->getApplicationURI()));
|
|
|
|
$this->getSearchEngine()->addNavigationItems($nav->getMenu());
|
|
|
|
$nav->selectFilter(null);
|
|
|
|
return $nav;
|
|
}
|
|
|
|
private function getSearchEngine() {
|
|
$branch = $this->getBranch();
|
|
return id(new ReleephRequestSearchEngine())
|
|
->setBranch($branch)
|
|
->setBaseURI($this->getApplicationURI('branch/'.$branch->getID().'/'))
|
|
->setViewer($this->getRequest()->getUser());
|
|
}
|
|
|
|
protected function buildApplicationCrumbs() {
|
|
$crumbs = parent::buildApplicationCrumbs();
|
|
|
|
$branch = $this->getBranch();
|
|
if ($branch) {
|
|
$pull_uri = $this->getApplicationURI('branch/pull/'.$branch->getID().'/');
|
|
$crumbs->addAction(
|
|
id(new PHUIListItemView())
|
|
->setHref($pull_uri)
|
|
->setName(pht('New Pull Request'))
|
|
->setIcon('fa-plus-square')
|
|
->setDisabled(!$branch->isActive()));
|
|
}
|
|
|
|
return $crumbs;
|
|
}
|
|
|
|
private function renderPreface() {
|
|
$viewer = $this->getRequest()->getUser();
|
|
|
|
$branch = $this->getBranch();
|
|
$id = $branch->getID();
|
|
|
|
$header = id(new PHUIHeaderView())
|
|
->setHeader($branch->getDisplayName())
|
|
->setUser($viewer)
|
|
->setPolicyObject($branch);
|
|
|
|
if ($branch->getIsActive()) {
|
|
$header->setStatus('fa-check', 'bluegrey', pht('Active'));
|
|
} else {
|
|
$header->setStatus('fa-ban', 'dark', pht('Closed'));
|
|
}
|
|
|
|
$actions = id(new PhabricatorActionListView())
|
|
->setUser($viewer)
|
|
->setObject($branch);
|
|
|
|
$can_edit = PhabricatorPolicyFilter::hasCapability(
|
|
$viewer,
|
|
$branch,
|
|
PhabricatorPolicyCapability::CAN_EDIT);
|
|
|
|
$edit_uri = $this->getApplicationURI("branch/edit/{$id}/");
|
|
$close_uri = $this->getApplicationURI("branch/close/{$id}/");
|
|
$reopen_uri = $this->getApplicationURI("branch/re-open/{$id}/");
|
|
$history_uri = $this->getApplicationURI("branch/{$id}/history/");
|
|
|
|
$actions->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Edit Branch'))
|
|
->setHref($edit_uri)
|
|
->setIcon('fa-pencil')
|
|
->setDisabled(!$can_edit)
|
|
->setWorkflow(!$can_edit));
|
|
|
|
if ($branch->getIsActive()) {
|
|
$actions->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Close Branch'))
|
|
->setHref($close_uri)
|
|
->setIcon('fa-times')
|
|
->setDisabled(!$can_edit)
|
|
->setWorkflow(true));
|
|
} else {
|
|
$actions->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Reopen Branch'))
|
|
->setHref($reopen_uri)
|
|
->setIcon('fa-plus')
|
|
->setUser($viewer)
|
|
->setDisabled(!$can_edit)
|
|
->setWorkflow(true));
|
|
}
|
|
|
|
$actions->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('View History'))
|
|
->setHref($history_uri)
|
|
->setIcon('fa-list'));
|
|
|
|
$properties = id(new PHUIPropertyListView())
|
|
->setUser($viewer)
|
|
->setObject($branch)
|
|
->setActionList($actions);
|
|
|
|
$properties->addProperty(
|
|
pht('Branch'),
|
|
$branch->getName());
|
|
|
|
return id(new PHUIObjectBoxView())
|
|
->setHeader($header)
|
|
->addPropertyList($properties);
|
|
}
|
|
|
|
}
|