Back to index

openldap  2.4.31
Functions
delete.c File Reference
#include "portable.h"
#include <stdio.h>
#include <ac/socket.h>
#include <ac/string.h>
#include <ac/time.h>
#include "ldap-int.h"

Go to the source code of this file.

Functions

int ldap_delete_ext (LDAP *ld, LDAP_CONST char *dn, LDAPControl **sctrls, LDAPControl **cctrls, int *msgidp)
int ldap_delete_ext_s (LDAP *ld, LDAP_CONST char *dn, LDAPControl **sctrls, LDAPControl **cctrls)
int ldap_delete (LDAP *ld, LDAP_CONST char *dn)
int ldap_delete_s (LDAP *ld, LDAP_CONST char *dn)

Function Documentation

int ldap_delete ( LDAP *  ld,
LDAP_CONST char *  dn 
)

Definition at line 138 of file delete.c.

{
       int msgid;

       /*
        * A delete request looks like this:
        *     DelRequet ::= DistinguishedName,
        */

       Debug( LDAP_DEBUG_TRACE, "ldap_delete\n", 0, 0, 0 );

       return ldap_delete_ext( ld, dn, NULL, NULL, &msgid ) == LDAP_SUCCESS
              ? msgid : -1 ;
}

Here is the call graph for this function:

Here is the caller graph for this function:

int ldap_delete_ext ( LDAP *  ld,
LDAP_CONST char *  dn,
LDAPControl **  sctrls,
LDAPControl **  cctrls,
int msgidp 
)

Definition at line 48 of file delete.c.

{
       int rc;
       BerElement    *ber;
       ber_int_t     id;

       Debug( LDAP_DEBUG_TRACE, "ldap_delete_ext\n", 0, 0, 0 );

       assert( ld != NULL );
       assert( LDAP_VALID( ld ) );
       assert( dn != NULL );
       assert( msgidp != NULL );

       /* check client controls */
       rc = ldap_int_client_controls( ld, cctrls );
       if( rc != LDAP_SUCCESS ) return rc;

       /* create a message to send */
       if ( (ber = ldap_alloc_ber_with_options( ld )) == NULL ) {
              ld->ld_errno = LDAP_NO_MEMORY;
              return( ld->ld_errno );
       }

       LDAP_NEXT_MSGID( ld, id );
       rc = ber_printf( ber, "{its", /* '}' */
              id, LDAP_REQ_DELETE, dn );
       if ( rc == -1 )
       {
              ld->ld_errno = LDAP_ENCODING_ERROR;
              ber_free( ber, 1 );
              return( ld->ld_errno );
       }

       /* Put Server Controls */
       if( ldap_int_put_controls( ld, sctrls, ber ) != LDAP_SUCCESS ) {
              ber_free( ber, 1 );
              return ld->ld_errno;
       }

       if ( ber_printf( ber, /*{*/ "N}" ) == -1 ) {
              ld->ld_errno = LDAP_ENCODING_ERROR;
              ber_free( ber, 1 );
              return( ld->ld_errno );
       }

       /* send the message */
       *msgidp = ldap_send_initial_request( ld, LDAP_REQ_DELETE, dn, ber, id );

       if(*msgidp < 0)
              return ld->ld_errno;

       return LDAP_SUCCESS;
}

Here is the call graph for this function:

Here is the caller graph for this function:

int ldap_delete_ext_s ( LDAP *  ld,
LDAP_CONST char *  dn,
LDAPControl **  sctrls,
LDAPControl **  cctrls 
)

Definition at line 108 of file delete.c.

{
       int    msgid;
       int rc;
       LDAPMessage   *res;

       rc = ldap_delete_ext( ld, dn, sctrls, cctrls, &msgid );
       
       if( rc != LDAP_SUCCESS )
              return( ld->ld_errno );

       if ( ldap_result( ld, msgid, LDAP_MSG_ALL, (struct timeval *) NULL, &res ) == -1 || !res )
              return( ld->ld_errno );

       return( ldap_result2error( ld, res, 1 ) );
}

Here is the call graph for this function:

Here is the caller graph for this function:

int ldap_delete_s ( LDAP *  ld,
LDAP_CONST char *  dn 
)

Definition at line 155 of file delete.c.

{
       return ldap_delete_ext_s( ld, dn, NULL, NULL );
}

Here is the call graph for this function:

Here is the caller graph for this function: