winter/modules/backend/models/UserRole.php

82 lines
1.9 KiB
PHP

<?php namespace Backend\Models;
use Backend\Classes\AuthManager;
use Winter\Storm\Auth\Models\Role as RoleBase;
/**
* Administrator role
*
* @package winter\wn-backend-module
* @author Alexey Bobkov, Samuel Georges
*/
class UserRole extends RoleBase
{
const CODE_DEVELOPER = 'developer';
const CODE_PUBLISHER = 'publisher';
/**
* @var string The database table used by the model.
*/
protected $table = 'backend_user_roles';
/**
* @var array Validation rules
*/
public $rules = [
'name' => 'required|between:2,128|unique:backend_user_roles',
'code' => 'unique:backend_user_roles',
];
/**
* @var array Relations
*/
public $hasMany = [
'users' => [User::class, 'key' => 'role_id'],
'users_count' => [User::class, 'key' => 'role_id', 'count' => true]
];
public function filterFields($fields)
{
if ($this->is_system) {
$fields->code->disabled = true;
$fields->permissions->disabled = true;
}
}
public function afterFetch()
{
if ($this->is_system) {
$this->permissions = $this->getDefaultPermissions();
}
}
public function beforeSave()
{
if ($this->isSystemRole()) {
$this->is_system = true;
$this->permissions = [];
}
}
public function isSystemRole()
{
if (!$this->code || !strlen(trim($this->code))) {
return false;
}
if ($this->is_system || in_array($this->code, [
self::CODE_DEVELOPER,
self::CODE_PUBLISHER
])) {
return true;
}
return AuthManager::instance()->hasPermissionsForRole($this->code);
}
public function getDefaultPermissions()
{
return AuthManager::instance()->listPermissionsForRole($this->code);
}
}