1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20: 21: 22: 23: 24: 25: 26: 27: 28: 29: 30: 31: 32: 33: 34: 35: 36: 37: 38: 39: 40: 41: 42: 43: 44: 45: 46: 47:
<?php
/**
* MvcCore
*
* This source file is subject to the BSD 3 License
* For the full copyright and license information, please view
* the LICENSE.md file that are distributed with this source code.
*
* @copyright Copyright (c) 2016 Tom Flidr (https://github.com/mvccore)
* @license https://mvccore.github.io/docs/mvccore/5.0.0/LICENCE.md
*/
namespace MvcCore\Ext\Auths\Basics;
use \MvcCore\Ext\Models\Db\Attrs;
/**
* Responsibility - base role model class.
* This class is necessary to extend and implement method
* `GetByName()` or more. It's also necessary to implement
* loading users with roles and their permissions to be able
* to check user roles and permissions.
* @table roles
*/
#[Attrs\Table('roles')]
class Role
extends \MvcCore\Model
implements \MvcCore\Ext\Auths\Basics\IRole {
use \MvcCore\Ext\Auths\Basics\Role\Features;
/**
* Get role instance from application roles list. It could be database or any other custom resource.
* @param string $name Role unique name.
* @throws \RuntimeException
* @return \MvcCore\Ext\Auths\Basics\Role
*/
public function GetByName ($roleName) {
$selfClass = get_class();
throw new \RuntimeException(
'['.$selfClass.'] Method is not implemented. '
.'Extend class `'.$selfClass.'` and implement method `GetByName ($roleName)` by your own.'
);
}
}