jeffwalsh / yii2-rbac-plus
yii2的数据库角色基于访问控制管理器
1.0.9
2017-12-06 21:49 UTC
Requires
- templesuite/yii2-ajaxcrud: 3.0.0
- yiisoft/yii2: >=2.0.4
Suggests
- johnitvn/yii2-user-plus: High flexible user management extension for yii2
README
yii2的数据库角色基于访问控制管理器
功能
- 对角色、权限和规则的CRUD操作
- 允许为用户分配多个角色
- 美观的视图,可立即集成
- 与Yii2-user-plus集成 - 灵活的用户管理模块
安装
安装此扩展的首选方式是通过composer。
运行以下命令之一:
php composer.phar require --prefer-dist johnitvn/yii2-rbac-plus "*"
或将以下内容添加到您的composer.json
文件的require部分:
"johnitvn/yii2-rbac-plus": "*"
用法
- 让我们将以下内容添加到主配置文件中的模块配置
'components' => [
'authManager' => [
'class' => 'yii\rbac\DbManager',
],
],
'modules' => [
'rbac' => [
'class' => 'johnitvn\rbacplus\Module'
]
]
然后,更新数据库模式
$ php yii migrate/up --migrationPath=@yii/rbac/migrations
好了。完成了。现在可用的路由
- /rbac/rule
- /rbac/permission
- /rbac/role
- /rbac/assignment
- 模块配置可用
'modules' => [
'rbac' => [
'class' => 'johnitvn\rbacplus\Module',
'userModelClassName'=>null,
'userModelIdField'=>'id',
'userModelLoginField'=>'username',
'userModelLoginFieldLabel'=>null,
'userModelExtraDataColumls'=>null,
'beforeCreateController'=>null,
'beforeAction'=>null
]
]
- userModelClassName: 用户模型类。
如果未设置或设置为null,RBAC Plus将来自Yii::$app->getUser()->identityClass
- userModelIdField: 用户模型id字段。
默认id字段是'id',如果您数据库中用户表的主键不是'id',则必须设置此配置 - userModelLoginField 用户模型登录字段。
默认登录字段是'username'。也许您使用电子邮件字段或某些其他字段进行登录。因此,您必须更改此配置 - userModelLoginFieldLabel 用户模型登录字段标签。
如果设置为null,标签将来自$userModelClass->attributeLabels()[$userModelLoginField]
- userModelExtraDataColumls 您希望在用户分配视图中显示的额外数据列。
默认情况下,分配数据网格视图仅显示id和登录列数据。如果您想添加created_at列,可以添加以下内容
'userModelExtraDataColumls'=>[ [ 'attributes'=>'created_at', 'value'=>function($model){ return date('m/d/Y', $model->created_at); } ] ]
- beforeCreateController 在Rbac Plus模块的所有控制器创建之前调用的调用。默认为null。当您想限制对Rbac Plus模块的访问时,您需要配置此设置。
示例
'beforeCreateController'=>function($route){ /** *@var string $route The route consisting of module, controller and action IDs. */ }
- beforeAction Rbac Plus模块中所有控制器中动作之前调用的调用。
默认为null。当您想限制对Rbac Plus模块中某些控制器中任何动作的访问时,您需要配置此设置。
示例
'beforeAction'=>function($action){ /** *@var yii\base\Action $action the action to be executed. */ }