kak/rbac
最新稳定版本:1.0.7
Composer 安装命令:
composer require kak/rbac
包简介
rbac manager for Yii2
README 文档
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);
统计信息
- 总下载量: 1.06k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 9
- 点击次数: 0
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2017-04-05