kak / rbac
rbac manager for Yii2
1.0.7
2023-03-24 12:01 UTC
Requires
- kak/grid: >=1.0
- kak/itemselect: >=1.0
- kak/panel: >=1.0
- kak/select2: *
- yiisoft/yii2: *
README
fork for
install
step 1
The preferred way to install this extension is through composer. Either run
php composer.phar require --prefer-dist kak/rbac ">=1.0"
or add
"kak/rbac": ">=1.0"
step 2
add config web.php
'authManager' => [
'class' => 'kak\rbac\components\DbManager',
'defaultRoles' => [
'guest',
'user'
],
],
step 3
create tables
yii migrate --migrationPath=@yii/rbac/migrations
Insert base rbac rules
yii migrate --migrationPath=@vendor/kak/rbac/migrations
step 4
Using module admin RBAC
$config['modules']['rbac'] = [
'class' => 'kak\rbac\Module',
// set custom Layout
'mainLayout' => '@app/modules/dashboard/views/layouts/main.php',
'layout' => 'main',
'userAttributes' => [
'username',
'email'
]
// desable check rbac - default true
'checkAccessPermissionAdministrateRbac' => false
];
Controllers rules base
Consts
interface PermissionConst { const ItemView = 'ItemView', ItemUpdate = 'ItemUpdate', ItemCreate = 'ItemCreate', ItemDelete = 'ItemDelete', UpdateOwn = 'UpdateOwn', DeleteOwn = 'DeleteOwn', AuthorRule = 'AuthorRule'; }
public function behaviors() { return [ 'access' => [ 'class' => yii\filters\AccessControl::className(), 'rules' => [ [ 'actions' => ['index', 'create'], 'allow' => true, 'roles' => [User::ROLE_ADMIN,User::ROLE_MANAGER], ],[ 'actions' => ['update'], 'allow' => true, 'roles' => [User::ROLE_ADMIN, User::ROLE_MANAGER ], ],[ 'actions' => ['delete'], 'allow' => true, 'roles' => [User::ROLE_ADMIN], ],[ 'actions' => ['about'], 'allow' => true, 'roles' => ["?" , "@"], ] ], ], ]; }
using context access rule
public function behaviors() { return [ 'access' => [ 'class' => AccessControl::className(), 'rules' => [ [ 'actions' => ['index', 'create'], 'allow' => true, 'roles' => ['@'], ],[ 'class' => 'kak\rbac\rules\ContextAccessRule', 'modelClass' => 'app\models\Stream', 'actions' => ['update'], 'roles' => [PermissionConst::UpdateOwn], ],[ 'class' => 'kak\rbac\rules\ContextAccessRule', 'modelClass' => 'app\models\Stream', 'actions' => ['delete'], 'roles' => [PermissionConst::DeleteOwn], ] ], ], ]; }
is current user personal check permission
$isAccess = Yii::$app->user->can(PermissionConst::ItemCreate) && Yii::$app->user->can(User::ROLE_ADMIN);