public function run() { $new_values = $this->request->get('value', array()); $group_id = $this->request->get('group_id', 0); if (!$new_values || !$group_id) { cmsCore::error404(); } $controllers = cmsPermissions::getControllersWithRules(); $owners = array(); foreach ($controllers as $controller_name) { $controller = cmsCore::getController($controller_name); $subjects = $controller->getPermissionsSubjects(); $rules = cmsPermissions::getRulesList($controller_name); $values = array(); foreach ($subjects as $subject) { $values[$subject['name']] = cmsPermissions::getPermissions($subject['name']); } $owners[$controller_name] = array('subjects' => $subjects, 'rules' => $rules, 'values' => $values); } foreach ($owners as $controller_name => $controller) { foreach ($controller['subjects'] as $subject) { $formatted_values = array(); foreach ($controller['rules'] as $rule) { $value = isset($new_values[$rule['id']][$subject['name']]) ? $new_values[$rule['id']][$subject['name']] : null; $formatted_values[$rule['id']][$group_id] = $value; } cmsPermissions::savePermissions($subject['name'], $formatted_values); } } cmsUser::addSessionMessage(LANG_CP_PERMISSIONS_SUCCESS, 'success'); $this->redirectBack(); }
public function run($id) { if (!$id) { cmsCore::error404(); } $users_model = cmsCore::getModel('users'); $group = $users_model->getGroup($id); if (!$group) { cmsCore::error404(); } $controllers = cmsPermissions::getControllersWithRules(); $owners = array(); foreach ($controllers as $controller_name) { $controller = cmsCore::getController($controller_name); $subjects = $controller->getPermissionsSubjects(); $rules = cmsPermissions::getRulesList($controller_name); $values = array(); foreach ($subjects as $subject) { $values[$subject['name']] = cmsPermissions::getPermissions($subject['name']); } $owners[$controller_name] = array('subjects' => $subjects, 'rules' => $rules, 'values' => $values); } $template = cmsTemplate::getInstance(); $template->setMenuItems('users_group', array(array('title' => LANG_CONFIG, 'url' => href_to($this->name, 'users', array('group_edit', $id))), array('title' => LANG_PERMISSIONS, 'url' => href_to($this->name, 'users', array('group_perms', $id))))); return $template->render('users_group_perms', array('group' => $group, 'owners' => $owners)); }
public function actionPerms($subject = '') { if (empty($this->useDefaultPermissionsAction)) { cmsCore::error404(); } $rules = cmsPermissions::getRulesList($this->name); $values = cmsPermissions::getPermissions($subject); $users_model = cmsCore::getModel('users'); $groups = $users_model->getGroups(false); return cmsTemplate::getInstance()->render('backend/perms', array('rules' => $rules, 'values' => $values, 'groups' => $groups, 'subject' => $subject)); }
public function run($ctype_id) { if (!$ctype_id) { cmsCore::error404(); } $content_model = cmsCore::getModel('content'); $ctype = $content_model->getContentType($ctype_id); if (!$ctype) { cmsCore::error404(); } cmsCore::loadControllerLanguage('content'); $rules = cmsPermissions::getRulesList('content'); $values = cmsPermissions::getPermissions($ctype['name']); list($ctype, $rules, $values) = cmsEventsManager::hook('content_perms', array($ctype, $rules, $values)); list($ctype, $rules, $values) = cmsEventsManager::hook("content_{$ctype['name']}_perms", array($ctype, $rules, $values)); $users_model = cmsCore::getModel('users'); $groups = $users_model->getGroups(false); return cmsTemplate::getInstance()->render('ctypes_perms', array('ctype' => $ctype, 'rules' => $rules, 'values' => $values, 'groups' => $groups)); }
public function actionPerms($subject = '') { if (empty($this->useDefaultPermissionsAction)) { cmsCore::error404(); } $rules = cmsPermissions::getRulesList($this->name); $values = cmsPermissions::getPermissions($subject); // добавляем правила доступа от типа контента, если контроллер на его основе $ctype = cmsCore::getModel('content')->getContentTypeByName($this->name); if ($ctype) { $rules = array_merge(cmsPermissions::getRulesList('content'), $rules); } list($rules, $values) = cmsEventsManager::hook("controller_{$this->name}_perms", array($rules, $values)); $groups = cmsCore::getModel('users')->getGroups(false); $template_params = array('rules' => $rules, 'values' => $values, 'groups' => $groups, 'subject' => $subject); // если задан шаблон опций в контроллере if ($this->cms_template->getTemplateFileName('controllers/' . $this->name . '/backend/perms', true)) { return $this->cms_template->render('backend/perms', $template_params); } else { $default_admin_tpl = $this->cms_template->getTemplateFileName('controllers/admin/controllers_perms'); return $this->cms_template->processRender($default_admin_tpl, $template_params); } }