Back to index

lightning-sunbird  0.9+nobinonly
Functions
delete.c File Reference
#include "ldap-int.h"

Go to the source code of this file.

Functions

int LDAP_CALL ldap_delete (LDAP *ld, const char *dn)
int LDAP_CALL ldap_delete_ext (LDAP *ld, const char *dn, LDAPControl **serverctrls, LDAPControl **clientctrls, int *msgidp)
int LDAP_CALL ldap_delete_s (LDAP *ld, const char *dn)
int LDAP_CALL ldap_delete_ext_s (LDAP *ld, const char *dn, LDAPControl **serverctrls, LDAPControl **clientctrls)

Function Documentation

int LDAP_CALL ldap_delete ( LDAP *  ld,
const char *  dn 
)

Definition at line 60 of file delete.c.

{
       int    msgid;

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

       if ( ldap_delete_ext( ld, dn, NULL, NULL, &msgid ) == LDAP_SUCCESS ) {
              return( msgid );
       } else {
              return( -1 ); /* error is in ld handle */
       }
}

Here is the call graph for this function:

Here is the caller graph for this function:

int LDAP_CALL ldap_delete_ext ( LDAP *  ld,
const char *  dn,
LDAPControl **  serverctrls,
LDAPControl **  clientctrls,
int msgidp 
)

Definition at line 75 of file delete.c.

{
       BerElement    *ber;
       int           rc, lderr;

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

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

       if ( !NSLDAPI_VALID_LDAP_POINTER( ld )) {
              return( LDAP_PARAM_ERROR );
       }

       if ( !NSLDAPI_VALID_LDAPMESSAGE_POINTER( msgidp )) 
        {
              LDAP_SET_LDERRNO( ld, LDAP_PARAM_ERROR, NULL, NULL );
              return( LDAP_PARAM_ERROR );
       }
       if ( dn == NULL ) {
              dn = "";
       }

       LDAP_MUTEX_LOCK( ld, LDAP_MSGID_LOCK );
       *msgidp = ++ld->ld_msgid;
       LDAP_MUTEX_UNLOCK( ld, LDAP_MSGID_LOCK );

       /* see if we should add to the cache */
       if ( ld->ld_cache_on && ld->ld_cache_delete != NULL ) {
              LDAP_MUTEX_LOCK( ld, LDAP_CACHE_LOCK );
              if ( (rc = (ld->ld_cache_delete)( ld, *msgidp, LDAP_REQ_DELETE,
                  dn )) != 0 ) {
                     *msgidp = rc;
                     LDAP_MUTEX_UNLOCK( ld, LDAP_CACHE_LOCK );
                     return( LDAP_SUCCESS );
              }
              LDAP_MUTEX_UNLOCK( ld, LDAP_CACHE_LOCK );
       }

       /* create a message to send */
       if (( lderr = nsldapi_alloc_ber_with_options( ld, &ber ))
           != LDAP_SUCCESS ) {
              return( lderr );
       }

       if ( ber_printf( ber, "{its", *msgidp, LDAP_REQ_DELETE, dn )
           == -1 ) {
              lderr = LDAP_ENCODING_ERROR;
              LDAP_SET_LDERRNO( ld, lderr, NULL, NULL );
              ber_free( ber, 1 );
              return( lderr );
       }

       if (( lderr = nsldapi_put_controls( ld, serverctrls, 1, ber ))
           != LDAP_SUCCESS ) {
              ber_free( ber, 1 );
              return( lderr );
       }

       /* send the message */
       rc = nsldapi_send_initial_request( ld, *msgidp, LDAP_REQ_DELETE,
              (char *)dn, ber );
       *msgidp = rc;
       return( rc < 0 ? LDAP_GET_LDERRNO( ld, NULL, NULL ) : LDAP_SUCCESS );
}

Here is the call graph for this function:

Here is the caller graph for this function:

int LDAP_CALL ldap_delete_ext_s ( LDAP *  ld,
const char *  dn,
LDAPControl **  serverctrls,
LDAPControl **  clientctrls 
)

Definition at line 153 of file delete.c.

{
       int           err, msgid;
       LDAPMessage   *res;

       if (( err = ldap_delete_ext( ld, dn, serverctrls, clientctrls,
           &msgid )) != LDAP_SUCCESS ) {
              return( err );
       }

       if ( ldap_result( ld, msgid, 1, (struct timeval *)NULL, &res ) == -1 ) {
              return( LDAP_GET_LDERRNO( ld, NULL, NULL ) );
       }

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

Here is the call graph for this function:

Here is the caller graph for this function:

int LDAP_CALL ldap_delete_s ( LDAP *  ld,
const char *  dn 
)

Definition at line 146 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: