myzero1 / yii2-rbacp
Simple captcha for yii2.Just add the module in config file and use the widget.
Installs: 288
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 0
Open Issues: 0
Type:yii2-module
Requires
- yiisoft/yii2: ~2.0
This package is not auto-updated.
Last update: 2025-01-20 05:06:57 UTC
README
Access modules,including functional access and data access.
Show time
Installation
The preferred way to install this module is through composer.
Either run
php composer.phar require myzero1/yii2-rbacp:1.*
or add
"myzero1/yii2-rbacp": "~1"
to the require section of your composer.json
file.
Setting
Once the extension is installed, simply modify your application configuration as follows:
return [ ...... 'bootstrap' => [ ...... 'rbacp' => [ 'class' => '\myzero1\rbacp\Bootstrap', // for rbacp function 'params' => [ 'urlManager' => [ 'rules' => [ // 'rate/area/index' => 'rate/jf-core-area/index', ], ], 'rbacp' => [ 'model' => 'rbac',//everyone,logined,rbac,rbacp 'develop' => 1,//The id of the developer 'rbacpTester' => 2,//The id of the tester of rbacp 'denyCallbackUri' => '/rbacp/default/rbacp403', 'loginUri' => '/site/login', // 'beforeCheckActionFunc' => function(){ // $url = \yii\helpers\Url::to(['/site/error403','isLocked'=>1], true); // $uri = '/site/error403'; // if ( strpos($_SERVER['REQUEST_URI'], $uri) === false) { // if (!\Yii::$app->user->isGuest && Yii::$app->user->identity->isLocked) { // \Yii::$app // ->getResponse() // ->redirect($url) // ->send(); // } // } // }, // 'afterCheckActionFunc' => function(){}, 'accessRules' => [ 'excludeUri' => [ '/rbacp/default/index', '/rbacp/default/rbacp403', '/site/captcha', '/site/login-ajax', ], 'developUri' => [ '/rbacp/default/migrate-up', '/rbacp/default/migrate-down', ], 'loginedExcludeUri' => [ '/site/logout', '/site/index', '/adminlteiframe/layout', ], ], ], ], ], ...... ], 'modules' => [ ...... 'rbacp' => [ // you should seting it,when you are developing. 'class' => '\myzero1\rbacp\Module', 'theme' => 'adminlteiframe', // adminlteiframe, adminlte ], ...... ], ...... ];
Usage
You can access Demo through the following URL:
http://localhost/path/to/index.php?r=rbacp/default/index
or if you have enabled pretty URLs, you may use the following URL:
http://localhost/path/to/index.php/rbacp/default/index
Use the rbac of rbacp:
Setting 'model' => 'rbac',//everyone,logined,rbac,rbacp
everyone: veryone can access.
logined: Only the logined can access.
rbac: Control access by rbac,you should to setting more.
Add tables by "/rbacp/default/migrate-up".
Add privilege by "rbacp-privilege/index".
Add role by "rbacp/rbacp-role/index".
Assign role by "rbacp/rbacp-user-view/index".
The rbac it working,now.
Use the rbacp of rbacp:
Setting 'model' => 'rbacp',//everyone,logined,rbac,rbacp
rbacp: Control access by rbacp,you should to setting more.
Add tables by "/rbacp/default/migrate-up".
Add privilege by "rbacp-privilege/index".
Add policy by "rbacp/rbacp-policy/index".//to control the access of data
Add role by "rbacp/rbacp-role/index".
Assign role by "rbacp/rbacp-user-view/index".
You can use rbacp as flow.
Use it by andFilterWhere
RbacpRole::find()->andFilterWhere([
'<>',
'rbacp_role.id',
'rbacp_policy_sku=rbacp|rbacp-role|index|rbacpPolicy|read|角色列表'// to use rbacp, set policy_sku.
])
Use it by GridView::widget
GridView::widget([
'dataProvider' => $dataProvider,
'options' => [
'rbacp_policy_sku' => 'rbacp|rbacp-role|index|rbacpPolicy|list|角色列表'// to use rbacp, set policy_sku.
],
'columns' => [...],
]);
Use it by BaseHtml::tag
yii\helpers\BaseHtml::tag('a', '创建', array(
'href' => yii\helpers\Url::toRoute(['create']),
'class' => 'btn btn-success btn-sm',
'rbacp_policy_sku' => 'rbacp|rbacp-role|index|rbacpPolicy|tag|角色列表创建按钮'// to use rbacp, set policy_sku.
));
Set the role id:
\myzero1\rbacp\components\Rbac::setRoleId($roleId);
Set and get the role id by user id:
\myzero1\rbacp\components\Rbac::getRoleByUid($userId);
Notice:
The rbacp module will call \myzero1\rbacp\components\Rbac::getRoleByUid(\Yii::$app->user->id);
to set role by default.