mirror of
https://we.phorge.it/source/phorge.git
synced 2025-03-02 23:49:19 +01:00
Summary: - Removed trailing newlines. - Added newline at EOF. - Removed leading newlines. - Trimmed trailing whitespace. - Spelling fix. - Added newline at EOF Test Plan: N/A Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley CC: hach-que, chad, Korvin, epriestley, aran Differential Revision: https://secure.phabricator.com/D8344
70 lines
1.8 KiB
PHP
70 lines
1.8 KiB
PHP
<?php
|
|
|
|
abstract class PhabricatorPolicyCapability extends Phobject {
|
|
|
|
const CAN_VIEW = 'view';
|
|
const CAN_EDIT = 'edit';
|
|
const CAN_JOIN = 'join';
|
|
|
|
/**
|
|
* Get the unique key identifying this capability. This key must be globally
|
|
* unique. Application capabilities should be namespaced. For example:
|
|
*
|
|
* application.create
|
|
*
|
|
* @return string Globally unique capability key.
|
|
*/
|
|
abstract public function getCapabilityKey();
|
|
|
|
|
|
/**
|
|
* Return a human-readable descriptive name for this capability, like
|
|
* "Can View".
|
|
*
|
|
* @return string Human-readable name describing the capability.
|
|
*/
|
|
abstract public function getCapabilityName();
|
|
|
|
|
|
/**
|
|
* Return a human-readable string describing what not having this capability
|
|
* prevents the user from doing. For example:
|
|
*
|
|
* - You do not have permission to edit this object.
|
|
* - You do not have permission to create new tasks.
|
|
*
|
|
* @return string Human-readable name describing what failing a check for this
|
|
* capability prevents the user from doing.
|
|
*/
|
|
public function describeCapabilityRejection() {
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
* Can this capability be set to "public"? Broadly, this is only appropriate
|
|
* for view and view-related policies.
|
|
*
|
|
* @return bool True to allow the "public" policy. Returns false by default.
|
|
*/
|
|
public function shouldAllowPublicPolicySetting() {
|
|
return false;
|
|
}
|
|
|
|
final public static function getCapabilityByKey($key) {
|
|
return idx(self::getCapabilityMap(), $key);
|
|
}
|
|
|
|
final public static function getCapabilityMap() {
|
|
static $map;
|
|
if ($map === null) {
|
|
$capabilities = id(new PhutilSymbolLoader())
|
|
->setAncestorClass(__CLASS__)
|
|
->loadObjects();
|
|
|
|
$map = mpull($capabilities, null, 'getCapabilityKey');
|
|
}
|
|
|
|
return $map;
|
|
}
|
|
|
|
}
|