public function search($params) { $query = static::ITEM_TYPE == static::TYPE_ROLE ? Role::find() : Permission::find(); $query->joinWith(['group']); $dataProvider = new ActiveDataProvider(['query' => $query, 'pagination' => ['pageSize' => \Yii::$app->request->cookies->getValue('_grid_page_size', 20)], 'sort' => ['defaultOrder' => ['created_at' => SORT_DESC]]]); if (!($this->load($params) && $this->validate())) { return $dataProvider; } $query->andFilterWhere(['like', Yii::$app->getModule(\Yii::$app->user->moduleAliasName)->auth_item_table . '.name', $this->name])->andFilterWhere(['like', Yii::$app->getModule(\Yii::$app->user->moduleAliasName)->auth_item_table . '.description', $this->description])->andFilterWhere([Yii::$app->getModule(\Yii::$app->user->moduleAliasName)->auth_item_table . '.group_code' => $this->group_code]); return $dataProvider; }
/** * @param string $id * * @return string */ public function actionView($id) { $role = $this->findModel($id); $authManager = Yii::$app->authManager instanceof DbManager ? Yii::$app->authManager : new DbManager(); $allRoles = Role::find()->asArray()->andWhere('name != :current_name', [':current_name' => $id])->all(); $permissions = Permission::find()->andWhere(Yii::$app->getModule('user-management')->auth_item_table . '.name != :commonPermissionName', [':commonPermissionName' => Yii::$app->getModule('user-management')->commonPermissionName])->joinWith('group')->all(); $permissionsByGroup = []; foreach ($permissions as $permission) { $permissionsByGroup[@$permission->group->name][] = $permission; } $childRoles = $authManager->getChildren($role->name); $currentRoutesAndPermissions = AuthHelper::separateRoutesAndPermissions($authManager->getPermissionsByRole($role->name)); $currentPermissions = $currentRoutesAndPermissions->permissions; return $this->renderIsAjax('view', compact('role', 'allRoles', 'childRoles', 'currentPermissions', 'permissionsByGroup')); }
/** * @param string $id * * @return string */ public function actionView($id) { $item = $this->findModel($id); $routes = Route::find()->asArray()->all(); $permissions = Permission::find()->andWhere(['not in', Yii::$app->getModule('user-management')->auth_item_table . '.name', [Yii::$app->getModule('user-management')->commonPermissionName, $id]])->joinWith('group')->all(); $permissionsByGroup = []; foreach ($permissions as $permission) { $permissionsByGroup[@$permission->group->name][] = $permission; } $childRoutes = AuthHelper::getChildrenByType($item->name, AbstractItem::TYPE_ROUTE); $childPermissions = AuthHelper::getChildrenByType($item->name, AbstractItem::TYPE_PERMISSION); $allRoles = Role::find()->all(); $roles = array(); foreach ($allRoles as $role) { $rolePermissions = $role->getPermissionsByRole($role->name, false); foreach ($rolePermissions as $permission) { if ($permission->name == $item->name) { array_push($roles, $role); } } } return $this->renderIsAjax('view', compact('item', 'childPermissions', 'routes', 'permissionsByGroup', 'childRoutes', 'roles')); }
/** * Default unique validator search only within specific class (Role, Route or Permission) because of the overwritten find() method */ public function validateUniqueName($attribute) { if (Role::find()->where(['name' => $this->name])->exists()) { $this->addError('name', Yii::t('yii', '{attribute} "{value}" has already been taken.', ['attribute' => $this->getAttributeLabel($attribute), 'value' => $this->{$attribute}])); } }