Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F98076080
PhabricatorPolicyConfigOptions.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
Thu, Jan 9, 13:11
Size
2 KB
Mime Type
text/x-php
Expires
Sat, Jan 11, 13:11 (2 d)
Engine
blob
Format
Raw Data
Handle
23500106
Attached To
rPH Phabricator
PhabricatorPolicyConfigOptions.php
View Options
<?php
final
class
PhabricatorPolicyConfigOptions
extends
PhabricatorApplicationConfigOptions
{
public
function
getName
()
{
return
pht
(
'Policy'
);
}
public
function
getDescription
()
{
return
pht
(
'Options relating to object visibility.'
);
}
public
function
getFontIcon
()
{
return
'fa-lock'
;
}
public
function
getOptions
()
{
$policy_locked_type
=
'custom:PolicyLockOptionType'
;
$policy_locked_example
=
array
(
'people.create.users'
=>
'admin'
,);
$json
=
new
PhutilJSON
();
$policy_locked_example
=
$json
->
encodeFormatted
(
$policy_locked_example
);
return
array
(
$this
->
newOption
(
'policy.allow-public'
,
'bool'
,
false
)
->
setBoolOptions
(
array
(
pht
(
'Allow Public Visibility'
),
pht
(
'Require Login'
),
))
->
setSummary
(
pht
(
'Allow users to set object visibility to public.'
))
->
setDescription
(
pht
(
"Phabricator allows you to set the visibility of objects (like "
.
"repositories and tasks) to 'Public', which means **anyone "
.
"on the internet can see them, without needing to log in or "
.
"have an account**."
.
"
\n\n
"
.
"This is intended for open source projects. Many installs will "
.
"never want to make anything public, so this policy is disabled "
.
"by default. You can enable it here, which will let you set the "
.
"policy for objects to 'Public'."
.
"
\n\n
"
.
"Enabling this setting will immediately open up some features, "
.
"like the user directory. Anyone on the internet will be able to "
.
"access these features."
.
"
\n\n
"
.
"With this setting disabled, the 'Public' policy is not "
.
"available, and the most open policy is 'All Users' (which means "
.
"users must have accounts and be logged in to view things)."
)),
$this
->
newOption
(
'policy.locked'
,
$policy_locked_type
,
array
())
->
setLocked
(
true
)
->
setSummary
(
pht
(
'Lock specific application policies so they can not be edited.'
))
->
setDescription
(
pht
(
'Phabricator has application policies which can dictate whether '
.
'users can take certain actions, such as creating new users. '
.
"
\n\n
"
.
'This setting allows for "locking" these policies such that no '
.
'further edits can be made on a per-policy basis.'
))
->
addExample
(
$policy_locked_example
,
pht
(
'Lock Create User Policy To Admins'
)),
);
}
}
Event Timeline
Log In to Comment