nullref/yii2-rbac

Installs: 309

Dependents: 0

Suggesters: 0

Security: 0

Stars: 1

Watchers: 4

Forks: 1

Open Issues: 0

Type:yii2-extension

dev-master 2020-03-31 08:36 UTC

This package is auto-updated.

Last update: 2024-04-29 04:12:48 UTC


README

Latest Stable Version Total Downloads Latest Unstable Version License

Advanced RBAC superstructure on yii2 RBAC, Dektrium extension

Main functions:

  1. Action access by roles and permissions
  2. UI element access by roles and permissions
  3. Model field access by scenarios,roles and permissions

Installation

The preferred way to install this extension is through composer.

Either run

php composer.phar require --prefer-dist nullref/yii2-rbac "*"

or add

"nullref/yii2-rbac": "*"

to the require section of your composer.json file.

Basic set up:

At first you need to configure authManager component to use database. You need to use \nullref\rbac\components\DBManager.

In modules configuration on 'rbac' section you

  • need to specify id (ex: user, admin, etc) of userComponent \yii\web\User with identity field and getId() method in it

  • need to specify userProvider class which implements interface

nullref\rbac\interfaces\UserProviderInterface

with getUsers() method which has to return array of users with required fields ['id', 'username']

  • may to override ruleManager class which implements interface
nullref\rbac\interfaces\RuleManagerInterface

with getList() method, there is RuleManager in module

nullref\rbac\components\RuleManager

Your modules configuration: In Module.php add array with aliases for module controllers

Ex:

  public $controllerAliases = [
        '@app/modules/myModule/controllers',
        '@app/modules/myModule/controllers/admin',
  ];  

Each controller you want to be under RBAC has to be extended from:

\nullref\rbac\components\BaseController

or behavior() method has contain next item:

 'access' => [
                'class'      => \nullref\rbac\filters\AccessControl::class,
                'controller' => $this,
            ],

Usage of UI element access:

To use this functionality you have to:

  • use widget in base layout
<?= ElementConfig::widget([]) ?>
  • specify $elementEditorRole in RBAC module by default 'elementEditor'
  • assign this role to your user
  • use html helper to build you 'a' and 'button'(for now) tags.
nullref\rbac\helpers\elementt\ElementHtml

and provide data-identifier option with unique value to $options array

    <?= ElementHtml::a('a', ['somewhere', ['data-identificator' => 'a-0.11723100 1545142675']) ?>

You can use gii generator to generate unique values for your element (single line code only for now). Before use you have to specify aliases for views folders

  public $viewPathAliases = [
      '@app/modules/myModule/views',
  ];  

Before:

<?php

use nullref\rbac\helpers\element\ElementHtml;
use nullref\rbac\helpers\element\ElementHtml as A;

?>
<?= ElementHtml::a('a') ?>
<?= ElementHtml::a('a', Url::to(['a']), []) ?>
<?= A::a('a', ['a']) ?>
<?= ElementHtml::a('a', Url::to(['a'])) ?>
<?= ElementHtml::a('a', Url::to(['a', 'c' => 1]), ['a' => 'a']) ?>
<?= A::a('a', Url::to(['a']), ['a' => 'a']) ?>

After:

<?php

use nullref\rbac\helpers\element\ElementHtml;
use nullref\rbac\helpers\element\ElementHtml as A;

?>
<?= ElementHtml::a('a', null, ['data-identificator' => 'a-0.11723100 1545142675']) ?>
<?= ElementHtml::a('a', Url::to(['a']), ['data-identificator' => 'a-0.11726200 1545142675']) ?>
<?= A::a('a', ['a'], ['data-identificator' => 'a-0.11728500 1545142675']) ?>
<?= ElementHtml::a('a', Url::to(['a']), ['data-identificator' => 'a-0.11730500 1545142675']) ?>
<?= ElementHtml::a('a', Url::to(['a', 'c' => 1]), ['a' => 'a', 'data-identificator' => 'a-0.11732500 1545142675']) ?>
<?= A::a('a', Url::to(['a']), ['a' => 'a', 'data-identificator' => 'a-0.11734500 1545142675']) ?>

Usage of Model field access:

To use this functionality you have to:

  • add array with aliases for models in Module.php
   public $modelAliases = [
          '@app/modules/myModule/models',
   ];  
  • add behavior in your Model and validate your model before save
public function behaviors()
{
    return [
        'checkFields' => [
            'class' => FieldCheckerBehavior::class,
        ],
    ];
}
  • use nullref\rbac\widgets\ActiveField field in your ActiveForm
 <?php $form = ActiveForm::begin([
        'fieldClass' => nullref\rbac\widgets\ActiveField::class,
 ]); ?>