2009-06-30 18:12:47 +10:00
|
|
|
<?php
|
|
|
|
// $Header: /cvsroot/phpldapadmin/phpldapadmin/rdelete.php,v 1.14 2004/03/19 20:13:08 i18phpldapadmin Exp $
|
|
|
|
|
2009-06-30 18:05:37 +10:00
|
|
|
|
|
|
|
/*
|
|
|
|
* rdelete.php
|
|
|
|
*
|
|
|
|
* Recursively deletes the specified DN and all of its children
|
|
|
|
* Variables that come in as POST vars:
|
|
|
|
* - dn (rawurlencoded)
|
|
|
|
* - server_id
|
|
|
|
*/
|
|
|
|
|
2009-06-30 18:09:20 +10:00
|
|
|
require realpath( 'common.php' );
|
2009-06-30 18:05:37 +10:00
|
|
|
|
2009-06-30 18:09:20 +10:00
|
|
|
$dn = $_POST['dn'];
|
|
|
|
$encoded_dn = rawurlencode( $dn );
|
2009-06-30 18:05:37 +10:00
|
|
|
$server_id = $_POST['server_id'];
|
2009-06-30 18:12:47 +10:00
|
|
|
$rdn = get_rdn( $dn );
|
2009-06-30 18:05:37 +10:00
|
|
|
|
|
|
|
if( ! $dn )
|
2009-06-30 18:12:47 +10:00
|
|
|
pla_error( $lang['you_must_specify_a_dn'] );
|
2009-06-30 18:05:37 +10:00
|
|
|
|
2009-06-30 18:07:14 +10:00
|
|
|
if( is_server_read_only( $server_id ) )
|
2009-06-30 18:12:47 +10:00
|
|
|
pla_error( $lang['no_updates_in_read_only_mode'] );
|
2009-06-30 18:07:14 +10:00
|
|
|
|
2009-06-30 18:12:47 +10:00
|
|
|
check_server_id( $server_id ) or pla_error( $lang['bad_server_id'] );
|
|
|
|
have_auth_info( $server_id ) or pla_error( $lang['not_enough_login_info'] );
|
|
|
|
pla_ldap_connect( $server_id ) or pla_error( $lang['could_not_connect'] );
|
|
|
|
dn_exists( $server_id, $dn ) or pla_error( sprintf( $lang['no_such_entry'], htmlspecialchars( $dn ) ) );
|
2009-06-30 18:05:37 +10:00
|
|
|
|
|
|
|
include 'header.php';
|
|
|
|
echo "<body>\n";
|
2009-06-30 18:12:47 +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";
|
|
|
|
flush();
|
|
|
|
|
|
|
|
// prevent script from bailing early on a long delete
|
|
|
|
@set_time_limit( 0 );
|
|
|
|
|
|
|
|
$del_result = pla_rdelete( $server_id, $dn );
|
|
|
|
echo "</small><br />\n";
|
|
|
|
if( $del_result )
|
|
|
|
{
|
|
|
|
// kill the DN from the tree browser session variable and
|
|
|
|
// refresh the tree viewer frame (left_frame)
|
|
|
|
|
2009-06-30 18:12:47 +10:00
|
|
|
if( array_key_exists( 'tree', $_SESSION ) )
|
2009-06-30 18:05:37 +10:00
|
|
|
{
|
|
|
|
$tree = $_SESSION['tree'];
|
|
|
|
|
|
|
|
// does it have children? (it shouldn't, but hey, you never know)
|
|
|
|
if( isset( $tree[$server_id][$dn] ) )
|
|
|
|
unset( $tree[$server_id][$dn] );
|
|
|
|
|
|
|
|
// search and destroy
|
|
|
|
foreach( $tree[$server_id] as $tree_dn => $subtree )
|
|
|
|
foreach( $subtree as $key => $sub_tree_dn )
|
|
|
|
if( 0 == strcasecmp( $sub_tree_dn, $dn ) )
|
|
|
|
unset( $tree[$server_id][$tree_dn][$key] );
|
|
|
|
}
|
|
|
|
|
|
|
|
$_SESSION['tree'] = $tree;
|
|
|
|
session_write_close();
|
|
|
|
|
|
|
|
?>
|
|
|
|
|
|
|
|
<script language="javascript">
|
|
|
|
parent.left_frame.location.reload();
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<?php
|
|
|
|
|
2009-06-30 18:12:47 +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 18:12:47 +10:00
|
|
|
pla_error( sprintf( $lang['could_not_delete_entry'], htmlspecialchars( $dn ) ), ldap_error( $ds ), ldap_errno( $ds ) );
|
2009-06-30 18:05:37 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
exit;
|
|
|
|
|
|
|
|
|
|
|
|
function pla_rdelete( $server_id, $dn )
|
|
|
|
{
|
2009-06-30 18:12:47 +10:00
|
|
|
global $lang;
|
2009-06-30 18:05:37 +10:00
|
|
|
$children = get_container_contents( $server_id, $dn );
|
|
|
|
global $ds;
|
|
|
|
$ds = pla_ldap_connect( $server_id );
|
|
|
|
|
|
|
|
if( ! is_array( $children ) || count( $children ) == 0 ) {
|
2009-06-30 18:12:47 +10:00
|
|
|
echo "<nobr>" . sprintf( $lang['deleting_dn'], htmlspecialchars( $dn ) ) . "...";
|
2009-06-30 18:05:37 +10:00
|
|
|
flush();
|
2009-06-30 18:09:20 +10:00
|
|
|
if( true === preEntryDelete( $server_id, $dn ) )
|
|
|
|
if( @ldap_delete( $ds, $dn ) ) {
|
|
|
|
postEntryDelete( $server_id, $dn );
|
2009-06-30 18:12:47 +10:00
|
|
|
echo " <span style=\"color:green\">" . $lang['success'] . "</span></nobr><br />\n";
|
2009-06-30 18:09:20 +10:00
|
|
|
return true;
|
|
|
|
} else {
|
2009-06-30 18:12:47 +10:00
|
|
|
pla_error( sprintf( $lang['failed_to_delete_entry'], htmlspecialchars( $dn ) ),
|
|
|
|
ldap_error( $ds ), ldap_errno( $ds ) );
|
2009-06-30 18:09:20 +10:00
|
|
|
}
|
2009-06-30 18:05:37 +10:00
|
|
|
} else {
|
|
|
|
foreach( $children as $child_dn ) {
|
|
|
|
pla_rdelete( $server_id, $child_dn );
|
|
|
|
}
|
2009-06-30 18:12:47 +10:00
|
|
|
echo "<nobr>" . sprintf( $lang['deleting_dn'], htmlspecialchars( $dn ) ) . "...";
|
2009-06-30 18:05:37 +10:00
|
|
|
flush();
|
2009-06-30 18:09:20 +10:00
|
|
|
if( true === preEntryDelete( $server_id, $dn ) )
|
|
|
|
if( @ldap_delete( $ds, $dn ) ) {
|
|
|
|
postEntryDelete( $server_id, $dn );
|
2009-06-30 18:12:47 +10:00
|
|
|
echo " <span style=\"color:green\">" . $lang['success'] . "</span></nobr><br />\n";
|
2009-06-30 18:09:20 +10:00
|
|
|
return true;
|
|
|
|
} else {
|
2009-06-30 18:12:47 +10:00
|
|
|
pla_error( sprintf( $lang['failed_to_delete_entry'], htmlspecialchars( $dn ) ),
|
|
|
|
ldap_error( $ds ), ldap_errno( $ds ) );
|
2009-06-30 18:09:20 +10:00
|
|
|
}
|
2009-06-30 18:05:37 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|