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]); }
/** * 获取用户所有的操作、自定义的授权项,缓存半小时,用于防止缓存被集中请求 * @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; }