Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ahmadasjad/yii2-rbac-plus
Database role base access control manager for yii2
https://github.com/ahmadasjad/yii2-rbac-plus
rbac yii2 yii2-extension yii2-rbac
Last synced: 6 days ago
JSON representation
Database role base access control manager for yii2
- Host: GitHub
- URL: https://github.com/ahmadasjad/yii2-rbac-plus
- Owner: ahmadasjad
- Created: 2016-07-19T07:09:20.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2017-01-08T11:23:50.000Z (over 7 years ago)
- Last Synced: 2024-09-25T20:47:14.606Z (10 days ago)
- Topics: rbac, yii2, yii2-extension, yii2-rbac
- Language: PHP
- Homepage:
- Size: 73.2 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
yii2-rbac-plus
=============
[![Latest Stable Version](https://poser.pugx.org/ahmadasjad/yii2-rbac-plus/v/stable)](https://packagist.org/packages/ahmadasjad/yii2-rbac-plus)
[![License](https://poser.pugx.org/ahmadasjad/yii2-rbac-plus/license)](https://packagist.org/packages/ahmadasjad/yii2-rbac-plus)
[![Total Downloads](https://poser.pugx.org/ahmadasjad/yii2-rbac-plus/downloads)](https://packagist.org/packages/ahmadasjad/yii2-rbac-plus)
[![Monthly Downloads](https://poser.pugx.org/ahmadasjad/yii2-rbac-plus/d/monthly)](https://packagist.org/packages/ahmadasjad/yii2-rbac-plus)
[![Daily Downloads](https://poser.pugx.org/ahmadasjad/yii2-rbac-plus/d/daily)](https://packagist.org/packages/ahmadasjad/yii2-rbac-plus)Database role base access control manager for yii2
Actually, this is duplicate repo of https://github.com/johnitvn/yii2-rbac-plus
Due to not being active and pulling request of contributor or listening to them, I created this one.Features
------------
+ CRUD operations for roles, permissions and rules
+ Allows to assign multiple roles to user
+ Nice views to intergrate right away
+ Integrated with [Yii2-user-plus](https://github.com/ahmadasjad/yii2-user-plus) - flexible user management moduleInstallation
------------The preferred way to install this extension is through [composer](http://getcomposer.org/download/).
Either run
```
php composer.phar require --prefer-dist ahmadasjad/yii2-rbac-plus "*"
```or add
```
"ahmadasjad/yii2-rbac-plus": "*"
```to the require section of your `composer.json` file.
Usage
-----
1. Let 's add into modules config in your main config file````
'components' => [
'authManager' => [
'class' => 'yii\rbac\DbManager',
],
],
'modules' => [
'rbac' => [
'class' => 'ahmadasjad\rbacplus\Module'
]
]
````Next, update the database schema
````
$ php yii migrate/up --migrationPath=@yii/rbac/migrations
````Ok. That's done. Avaiable route now:
+ /rbac/rule
+ /rbac/permission
+ /rbac/role
+ /rbac/assignment2. The module configuration avaible:
````
'modules' => [
'rbac' => [
'class' => 'ahmadasjad\rbacplus\Module',
'userModelClassName'=>null,
'userModelIdField'=>'id',
'userModelLoginField'=>'username',
'userModelLoginFieldLabel'=>null,
'userModelExtraDataColumls'=>null,
'beforeCreateController'=>null,
'beforeAction'=>null
]
]
````+ userModelClassName: The user model class.
If you not set or set null, RBAC Plus will be get from `Yii::$app->getUser()->identityClass`
+ userModelIdField: The user model id field.
Default id field is 'id', you must set this config if primary key of user table in database is not 'id'
+ userModelLoginField The user model login field.
Default login field is 'username'. Maybe you use email field or something other for login. So you must change this config
+ userModelLoginFieldLabel The user model login field label.
If you set null the label will get from `$userModelClass->attributeLabels()[$userModelLoginField]`
+ userModelExtraDataColumls The extra data columns you want to show in user assign views.
The default in assignment data gridview just display id and login column data. if you want to add created_at column you can add
````php
'userModelExtraDataColumls'=>[
[
'attributes'=>'created_at',
'value'=>function($model){
return date('m/d/Y', $model->created_at);
}
]
]
````
+ beforeCreateController The callable before create all controller of Rbac Plus module.
The default it is null. You need config this when you want to restrict access to Rbac Plus module.
Example:
````php
'beforeCreateController'=>function($route){
/**
*@var string $route The route consisting of module, controller and action IDs.
*/
}
````
+ beforeActionThe callable before action of all controller in Rbac Plus module.
The default it is null. You need config this when you want to restrict access to any action in some controller of Rbac Plus module
Example:
````php
'beforeAction'=>function($action){
/**
*@var yii\base\Action $action the action to be executed.
*/
}
````