public function indexAction()
 {
     // get user session
     $session = new Zend_Session_Namespace('user');
     // check for non guest users
     if (!$session->valid) {
         $this->_redirect('');
     }
     // get user
     $user = new Knowledgeroot_User($session->id);
     // check for post
     if ($this->getRequest()->getMethod() == 'POST') {
         $user->setFirstName($this->_getParam('first_name'));
         $user->setLastName($this->_getParam('last_name'));
         $user->setEmail($this->_getParam('email'));
         $user->setLanguage($this->_getParam('language'));
         $user->setTimezone($this->_getParam('timezone'));
         // check for password change
         if ($this->_getParam('password') != '') {
             if ($this->_getParam('password') == $this->_getParam('password1')) {
                 //  save password
                 $user->setPassword($this->_getParam('password'));
                 // display success message
                 Knowledgeroot_Message::success("Password changed", "Your password was changed!");
             } else {
                 Knowledgeroot_Message::error("Password", "Your password could not changed!");
             }
         }
         // save user
         $user->save();
         // save settings also to session
         $session->language = $this->_getParam('language');
         $session->timezone = $this->_getParam('timezone');
         // display message
         // TODO: translate text to new language here!
         Knowledgeroot_Message::success("Settings", "Your settings were saved");
         // redirect to this page again
         $this->_redirect('settings');
     }
     // prepare view vars
     $this->view->id = $user->getId();
     $this->view->login = $user->getLogin();
     $this->view->first_name = $user->getFirstName();
     $this->view->last_name = $user->getLastName();
     $this->view->email = $user->getEmail();
     $this->view->language = $user->getLanguage();
     $this->view->timezone = $user->getTimezone();
     // get translations
     $translation = Knowledgeroot_Registry::get('translate');
     $this->view->translations = $translation->getTranslations();
     // get timezones
     $this->view->timezones = Knowledgeroot_Timezone::getTimezones();
 }
示例#2
0
 /**
  * show member panel
  *
  * @param string $name
  * @param Knowledgeroot_User|Knowledgeroot_Group $member
  * @param array $config
  * @return string
  */
 public function memberPanel($name, $member, $config = null)
 {
     $view = new Zend_View();
     $view->name = $name;
     // available roles
     $roles = array();
     if (!isset($config['show_users']) || isset($config['show_users']) && $config['show_users']) {
         $users = Knowledgeroot_User::getUsers();
         foreach ($users as $value) {
             $roles['U_' . $value->getId()] = $value->getLogin() . ' (U)';
         }
     }
     if (!isset($config['show_groups']) || isset($config['show_groups']) && $config['show_groups']) {
         $groups = Knowledgeroot_Group::getGroups();
         foreach ($groups as $value) {
             $roles['G_' . $value->getId()] = $value->getName() . ' (G)';
         }
     }
     $view->roles = $roles;
     $memberType = "";
     $memberId = "";
     if ($member instanceof Knowledgeroot_User) {
         $memberType = "user";
         $memberId = $member->getId();
     }
     if ($member instanceof Knowledgeroot_Group) {
         $memberType = "group";
         $memberId = $member->getId();
     }
     $members = array();
     if ($memberId != null) {
         if (isset($config['show_members']) && $config['show_members'] && $memberType == 'group') {
             $members = new Knowledgeroot_Db_GroupMember();
             $select = $members->select();
             $select->where('group_id = ?', $memberId);
         } else {
             $members = new Knowledgeroot_Db_GroupMember();
             $select = $members->select();
             $select->where('member_id = ?', $memberId);
             $select->where('member_type = ?', $memberType);
         }
         $all = $members->fetchAll($select);
         $members = array();
         foreach ($all as $value) {
             if (isset($config['show_members']) && $config['show_members'] && $memberType == 'group') {
                 if ($value['member_type'] == 'user') {
                     $user = new Knowledgeroot_User($value['member_id']);
                     $members['U_' . $user->getId()] = array('name' => $user->getLogin());
                 } else {
                     $group = new Knowledgeroot_Group($value['member_id']);
                     $members['G_' . $group->getId()] = array('name' => $group->getName());
                 }
             } else {
                 $group = new Knowledgeroot_Group($value['group_id']);
                 $members['G_' . $group->getId()] = array('name' => $group->getName());
             }
         }
     }
     $view->permissions = $members;
     $view->setScriptPath(APPLICATION_PATH . '/view/scripts/');
     return $view->render('helpers/memberpanel.phtml');
 }
示例#3
0
 public function getAclForResource($resource)
 {
     $db = Knowledgeroot_Registry::get('db');
     $acl = $db->fetchAll('SELECT * FROM ' . $db->quoteIdentifier('acl') . ' WHERE resource = ?', array($resource));
     $ret = array();
     foreach ($acl as $value) {
         if (!isset($ret[$value['role_id']]['name'])) {
             if (substr($value['role_id'], 0, 2) == 'U_') {
                 $u = new Knowledgeroot_User(substr($value['role_id'], 2));
                 $ret[$value['role_id']]['name'] = $u->getLogin();
             }
             if (substr($value['role_id'], 0, 2) == 'G_') {
                 $g = new Knowledgeroot_Group(substr($value['role_id'], 2));
                 $ret[$value['role_id']]['name'] = $g->getName();
             }
         }
         $ret[$value['role_id']]['permissions'][$value['action']] = $value['right'];
     }
     return $ret;
 }
示例#4
0
 public function editAction()
 {
     if ($this->getRequest()->getMethod() == 'POST') {
         if ($this->_getParam('button') == 'close') {
             $this->_redirect('user/');
         }
         $user = new Knowledgeroot_User($this->_getParam('id'));
         $user->setLogin($this->_getParam('login'));
         // check if password is changed
         if ($this->_getParam('password') != '' && $this->_getParam('password2') != '' && $this->_getParam('password') == $this->_getParam('password2')) {
             $user->setPassword($this->_getParam('password'));
         }
         $user->setFirstName($this->_getParam('firstname'));
         $user->setLastName($this->_getParam('lastname'));
         $user->setEmail($this->_getParam('email'));
         $user->setLanguage($this->_getParam('language'));
         $user->setTimezone($this->_getParam('timezone'));
         $user->setActive($this->_getParam('active'));
         $user->save();
         // remove existing group memberships
         Knowledgeroot_Group::deleteMemberFromGroups($user);
         // save group membership
         foreach (Knowledgeroot_Util::objectToArray(json_decode($this->_getParam('memberpanel_user'))) as $memberId => $value) {
             // we only can be a member of a group
             if ($memberId[0] == 'G') {
                 $id = substr($memberId, 2);
                 $group = new Knowledgeroot_Group($id);
                 $group->addMember($user);
             }
         }
         if ($this->_getParam('button') == 'save') {
             $this->_redirect('user/edit/' . $user->getId());
         } else {
             $this->_redirect('user/');
         }
     } else {
         $id = $this->_getParam('id');
         $user = new Knowledgeroot_User($id);
         $this->view->action = 'edit';
         $this->view->id = $user->getId();
         $this->view->login = $user->getLogin();
         $this->view->firstname = $user->getFirstName();
         $this->view->lastname = $user->getLastName();
         $this->view->email = $user->getEmail();
         $this->view->timezone = $user->getTimezone();
         $this->view->language = $user->getLanguage();
         $this->view->active = $user->getActive();
         $this->renderScript("user/user.phtml");
     }
 }