RABC经常使用的一些方法

前面加 yii::$app->authmanager->....web

 

ManagerInterface权限管理的接口,若是要自定义RBAC并要利用YII的RBAC相应的功能就须要实现这个接口
YII2 里的BaseManager(抽象类) 就实现了这个接口  可是并无彻底实现这个接口的全部方法,接口中的部分方法被DbMagager 或 PhpManager实现了,一个是基于数据库的RBAC 一个是基于PHP文件的RBAC

检查用户是否拥有某项权限
$userId 用户惟一标识 来源于\yii\web\User::id  
$permissionName  权限名称
$params 为当前用户指派的权限规则
返回 boolean数据库

public function checkAccess($userId, $permissionName, $params = []);数组


建立一个角色对象
     提示:建立角色对象并无添加到RBAC  须要使用  add()方法添加到系统的RBAC
返回 role对象app

public function createRole($name);yii



建立一个权限对象
         须要调用add()方法添加到RBAC
返回Permission对象spa

public function createPermission($name);对象


添加角色、权限或者规则到RBAC库  参数为相应的对象
返回 boolean索引

public function add($object);接口


删除角色或权限或规则记录rem

public function remove($object);



更新一条记录(角色、权限或规则)
$name 须要更新的名称 返回BOOLEAN  

public function update($name, $object);



获取命名的角色
$name 角色的名称      返回角色对应的名称   若是角色不存在则返回null

public function getRole($name);



返回全部的角色  roles[]  索引为角色名

public function getRoles();



根据用户ID返回角色信息
若是子角色没有直接assigned 那么不会返回
返回数组 以角色名索引

public function getRolesByUser($userId);




返回权限名称或 NULL

public function getPermission($name);


返回全部的权限

public function getPermissions();


权限角色名称返回权限名称  数组形式

public function getPermissionsByRole($roleName);


根据角色ID返回权限名称  数组形式

public function getPermissionsByUser($userId);


根据规则名称返回规则对象

public function getRule($name);


返回全部的规则 数组

public function getRules();


为一条记录添加一个子记录

public function addChild($parent, $child);



删除一个子记录
注意:子记录并非被删除了,而是断开了与当前父记录的关系

public function removeChild($parent, $child);



删除全部的子记录

public function removeChildren($parent);



是否拥有子记录

public function hasChild($parent, $child);



返回子权限或角色item[]

public function getChildren($name);



为某个用户分配一个角色
$role Role对象   用户ID

public function assign($role, $userId);



从某个用户撤销一个角色
返回BOOLEAN

public function revoke($role, $userId);



清空该用户的全部角色

public function revokeAll($userId);


根据角色名返回该用户分配的角色信息

public function getAssignment($roleName, $userId);



返回全部的分配的角色信息

public function getAssignments($userId);



删除全部的受权数据  包括角色、权限、规则  、分配

public function removeAll();



删除全部的权限

public function removeAllPermissions();


删除全部的角色

public function removeAllRoles();


删除全部的规则

public function removeAllRules();


删除全部的分配

public function removeAllAssignments();

相关文章
相关标签/搜索