Esempio n. 1
0
 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();
 }