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() ) ); } } } ?>