isReadOnly() )
pla_error( $lang['no_updates_in_read_only_mode'] );
if( ! $ldapserver->haveAuthInfo())
pla_error( $lang['not_enough_login_info'] );
$dn = $_POST['dn'];
$encoded_dn = rawurlencode( $dn );
$rdn = get_rdn( $dn );
if( ! $dn )
pla_error( $lang['you_must_specify_a_dn'] );
dn_exists( $ldapserver, $dn ) or pla_error( sprintf( $lang['no_such_entry'], htmlspecialchars( $dn ) ) );
include './header.php';
echo "
\n";
echo "" . sprintf( $lang['deleting_dn'], htmlspecialchars($rdn) ) . "
\n";
echo "" . $lang['recursive_delete_progress'] . "
";
echo "
";
echo "\n";
flush();
// prevent script from bailing early on a long delete
@set_time_limit( 0 );
$del_result = pla_rdelete( $ldapserver, $dn );
echo "
\n";
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 ) ) {
$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] );
// Get a tree in the session if not already gotten
initialize_session_tree();
// search and destroy from the tree sesssion
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();
?>
' . htmlspecialchars( $dn ) . '' );
} else {
pla_error( sprintf( $lang['could_not_delete_entry'], htmlspecialchars( $dn ) ), ldap_error( $ldapserver->connect() ), ldap_errno( $ldapserver->connect() ) );
}
exit;
function pla_rdelete( $ldapserver, $dn ) {
global $lang;
$children = get_container_contents( $ldapserver, $dn );
if( ! is_array( $children ) || count( $children ) == 0 ) {
echo "" . sprintf( $lang['deleting_dn'], htmlspecialchars( $dn ) ) . "...";
flush();
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 " " . $lang['success'] . "
\n";
return true;
} else {
pla_error( sprintf( $lang['failed_to_delete_entry'], htmlspecialchars( $dn ) ),
ldap_error( $ldapserver->connect() ), ldap_errno( $ldapserver->connect() ) );
}
} else {
foreach( $children as $child_dn ) {
pla_rdelete( $ldapserver, $child_dn );
}
echo "" . sprintf( $lang['deleting_dn'], htmlspecialchars( $dn ) ) . "...";
flush();
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 " " . $lang['success'] . "
\n";
return true;
} else {
pla_error( sprintf( $lang['failed_to_delete_entry'], htmlspecialchars( $dn ) ),
ldap_error( $ldapserver->connect() ), ldap_errno( $ldapserver->connect() ) );
}
}
}
?>