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"); } }
/** * show permission panel * * @param string $name * @param array $actions * @param array $config * @return string * * config options: * bool show_save_button - show save button so that stuff will be saved per ajax - default: false * bool add_acl_on_form_submit - should acl be submitted on form submit as value - default: false * bool add_user_permissions - add full permissions for the user itself if permissions are empty - default: false */ public function permissionPanel($name, $actions, $config = null) { $view = new Zend_View(); $view->name = $name; $view->actions = $actions; // get actual userid $session = new Zend_Session_Namespace('user'); $view->userId = $session->id; if (isset($config['show_save_button']) && $config['show_save_button']) { $view->showSaveButton = true; } else { $view->showSaveButton = false; } if (isset($config['add_acl_on_form_submit']) && $config['add_acl_on_form_submit']) { $view->addAclOnFormSubmit = true; } else { $view->addAclOnFormSubmit = false; } if (isset($config['add_user_permissions']) && $config['add_user_permissions']) { $view->addUserPermissions = true; } else { $view->addUserPermissions = false; } // available roles $roles = array(); $users = Knowledgeroot_User::getUsers(); foreach ($users as $value) { $roles['U_' . $value->getId()] = $value->getLogin() . ' (U)'; } $groups = Knowledgeroot_Group::getGroups(); foreach ($groups as $value) { $roles['G_' . $value->getId()] = $value->getName() . ' (G)'; } $view->roles = $roles; $acl = Knowledgeroot_Registry::get('acl'); // active roles with permissions $view->permissions = $acl->getAclForResource($name); $view->setScriptPath(APPLICATION_PATH . '/view/scripts/'); return $view->render('helpers/permissionpanel.phtml'); }
/** * delete user or group as member of this group * * @param Knowledgeroot_User|Knowledgeroot_Group $member */ public function delMember($member) { $type = ''; $memberId = null; // check if member is a user if ($member instanceof Knowledgeroot_User) { $type = 'user'; $memberId = $member->getId(); } // check if member is a group if ($member instanceof Knowledgeroot_Group) { $type = 'group'; $memberId = $member->getId(); } $member = new Knowledgeroot_Db_GroupMember(); $member->delete(array('group_id = ?' => $this->id, 'member_id = ?' => $memberId, 'member_type = ?' => $type)); }
/** * 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'); }
public function disableAction() { $id = $this->_getParam('id'); $group = new Knowledgeroot_Group($id); $group->setActive(false); $group->save(); $this->_redirect('group/'); }
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; }