mirror of
https://we.phorge.it/source/phorge.git
synced 2025-04-04 16:38:24 +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
143 lines
3.8 KiB
PHP
143 lines
3.8 KiB
PHP
<?php
|
|
|
|
final class PhabricatorSpacesViewController
|
|
extends PhabricatorSpacesController {
|
|
|
|
public function shouldAllowPublic() {
|
|
return true;
|
|
}
|
|
|
|
public function handleRequest(AphrontRequest $request) {
|
|
$viewer = $this->getViewer();
|
|
|
|
$space = id(new PhabricatorSpacesNamespaceQuery())
|
|
->setViewer($viewer)
|
|
->withIDs(array($request->getURIData('id')))
|
|
->executeOne();
|
|
if (!$space) {
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
$action_list = $this->buildActionListView($space);
|
|
$property_list = $this->buildPropertyListView($space);
|
|
$property_list->setActionList($action_list);
|
|
|
|
$xactions = id(new PhabricatorSpacesNamespaceTransactionQuery())
|
|
->setViewer($viewer)
|
|
->withObjectPHIDs(array($space->getPHID()))
|
|
->execute();
|
|
|
|
$timeline = $this->buildTransactionTimeline(
|
|
$space,
|
|
new PhabricatorSpacesNamespaceTransactionQuery());
|
|
$timeline->setShouldTerminate(true);
|
|
|
|
$header = id(new PHUIHeaderView())
|
|
->setUser($viewer)
|
|
->setHeader($space->getNamespaceName())
|
|
->setPolicyObject($space);
|
|
|
|
if ($space->getIsArchived()) {
|
|
$header->setStatus('fa-ban', 'red', pht('Archived'));
|
|
} else {
|
|
$header->setStatus('fa-check', 'bluegrey', pht('Active'));
|
|
}
|
|
|
|
$box = id(new PHUIObjectBoxView())
|
|
->setHeader($header)
|
|
->addPropertyList($property_list);
|
|
|
|
$crumbs = $this->buildApplicationCrumbs();
|
|
$crumbs->addTextCrumb($space->getMonogram());
|
|
|
|
return $this->buildApplicationPage(
|
|
array(
|
|
$crumbs,
|
|
$box,
|
|
$timeline,
|
|
),
|
|
array(
|
|
'title' => array($space->getMonogram(), $space->getNamespaceName()),
|
|
));
|
|
}
|
|
|
|
private function buildPropertyListView(PhabricatorSpacesNamespace $space) {
|
|
$viewer = $this->getRequest()->getUser();
|
|
|
|
$list = id(new PHUIPropertyListView())
|
|
->setUser($viewer);
|
|
|
|
$list->addProperty(
|
|
pht('Default Space'),
|
|
$space->getIsDefaultNamespace()
|
|
? pht('Yes')
|
|
: pht('No'));
|
|
|
|
$descriptions = PhabricatorPolicyQuery::renderPolicyDescriptions(
|
|
$viewer,
|
|
$space);
|
|
|
|
$list->addProperty(
|
|
pht('Editable By'),
|
|
$descriptions[PhabricatorPolicyCapability::CAN_EDIT]);
|
|
|
|
$description = $space->getDescription();
|
|
if (strlen($description)) {
|
|
$description = PhabricatorMarkupEngine::renderOneObject(
|
|
id(new PhabricatorMarkupOneOff())->setContent($description),
|
|
'default',
|
|
$viewer);
|
|
|
|
$list->addSectionHeader(
|
|
pht('Description'),
|
|
PHUIPropertyListView::ICON_SUMMARY);
|
|
|
|
$list->addTextContent($description);
|
|
}
|
|
|
|
return $list;
|
|
}
|
|
|
|
private function buildActionListView(PhabricatorSpacesNamespace $space) {
|
|
$viewer = $this->getRequest()->getUser();
|
|
|
|
$list = id(new PhabricatorActionListView())
|
|
->setUser($viewer);
|
|
|
|
$can_edit = PhabricatorPolicyFilter::hasCapability(
|
|
$viewer,
|
|
$space,
|
|
PhabricatorPolicyCapability::CAN_EDIT);
|
|
|
|
$list->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Edit Space'))
|
|
->setIcon('fa-pencil')
|
|
->setHref($this->getApplicationURI('edit/'.$space->getID().'/'))
|
|
->setWorkflow(!$can_edit)
|
|
->setDisabled(!$can_edit));
|
|
|
|
$id = $space->getID();
|
|
|
|
if ($space->getIsArchived()) {
|
|
$list->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Activate Space'))
|
|
->setIcon('fa-check')
|
|
->setHref($this->getApplicationURI("activate/{$id}/"))
|
|
->setDisabled(!$can_edit)
|
|
->setWorkflow(true));
|
|
} else {
|
|
$list->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Archive Space'))
|
|
->setIcon('fa-ban')
|
|
->setHref($this->getApplicationURI("archive/{$id}/"))
|
|
->setDisabled(!$can_edit)
|
|
->setWorkflow(true));
|
|
}
|
|
|
|
return $list;
|
|
}
|
|
|
|
}
|