getConstant('CAPABILITY'); if ($const === false) { throw new Exception( pht( 'PolicyCapability class "%s" must define an CAPABILITY property.', get_class($this))); } if (!is_string($const)) { throw new Exception( pht( 'PolicyCapability class "%s" has an invalid CAPABILITY '. 'property. Capability constants must be a string.', get_class($this))); } return $const; } /** * 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; } }