phpldapadmin/htdocs/delete.php

82 lines
2.3 KiB
PHP
Raw Normal View History

2009-06-30 19:22:30 +10:00
<?php
2009-06-30 19:29:51 +10:00
// $Header: /cvsroot/phpldapadmin/phpldapadmin/delete.php,v 1.23 2005/09/25 16:11:44 wurley Exp $
2009-06-30 18:05:37 +10:00
2009-06-30 19:29:51 +10:00
/**
2009-06-30 18:05:37 +10:00
* Deletes a DN and presents a "job's done" message.
*
2009-06-30 19:29:51 +10:00
* Variables that come in via common.php
* - server_id
2009-06-30 18:05:37 +10:00
* Variables that come in as POST vars:
* - dn (rawurlencoded)
2009-06-30 19:29:51 +10:00
*
* @package phpLDAPadmin
*/
/**
2009-06-30 18:05:37 +10:00
*/
2009-06-30 19:29:51 +10:00
require './common.php';
2009-06-30 18:05:37 +10:00
2009-06-30 19:29:51 +10:00
if ($ldapserver->isReadOnly())
pla_error($lang['no_updates_in_read_only_mode']);
if (! $ldapserver->haveAuthInfo())
pla_error($lang['not_enough_login_info']);
2009-06-30 18:05:37 +10:00
2009-06-30 19:29:51 +10:00
$dn = $_POST['dn'];
$encoded_dn = rawurlencode($dn);
2009-06-30 18:07:14 +10:00
2009-06-30 19:29:51 +10:00
if (is_null($dn))
pla_error($lang['you_must_specify_a_dn']);
2009-06-30 18:05:37 +10:00
2009-06-30 19:29:51 +10:00
dn_exists($ldapserver,$dn) or pla_error(sprintf($lang['no_such_entry'], '<b>' . pretty_print_dn($dn) . '</b>'));
2009-06-30 18:09:20 +10:00
// Check the user-defined custom callback first.
2009-06-30 19:29:51 +10:00
if (run_hook('pre_entry_delete',array('server_id' => $ldapserver->server_id,'dn' => $dn)))
$del_result = @ldap_delete($ldapserver->connect(), $dn);
2009-06-30 18:05:37 +10:00
2009-06-30 19:29:51 +10:00
else
pla_error(sprintf($lang['could_not_delete_entry'],'<b>'.pretty_print_dn($dn).'</b>'));
2009-06-30 18:09:20 +10:00
2009-06-30 19:29:51 +10:00
if ($del_result) {
2009-06-30 18:05:37 +10:00
2009-06-30 19:29:51 +10:00
# Custom callback
run_hook('post_entry_delete',array('server_id' => $ldapserver->server_id,'dn' => $dn));
# kill the DN from the tree browser session variable and
# refresh the tree viewer frame (left_frame)
if (array_key_exists('tree', $_SESSION)) {
2009-06-30 18:05:37 +10:00
$tree = $_SESSION['tree'];
2009-06-30 19:29:51 +10:00
if (isset($tree[$ldapserver->server_id]) && is_array($tree[$ldapserver->server_id])) {
# does it have children? (it shouldn't, but hey, you never know)
if (isset($tree[$ldapserver->server_id][$dn]))
unset($tree[$ldapserver->server_id][$dn]);
# search and destroy
foreach ($tree[$ldapserver->server_id] as $tree_dn => $subtree)
foreach ($subtree as $key => $sub_tree_dn)
if (0 == strcasecmp($sub_tree_dn, $dn))
unset($tree[$ldapserver->server_id][$tree_dn][$key]);
2009-06-30 18:10:17 +10:00
$_SESSION['tree'] = $tree;
}
2009-06-30 18:09:20 +10:00
session_write_close();
2009-06-30 18:05:37 +10:00
}
2009-06-30 19:29:51 +10:00
include './header.php'; ?>
2009-06-30 18:05:37 +10:00
<script language="javascript">
parent.left_frame.location.reload();
</script>
2009-06-30 18:09:20 +10:00
<br />
<br />
2009-06-30 19:29:51 +10:00
<center><?php echo sprintf($lang['entry_deleted_successfully'],'<b>'.pretty_print_dn($dn).'</b>'); ?></center>
2009-06-30 18:05:37 +10:00
2009-06-30 19:29:51 +10:00
<?php
2009-06-30 18:05:37 +10:00
} else {
2009-06-30 19:29:51 +10:00
pla_error(sprintf($lang['could_not_delete_entry'], '<b>' . pretty_print_dn($dn) . '</b>'),
ldap_error($ldapserver->connect()), ldap_errno($ldapserver->connect()));
2009-06-30 18:05:37 +10:00
}
2009-06-30 19:29:51 +10:00
?>