mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
64 lines
1.6 KiB
PHP
64 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace SilverStripe\Security;
|
|
|
|
use SilverStripe\ORM\DataObject;
|
|
use SilverStripe\Security\PermissionRole;
|
|
|
|
/**
|
|
* A PermissionRoleCode represents a single permission code assigned to a {@link PermissionRole}.
|
|
*
|
|
* @property string Code
|
|
* @property int RoleID
|
|
* @method PermissionRole Role()
|
|
*/
|
|
class PermissionRoleCode extends DataObject
|
|
{
|
|
private static $db = [
|
|
"Code" => "Varchar",
|
|
];
|
|
|
|
private static $has_one = [
|
|
"Role" => PermissionRole::class,
|
|
];
|
|
|
|
private static $table_name = "PermissionRoleCode";
|
|
|
|
public function validate()
|
|
{
|
|
$result = parent::validate();
|
|
|
|
// Check that new code doesn't increase privileges, unless an admin is editing.
|
|
$privilegedCodes = Permission::config()->privileged_permissions;
|
|
if ($this->Code
|
|
&& in_array($this->Code, $privilegedCodes)
|
|
&& !Permission::check('ADMIN')
|
|
) {
|
|
$result->addError(
|
|
_t(
|
|
__CLASS__ . '.PermsError',
|
|
'Can\'t assign code "{code}" with privileged permissions (requires ADMIN access)',
|
|
['code' => $this->Code]
|
|
)
|
|
);
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
public function canCreate($member = null, $context = [])
|
|
{
|
|
return Permission::check('APPLY_ROLES', 'any', $member);
|
|
}
|
|
|
|
public function canEdit($member = null)
|
|
{
|
|
return Permission::check('APPLY_ROLES', 'any', $member);
|
|
}
|
|
|
|
public function canDelete($member = null)
|
|
{
|
|
return Permission::check('APPLY_ROLES', 'any', $member);
|
|
}
|
|
}
|