*/ require_once __DIR__ . '/../../lib/Application.php'; Horde_Registry::appInit('horde', array('permission' => array('horde:administration:perms'))); /* Set up the form variables. */ $vars = $injector->getInstance('Horde_Variables'); $perms = $injector->getInstance('Horde_Perms'); $corePerms = $injector->getInstance('Horde_Core_Perms'); $perm_id = $vars->get('perm_id'); try { $permission = $perms->getPermissionById($perm_id); } catch (Exception $e) { $notification->push(_("Invalid parent permission."), 'horde.error'); Horde::url('admin/perms/index.php', true)->redirect(); } /* Set up form. */ $ui = new Horde_Core_Perms_Ui($perms, $corePerms); $ui->setVars($vars); $ui->setupAddForm($permission); if ($ui->validateAddForm($info)) { try { if ($info['perm_id'] == Horde_Perms::ROOT) { $child = $corePerms->newPermission($info['child']); $result = $perms->addPermission($child); } else { $pOb = $perms->getPermissionById($info['perm_id']); $name = $pOb->getName() . ':' . str_replace(':', '.', $info['child']); $child = $corePerms->newPermission($name); $result = $perms->addPermission($child); } $notification->push(sprintf(_("\"%s\" was added to the permissions system."), $corePerms->getTitle($child->getName())), 'horde.success'); Horde::url('admin/perms/edit.php', true)->add('perm_id', $child->getId())->redirect();
<?php /** * Copyright 1999-2015 Horde LLC (http://www.horde.org/) * * See the enclosed file COPYING for license information (LGPL-2). If you * did not receive this file, see http://www.horde.org/licenses/lgpl. * * @author Chuck Hagenbuch <*****@*****.**> * @author Jan Schneider <*****@*****.**> * @category Horde * @license http://www.horde.org/licenses/lgpl LGPL-2 * @package Horde */ require_once __DIR__ . '/../../lib/Application.php'; Horde_Registry::appInit('horde', array('permission' => array('horde:administration:perms'))); $perm_id = Horde_Util::getFormData('perm_id'); $page_output->header(array('title' => _("Permissions Administration"))); require HORDE_TEMPLATES . '/admin/menu.inc'; $ui = new Horde_Core_Perms_Ui($injector->getInstance('Horde_Perms'), $injector->getInstance('Horde_Core_Perms')); echo '<h1 class="header">' . Horde_Themes_Image::tag('perms.png') . ' ' . _("Permissions") . '</h1>'; $ui->renderTree($perm_id); $page_output->footer();
} catch (Exception $e) { $redirect = true; } $vars->set('perm_id', $perm_id); } else { try { $permission = $perms->getPermissionById($perm_id); } catch (Exception $e) { $redirect = true; } } if ($redirect) { $notification->push(_("Attempt to edit a non-existent permission."), 'horde.error'); Horde::url('admin/perms/index.php', true)->redirect(); } $ui = new Horde_Core_Perms_Ui($perms, $corePerms); $ui->setVars($vars); $ui->setupEditForm($permission); if ($ui->validateEditForm($info)) { /* Update and save the permissions. */ $permission->updatePermissions($info); $permission->save(); $notification->push(sprintf(_("Updated \"%s\"."), $corePerms->getTitle($permission->getName())), 'horde.success'); Horde::url('admin/perms/edit.php', true)->add('perm_id', $permission->getId())->redirect(); } // Buffer the tree rendering Horde::startBuffer(); $ui->renderForm('edit.php'); echo '<br />'; $ui->renderTree($perm_id); $tree_output = Horde::endBuffer();
Horde_Registry::appInit('horde', array('permission' => array('horde:administration:perms'))); /* Set up the form variables. */ $vars = $injector->getInstance('Horde_Variables'); $perms = $injector->getInstance('Horde_Perms'); $corePerms = $injector->getInstance('Horde_Core_Perms'); $perm_id = $vars->get('perm_id'); $category = $vars->get('category'); try { $permission = $perms->getPermissionById($perm_id); } catch (Exception $e) { /* If the permission fetched is an error return to permissions list. */ $notification->push(_("Attempt to delete a non-existent permission."), 'horde.error'); Horde::url('admin/perms/index.php', true)->redirect(); } /* Set up form. */ $ui = new Horde_Core_Perms_Ui($perms, $corePerms); $ui->setVars($vars); $ui->setupDeleteForm($permission); if ($confirmed = $ui->validateDeleteForm($info)) { try { $result = $perms->removePermission($permission, true); $notification->push(sprintf(_("Successfully deleted \"%s\"."), $corePerms->getTitle($permission->getName())), 'horde.success'); Horde::url('admin/perms/index.php', true)->redirect(); } catch (Exception $e) { $notification->push(sprintf(_("Unable to delete \"%s\": %s."), $corePerms->getTitle($permission->getName()), $result->getMessage()), 'horde.error'); } } elseif ($confirmed === false) { $notification->push(sprintf(_("Permission \"%s\" not deleted."), $corePerms->getTitle($permission->getName())), 'horde.success'); Horde::url('admin/perms/index.php', true)->redirect(); } $page_output->header(array('title' => _("Permissions Administration")));