public function executePermissions() { if (!$this->isAllowed(PERMISSION_ROLE_PERMISSION_MANAGE)) { return $this->raise403(t("You don't have permission")); } $id = $this->get('id'); if (!$id || !($role = \Roles::retrieveById($id))) { return $this->raise404(t('Role not found!')); } //get role's members id /** @var \UserRole[] $userRoles */ $userRoles = (array) \UserRole::findByRoleId($id); $staffs = \Users::findBySection(\Users::SECTION_STAFF); $members = []; $others = []; $t = []; foreach ($userRoles as $ur) { $t[$ur->getUserId()] = true; } foreach ($staffs as $staff) { if (isset($t[$staff->getId()])) { $members[$staff->getId()] = $staff; } else { if ($staff->isActive()) { $others[$staff->getId()] = $staff; } } } unset($members[1]); unset($others[1]); $assigned = \Permissions::findByRoleId($role->getId(), true); $permissions = \Permissions::getPermissionsList(); foreach ($permissions as $group => &$pg) { foreach ($pg['permissions'] as $permission => &$detail) { if (isset($assigned[$permission])) { $detail['assigned'] = true; } else { $detail['assigned'] = false; } } } $this->setView('Role/detail'); $this->view()->assign(array('permissions' => $permissions, 'role' => $role, 'members' => $members, 'otherGuys' => $others)); return $this->renderComponent(); }