2009-06-30 19:22:30 +10:00
|
|
|
<?php
|
2009-06-30 19:40:37 +10:00
|
|
|
// $Header: /cvsroot/phpldapadmin/phpldapadmin/htdocs/rdelete.php,v 1.22.2.1 2005/10/09 09:07:21 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
|
|
|
* Recursively deletes the specified DN and all of its children
|
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);
|
|
|
|
$rdn = get_rdn($dn);
|
2009-06-30 18:05:37 +10:00
|
|
|
|
2009-06-30 19:29:51 +10:00
|
|
|
if (! $dn)
|
|
|
|
pla_error($lang['you_must_specify_a_dn']);
|
2009-06-30 18:07:14 +10:00
|
|
|
|
2009-06-30 19:29:51 +10:00
|
|
|
dn_exists($ldapserver,$dn) or pla_error(sprintf($lang['no_such_entry'],htmlspecialchars($dn)));
|
2009-06-30 18:05:37 +10:00
|
|
|
|
2009-06-30 19:22:30 +10:00
|
|
|
include './header.php';
|
2009-06-30 19:29:51 +10:00
|
|
|
|
2009-06-30 18:05:37 +10:00
|
|
|
echo "<body>\n";
|
2009-06-30 19:29:51 +10:00
|
|
|
echo "<h3 class=\"title\">".sprintf($lang['deleting_dn'],htmlspecialchars($rdn))."</h3>\n";
|
|
|
|
echo "<h3 class=\"subtitle\">".$lang['recursive_delete_progress']."</h3>";
|
2009-06-30 18:05:37 +10:00
|
|
|
echo "<br /><br />";
|
|
|
|
echo "<small>\n";
|
2009-06-30 19:29:51 +10:00
|
|
|
|
2009-06-30 18:05:37 +10:00
|
|
|
flush();
|
|
|
|
|
|
|
|
// prevent script from bailing early on a long delete
|
2009-06-30 19:29:51 +10:00
|
|
|
@set_time_limit(0);
|
2009-06-30 18:05:37 +10:00
|
|
|
|
2009-06-30 19:29:51 +10:00
|
|
|
$del_result = pla_rdelete($ldapserver,$dn);
|
2009-06-30 18:05:37 +10:00
|
|
|
echo "</small><br />\n";
|
|
|
|
|
2009-06-30 19:29:51 +10:00
|
|
|
if ($del_result) {
|
|
|
|
# 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
|
|
|
# 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]);
|
|
|
|
|
|
|
|
# Get a tree in the session if not already gotten
|
|
|
|
initialize_session_tree();
|
|
|
|
|
|
|
|
# search and destroy from the tree sesssion
|
|
|
|
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:05:37 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
$_SESSION['tree'] = $tree;
|
|
|
|
session_write_close();
|
|
|
|
|
2009-06-30 19:29:51 +10:00
|
|
|
?>
|
2009-06-30 18:05:37 +10:00
|
|
|
|
|
|
|
<script language="javascript">
|
|
|
|
parent.left_frame.location.reload();
|
|
|
|
</script>
|
|
|
|
|
2009-06-30 19:29:51 +10:00
|
|
|
<?php
|
2009-06-30 18:05:37 +10:00
|
|
|
|
2009-06-30 19:29:51 +10:00
|
|
|
echo sprintf($lang['entry_and_sub_tree_deleted_successfully'],'<b>'.htmlspecialchars($dn).'</b>');
|
2009-06-30 18:05:37 +10:00
|
|
|
|
|
|
|
} else {
|
2009-06-30 19:40:37 +10:00
|
|
|
pla_error(sprintf($lang['could_not_delete_entry'],htmlspecialchars($dn)),
|
|
|
|
$ldapserver->error(),$ldapserver->errno());
|
2009-06-30 18:05:37 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
exit;
|
|
|
|
|
2009-06-30 19:29:51 +10:00
|
|
|
function pla_rdelete($ldapserver,$dn) {
|
2009-06-30 19:22:30 +10:00
|
|
|
global $lang;
|
2009-06-30 19:29:51 +10:00
|
|
|
$children = get_container_contents($ldapserver,$dn);
|
2009-06-30 18:05:37 +10:00
|
|
|
|
2009-06-30 19:29:51 +10:00
|
|
|
if (! is_array($children) || count($children) == 0) {
|
|
|
|
echo "<nobr>".sprintf($lang['deleting_dn'],htmlspecialchars($dn))."...";
|
2009-06-30 18:05:37 +10:00
|
|
|
flush();
|
2009-06-30 19:29:51 +10:00
|
|
|
|
|
|
|
if (run_hook('pre_entry_delete',array('server_id' => $ldapserver->server_id,'dn' => $dn)))
|
|
|
|
|
|
|
|
if (@ldap_delete($ldapserver->connect(),$dn)) {
|
|
|
|
run_hook ('post_entry_delete',
|
|
|
|
array('server_id' => $ldapserver->server_id,'dn' => $dn));
|
|
|
|
echo " <span style=\"color:green\">".$lang['success']."</span></nobr><br />\n";
|
|
|
|
return true;
|
|
|
|
|
|
|
|
} else {
|
2009-06-30 19:40:37 +10:00
|
|
|
pla_error(sprintf($lang['failed_to_delete_entry'],htmlspecialchars($dn)),
|
|
|
|
$ldapserver->error(),$ldapserver->errno());
|
2009-06-30 19:29:51 +10:00
|
|
|
}
|
2009-06-30 18:05:37 +10:00
|
|
|
} else {
|
2009-06-30 19:29:51 +10:00
|
|
|
foreach ($children as $child_dn) {
|
|
|
|
pla_rdelete($ldapserver,$child_dn);
|
2009-06-30 18:05:37 +10:00
|
|
|
}
|
2009-06-30 19:29:51 +10:00
|
|
|
|
|
|
|
echo "<nobr>".sprintf($lang['deleting_dn'],htmlspecialchars($dn))."...";
|
2009-06-30 18:05:37 +10:00
|
|
|
flush();
|
|
|
|
|
2009-06-30 19:29:51 +10:00
|
|
|
if (true === run_hook ('pre_entry_delete',array('server_id' => $ldapserver->server_id,'dn' => $dn)))
|
|
|
|
if (@ldap_delete($ldapserver->connect(),$dn)) {
|
|
|
|
run_hook ('post_entry_delete',
|
|
|
|
array('server_id' => $ldapserver->server_id,'dn' => $dn));
|
|
|
|
|
|
|
|
echo " <span style=\"color:green\">".$lang['success']."</span></nobr><br />\n";
|
|
|
|
return true;
|
|
|
|
|
|
|
|
} else {
|
2009-06-30 19:40:37 +10:00
|
|
|
pla_error(sprintf($lang['failed_to_delete_entry'],htmlspecialchars($dn)),
|
|
|
|
$ldapserver->error(),$ldapserver->errno());
|
2009-06-30 19:29:51 +10:00
|
|
|
}
|
|
|
|
}
|
2009-06-30 18:05:37 +10:00
|
|
|
}
|
2009-06-30 19:29:51 +10:00
|
|
|
?>
|