Esempio n. 1
0
 public function setRole($roleId = null)
 {
     $roles = Config::get('loginEnabled') ? Role::getAllSessionRoles() : Role::getAllRoleObjects();
     if (empty($roles) || $roleId == 0) {
         $this->role = new Role(0);
     } elseif (is_null($roleId)) {
         $this->role = current($roles);
     } elseif (isset($roleId)) {
         if (!is_int($roleId)) {
             throw new Exception("roleId must be an integer", 400);
         }
         foreach ($roles as $role) {
             if ($role->id == $roleId) {
                 $this->role = $role;
             }
         }
         if (!isset($this->role)) {
             throw new Exception("You do not have access to the selected role", 401);
         }
     } else {
         throw new Exception("No role could be selected", 500);
     }
     if (Config::get('loginEnabled')) {
         $arr = array();
         foreach ($roles as $role) {
             $arr = array_merge($arr, $role->interfaces);
         }
         $this->accessibleInterfaces = array_unique($arr);
     }
     Notifications::addLog("Role " . $this->role->name . " selected", 'SESSION');
     return $this->role->id;
 }
Esempio n. 2
0
 public static function getAllSessionRoles()
 {
     $sessionRoleLabels = array();
     $sessionRoles = array();
     $interface = new InterfaceObject('SessionRoles');
     $session = new Atom(session_id(), 'SESSION');
     $sessionRoleLabels = array_keys((array) $session->getContent($interface, true));
     foreach (Role::getAllRoleObjects() as $role) {
         if (in_array($role->label, $sessionRoleLabels) || $role->id == 0) {
             $sessionRoles[] = $role;
         }
     }
     return $sessionRoles;
 }
Esempio n. 3
0
 public function getSessionRoles()
 {
     if (isset($this->sessionRoles)) {
         return $this->sessionRoles;
     } else {
         if (Config::get('loginEnabled')) {
             $sessionRoleLabels = array();
             $sessionRoles = array();
             $interface = new InterfaceObject('SessionRoles');
             $session = new Atom(session_id(), 'SESSION');
             $sessionRoleLabels = array_keys((array) $session->getContent($interface, true));
             foreach (Role::getAllRoleObjects() as $role) {
                 if (in_array($role->label, $sessionRoleLabels)) {
                     $sessionRoles[] = $role;
                 }
             }
         } else {
             $sessionRoles = Role::getAllRoleObjects();
         }
         return $this->sessionRoles = $sessionRoles;
     }
 }
Esempio n. 4
0
 /**
  * @url GET navBar
  * @param int $roleId
  */
 public function getNavBar($roleId = 0)
 {
     try {
         $session = Session::singleton();
         $session->setRole($roleId);
         // top level interfaces
         foreach ($session->role->getInterfacesForNavBar() as $ifc) {
             $top[] = array('id' => $ifc->id, 'label' => $ifc->label, 'link' => '/' . $ifc->id);
         }
         // new interfaces
         foreach ($session->role->getInterfacesToCreateAtom() as $ifc) {
             $new[] = array('id' => $ifc->id, 'label' => $ifc->label, 'link' => '/' . $ifc->id);
         }
         // roles
         $roles = array();
         $allRoles = Config::get('loginEnabled') ? Role::getAllSessionRoles() : Role::getAllRoleObjects();
         foreach ((array) $allRoles as $role) {
             $roles[] = array('id' => $role->id, 'label' => $role->label);
         }
         return array('top' => $top, 'new' => $new, 'refreshMenu' => $GLOBALS['navBar']['refreshMenu'], 'appMenu' => $GLOBALS['navBar']['appMenu'], 'roleMenu' => $GLOBALS['navBar']['roleMenu'], 'roles' => $roles, 'defaultSettings' => array('notifications' => Notifications::getDefaultSettings()), 'notifications' => Notifications::getAll(), 'session' => array('id' => $session->id, 'loggedIn' => Session::sessionUserLoggedIn(), 'sessionRoles' => $roles), 'sessionVars' => Session::getSessionVars());
     } catch (Exception $e) {
         throw new RestException($e->getCode(), $e->getMessage());
     }
 }