示例#1
0
 public function actionAssign($id)
 {
     $model = self::findModel($id);
     // 已授权的分配项
     $authorized = models\RbacTaskItems::getTaskAuthorized($id);
     //全部的分配项
     $authItems = models\RbacAuthitems::getCanAssignItems();
     // 未授权的就是全部授权项与已授权项的差集
     $unassign = array_diff($authItems, $authorized);
     return $this->render('/rbac/authtask/assign', ['model' => $model, 'unassign' => $unassign, 'assigned' => $authorized]);
 }
示例#2
0
 /**
  * 获取用户所有的操作、自定义的授权项,缓存半小时,用于防止缓存被集中请求
  * @param  int $userId
  * @param  boolean $useCache
  * @return array
  */
 public static function getUserOperationAuthItems($userId, $useCache = true)
 {
     //获取RBAC权限使用的cache名字
     $cacheComponents = Yii::$app->getModule('rbac')->cacheComponents;
     $cachekey = 'UserAuthItems_userId_' . $userId;
     $items = [];
     //所有权限
     // 如果使用cache优先从cache读取
     if ($useCache) {
         $items = Yii::$app->{$cacheComponents}->get($cachekey);
     }
     // 如果未使用cache或从cache中未读出值,则到数据库读取,并缓存起来。
     if (!$useCache || $items === false) {
         // 先获得用户的所有角色
         $roles = RbacUserRole::getUserRoles($userId, true);
         if (empty($roles)) {
             return $items;
         }
         //获取该用户所有角色的任务
         $taskIds = RbacRoleTask::getTaskAuthorized($roles);
         $authItems = [];
         ////获取任务的所有权限
         if (is_array($taskIds) && count($taskIds) > 0) {
             //获取任务的所有权限
             $authItems = RbacTaskItems::getTaskAuthorized($taskIds);
         }
         foreach ($authItems as $v) {
             $items[$v] = $v;
         }
         Yii::$app->{$cacheComponents}->set($cachekey, $items, 1800);
     }
     return $items;
 }