added RBAC
This commit is contained in:
		
							
								
								
									
										120
									
								
								lib/User/Model/AbstractAuthItem.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										120
									
								
								lib/User/Model/AbstractAuthItem.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,120 @@ | ||||
| <?php | ||||
| namespace Da\User\Model; | ||||
|  | ||||
| use Da\User\Traits\AuthManagerTrait; | ||||
| use Da\User\Validator\RbacItemsValidator; | ||||
| use Da\User\Validator\RbacRuleValidator; | ||||
| use yii\base\Model; | ||||
| use yii\rbac\Item; | ||||
| use Yii; | ||||
|  | ||||
| abstract class AbstractAuthItem extends Model | ||||
| { | ||||
|     use AuthManagerTrait; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     public $itemName; | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     public $name; | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     public $description; | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     public $rule; | ||||
|     /** | ||||
|      * @var string[] | ||||
|      */ | ||||
|     public $children; | ||||
|     /** | ||||
|      * @var \yii\rbac\Role|\yii\rbac\Permission | ||||
|      */ | ||||
|     public $item; | ||||
|  | ||||
|     /** | ||||
|      * @inheritdoc | ||||
|      */ | ||||
|     public function init() | ||||
|     { | ||||
|         parent::init(); | ||||
|  | ||||
|         if ($this->item instanceof Item) { | ||||
|             $this->itemName = $this->item->name; | ||||
|             $this->name = $this->item->name; | ||||
|             $this->description = $this->item->description; | ||||
|             $this->children = array_keys($this->getAuthManager()->getChildren($this->item->name)); | ||||
|             if ($this->item->ruleName !== null) { | ||||
|                 $this->rule = get_class($this->getAuthManager()->getRule($this->item->ruleName)); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @inheritdoc | ||||
|      */ | ||||
|     public function attributeLabels() | ||||
|     { | ||||
|         return [ | ||||
|             'name' => Yii::t('user', 'Name'), | ||||
|             'description' => Yii::t('user', 'Description'), | ||||
|             'children' => Yii::t('user', 'Children'), | ||||
|             'rule' => Yii::t('user', 'Rule'), | ||||
|         ]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @inheritdoc | ||||
|      */ | ||||
|     public function scenarios() | ||||
|     { | ||||
|         return [ | ||||
|             'create' => ['name', 'description', 'children', 'rule'], | ||||
|             'update' => ['name', 'description', 'children', 'rule'], | ||||
|         ]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @inheritdoc | ||||
|      */ | ||||
|     public function rules() | ||||
|     { | ||||
|         return [ | ||||
|             ['itemName', 'safe'], | ||||
|             ['name', 'required'], | ||||
|             ['name', 'match', 'pattern' => '/^[\w][\w-.:]+[\w]$/'], | ||||
|             [['name', 'description', 'rule'], 'trim'], | ||||
|             [ | ||||
|                 'name', | ||||
|                 function () { | ||||
|                     if ($this->getAuthManager()->getItem($this->name) !== null) { | ||||
|                         $this->addError('name', Yii::t('user', 'Auth item with such name already exists')); | ||||
|                     } | ||||
|                 }, | ||||
|                 'when' => function () { | ||||
|                     return $this->scenario == 'create' || $this->item->name != $this->name; | ||||
|                 } | ||||
|             ], | ||||
|             ['children', RbacItemsValidator::class], | ||||
|             ['rule', RbacRuleValidator::class], | ||||
|         ]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function getIsNewRecord() | ||||
|     { | ||||
|         return $this->item === null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return Item | ||||
|      */ | ||||
|     abstract public function getType(); | ||||
| } | ||||
							
								
								
									
										54
									
								
								lib/User/Model/Assignment.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								lib/User/Model/Assignment.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,54 @@ | ||||
| <?php | ||||
| namespace Da\User\Model; | ||||
|  | ||||
| use Da\User\Traits\AuthManagerTrait; | ||||
| use Da\User\Validator\RbacItemsValidator; | ||||
| use yii\base\InvalidConfigException; | ||||
| use yii\base\Model; | ||||
| use Yii; | ||||
|  | ||||
| class Assignment extends Model | ||||
| { | ||||
|     use AuthManagerTrait; | ||||
|  | ||||
|     public $items = []; | ||||
|     public $user_id; | ||||
|     public $updated = false; | ||||
|  | ||||
|     /** | ||||
|      * @inheritdoc | ||||
|      * @throws InvalidConfigException | ||||
|      */ | ||||
|     public function init() | ||||
|     { | ||||
|         parent::init(); | ||||
|  | ||||
|         if($this->user_id === null) { | ||||
|             throw new InvalidConfigException('"user_id" must be set.'); | ||||
|         } | ||||
|  | ||||
|         $this->items = array_keys($this->getAuthManager()->getItemsByUser($this->user_id)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @inheritdoc | ||||
|      */ | ||||
|     public function attributeLabels() | ||||
|     { | ||||
|         return [ | ||||
|             'items' => Yii::t('user', 'Items') | ||||
|         ]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @inheritdoc | ||||
|      */ | ||||
|     public function rules() | ||||
|     { | ||||
|         return [ | ||||
|             ['user_id', 'required'], | ||||
|             ['items', RbacItemsValidator::class], | ||||
|             ['user_id', 'integer'] | ||||
|         ]; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										12
									
								
								lib/User/Model/Permission.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								lib/User/Model/Permission.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | ||||
| <?php | ||||
| namespace Da\User\Model; | ||||
|  | ||||
| use yii\rbac\Item; | ||||
|  | ||||
| class Permission extends AbstractAuthItem | ||||
| { | ||||
|     public function getType() | ||||
|     { | ||||
|         return Item::TYPE_PERMISSION; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										13
									
								
								lib/User/Model/Role.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								lib/User/Model/Role.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | ||||
| <?php | ||||
| namespace Da\User\Model; | ||||
|  | ||||
| use yii\rbac\Item; | ||||
|  | ||||
|  | ||||
| class Role extends AbstractAuthItem | ||||
| { | ||||
|     public function getType() | ||||
|     { | ||||
|         return Item::TYPE_ROLE; | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user