Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F98345065
PhabricatorPolicyCapability.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Sun, Jan 12, 07:41
Size
2 KB
Mime Type
text/x-php
Expires
Tue, Jan 14, 07:41 (1 d, 20 h)
Engine
blob
Format
Raw Data
Handle
23565663
Attached To
rPH Phabricator
PhabricatorPolicyCapability.php
View Options
<?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.
*/
final
public
function
getCapabilityKey
()
{
$class
=
new
ReflectionClass
(
$this
);
$const
=
$class
->
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
;
}
}
Event Timeline
Log In to Comment