mirror of
https://we.phorge.it/source/phorge.git
synced 2025-03-28 12:08:14 +01:00
Summary: Ref T3675. Some of these listeners shouldn't do their thing if the viewer doesn't have access to an application (for example, users without access to Differential should not be able to "Edit Tasks"). Set the stage for that: - Introduce `PhabricatorEventListener`, which has an application. - Populate this for event listeners installed by applications. - Rename the "PeopleMenu" listeners to "ActionMenu" listeners, which better describes their modern behavior. This doesn't actually change any behaviors. Test Plan: Viewed Maniphest, Differntial, People. Reviewers: btrahan, chad Reviewed By: btrahan CC: aran Maniphest Tasks: T3675 Differential Revision: https://secure.phabricator.com/D7364
119 lines
3.2 KiB
PHP
119 lines
3.2 KiB
PHP
<?php
|
|
|
|
final class PhabricatorApplicationManiphest extends PhabricatorApplication {
|
|
|
|
public function getShortDescription() {
|
|
return 'Tasks and Bugs';
|
|
}
|
|
|
|
public function getBaseURI() {
|
|
return '/maniphest/';
|
|
}
|
|
|
|
public function getIconName() {
|
|
return 'maniphest';
|
|
}
|
|
|
|
public function getApplicationGroup() {
|
|
return self::GROUP_CORE;
|
|
}
|
|
|
|
public function getApplicationOrder() {
|
|
return 0.110;
|
|
}
|
|
|
|
public function getFactObjectsForAnalysis() {
|
|
return array(
|
|
new ManiphestTask(),
|
|
);
|
|
}
|
|
|
|
public function getQuickCreateURI() {
|
|
return $this->getBaseURI().'task/create/';
|
|
}
|
|
|
|
public function getEventListeners() {
|
|
return array(
|
|
new ManiphestNameIndexEventListener(),
|
|
new ManiphestActionMenuEventListener(),
|
|
new ManiphestHovercardEventListener(),
|
|
);
|
|
}
|
|
|
|
public function getRemarkupRules() {
|
|
return array(
|
|
new ManiphestRemarkupRule(),
|
|
);
|
|
}
|
|
|
|
public function getRoutes() {
|
|
return array(
|
|
'/T(?P<id>[1-9]\d*)' => 'ManiphestTaskDetailController',
|
|
'/maniphest/' => array(
|
|
'(?:query/(?P<queryKey>[^/]+)/)?' => 'ManiphestTaskListController',
|
|
'report/(?:(?P<view>\w+)/)?' => 'ManiphestReportController',
|
|
'batch/' => 'ManiphestBatchEditController',
|
|
'task/' => array(
|
|
'create/' => 'ManiphestTaskEditController',
|
|
'edit/(?P<id>[1-9]\d*)/' => 'ManiphestTaskEditController',
|
|
'descriptionpreview/' =>
|
|
'PhabricatorMarkupPreviewController',
|
|
),
|
|
'transaction/' => array(
|
|
'save/' => 'ManiphestTransactionSaveController',
|
|
'preview/(?P<id>[1-9]\d*)/'
|
|
=> 'ManiphestTransactionPreviewController',
|
|
),
|
|
'export/(?P<key>[^/]+)/' => 'ManiphestExportController',
|
|
'subpriority/' => 'ManiphestSubpriorityController',
|
|
'subscribe/(?P<action>add|rem)/(?P<id>[1-9]\d*)/'
|
|
=> 'ManiphestSubscribeController',
|
|
),
|
|
);
|
|
}
|
|
|
|
public function loadStatus(PhabricatorUser $user) {
|
|
$status = array();
|
|
|
|
$query = id(new ManiphestTaskQuery())
|
|
->setViewer($user)
|
|
->withStatus(ManiphestTaskQuery::STATUS_OPEN)
|
|
->withOwners(array($user->getPHID()));
|
|
$count = count($query->execute());
|
|
|
|
$type = PhabricatorApplicationStatusView::TYPE_WARNING;
|
|
$status[] = id(new PhabricatorApplicationStatusView())
|
|
->setType($type)
|
|
->setText(pht('%s Assigned Task(s)', new PhutilNumber($count)))
|
|
->setCount($count);
|
|
|
|
return $status;
|
|
}
|
|
|
|
protected function getCustomCapabilities() {
|
|
return array(
|
|
ManiphestCapabilityDefaultView::CAPABILITY => array(
|
|
'caption' => pht(
|
|
'Default view policy for newly created tasks.'),
|
|
),
|
|
ManiphestCapabilityDefaultEdit::CAPABILITY => array(
|
|
'caption' => pht(
|
|
'Default edit policy for newly created tasks.'),
|
|
),
|
|
ManiphestCapabilityEditStatus::CAPABILITY => array(
|
|
),
|
|
ManiphestCapabilityEditAssign::CAPABILITY => array(
|
|
),
|
|
ManiphestCapabilityEditPolicies::CAPABILITY => array(
|
|
),
|
|
ManiphestCapabilityEditPriority::CAPABILITY => array(
|
|
),
|
|
ManiphestCapabilityEditProjects::CAPABILITY => array(
|
|
),
|
|
ManiphestCapabilityBulkEdit::CAPABILITY => array(
|
|
),
|
|
);
|
|
}
|
|
|
|
}
|
|
|