silverstripe-framework/src/Security/PermissionRoleCode.php

68 lines
1.7 KiB
PHP
Raw Normal View History

<?php
2016-06-23 01:37:22 +02:00
namespace SilverStripe\Security;
use SilverStripe\ORM\DataObject;
use SilverStripe\Security\PermissionRole;
2016-06-23 01:37:22 +02:00
/**
* A PermissionRoleCode represents a single permission code assigned to a {@link PermissionRole}.
2014-08-15 08:53:05 +02:00
*
* @property string Code
* @property int RoleID
* @method PermissionRole Role()
*/
2016-11-29 00:31:16 +01:00
class PermissionRoleCode extends DataObject
{
private static $db = [
"Code" => "Varchar",
];
2016-11-29 00:31:16 +01:00
private static $has_one = [
"Role" => PermissionRole::class,
];
2016-11-29 00:31:16 +01:00
private static $table_name = "PermissionRoleCode";
private static $indexes = [
"Code" => true,
];
2016-11-29 00:31:16 +01:00
public function validate()
{
$result = parent::validate();
2016-11-29 00:31:16 +01:00
// Check that new code doesn't increase privileges, unless an admin is editing.
$privilegedCodes = Permission::config()->privileged_permissions;
2016-11-29 00:31:16 +01:00
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;
}
2016-11-29 00:31:16 +01:00
public function canCreate($member = null, $context = [])
2016-11-29 00:31:16 +01:00
{
return Permission::check('APPLY_ROLES', 'any', $member);
}
2016-11-29 00:31:16 +01:00
public function canEdit($member = null)
{
return Permission::check('APPLY_ROLES', 'any', $member);
}
2016-11-29 00:31:16 +01:00
public function canDelete($member = null)
{
return Permission::check('APPLY_ROLES', 'any', $member);
}
}