1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
<?php
/**
* $Horde: horde/admin/perms/addchild.php,v 1.27.2.1 2005/01/03 12:25:29 jan Exp $
*
* Copyright 1999-2005 Chuck Hagenbuch <chuck@horde.org>
*
* See the enclosed file COPYING for license information (LGPL). If you
* did not receive this file, see http://www.fsf.org/copyleft/lgpl.html.
*/
@define('HORDE_BASE', dirname(__FILE__) . '/../..');
require_once HORDE_BASE . '/lib/base.php';
require_once 'Horde/Menu.php';
require_once 'Horde/Group.php';
require_once 'Horde/Tree.php';
/* Form libraries. */
require_once 'Horde/Form.php';
require_once 'Horde/Form/Renderer.php';
require_once 'Horde/Variables.php';
if (!Auth::isAdmin()) {
Horde::authenticationFailureRedirect();
}
$groups = &Group::singleton();
$auth = &Auth::singleton($conf['auth']['driver']);
/* Set up the form variables. */
$vars = &Variables::getDefaultVariables();
$cid = $vars->get('cid');
$form = &Horde_Form::singleton('', $vars);
/* Depending on what level set relative title and type of child to
* add. */
if ($cid == DATATREE_ROOT) {
$pname = _("All Permissions");
$cid_name = '';
} else {
$permission = &$perms->getPermissionById($cid);
if (is_a($permission, 'PEAR_Error')) {
$notification->push(_("Invalid parent permission."), 'horde.error');
$url = Horde::applicationUrl('admin/perms/index.php', true);
header('Location: ' . $url);
exit;
}
$pname = $perms->getTitle($permission->getName());
$cid_name = $permission->getName();
}
/* Set up form. */
$form->setTitle(sprintf(_("Add a child permission to '%s'"), $pname));
$form->setButtons(_("Add"), true);
$form->addHidden('', 'cid', 'text', false);
/* Set up the actual child adding field. */
$child_perms = $perms->getAvailable($cid_name);
if ($child_perms === false) {
/* False, so no children are to be added below this level. */
$form->addVariable(_("Permission"), 'child', 'invalid', true, false, null, array(_("No children can be added to this permission.")));
} elseif (is_array($child_perms)) {
/* Choice array available, so set up enum field. */
$form->addVariable(_("Permission"), 'child', 'enum', true, false, null, array($child_perms));
} else {
/* No choices returned, so give a free form text field. */
$form->addVariable(_("Permission"), 'child', 'text', true);
}
if ($form->validate($vars)) {
$form->getInfo($vars, $info);
if ($info['cid'] == DATATREE_ROOT) {
$child = &$perms->newPermission($info['child']);
$result = $perms->addPermission($child);
} else {
$pOb = &$perms->getPermissionById($info['cid']);
$name = $pOb->getName() . ':' . DataTree::encodeName($info['child']);
$child = &$perms->newPermission($name);
$result = $perms->addPermission($child);
}
if (is_a($result, 'PEAR_Error')) {
$notification->push(sprintf(_("'%s' was not created: %s."), $child->getShortName(), $result->getMessage()), 'horde.error');
} else {
$notification->push(sprintf(_("'%s' was added to the permissions system."), $child->getShortName()), 'horde.success');
$url = Horde::applicationUrl('admin/perms/edit.php', true);
$url = Util::addParameter($url, 'cid', $child->getId(), false);
header('Location: ' . $url);
exit;
}
}
$title = _("Permissions Administration");
require HORDE_TEMPLATES . '/common-header.inc';
require HORDE_TEMPLATES . '/admin/common-header.inc';
$notification->notify(array('listeners' => 'status'));
/* Render the form. */
$renderer = &new Horde_Form_Renderer();
$form->renderActive($renderer, $vars, 'addchild.php', 'post');
echo '<br />';
require_once 'Horde/Perms/UI.php';
$ui = &new Perms_UI($perms);
$ui->renderTree($cid);
require HORDE_TEMPLATES . '/common-footer.inc';
|