3 * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved.
4 * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
7 * Copyright (c) 1990 Regents of the University of Michigan.
14 * A delete request looks like this:
15 * DelRequet ::= DistinguishedName,
22 #include <ac/socket.h>
23 #include <ac/string.h>
29 * ldap_delete_ext - initiate an ldap extended delete operation. Parameters:
32 * dn DN of the object to delete
33 * sctrls Server Controls
34 * cctrls Client Controls
35 * msgidp Message Id Pointer
38 * rc = ldap_delete( ld, dn, sctrls, cctrls, msgidp );
53 LDAP_LOG ( OPERATION, ENTRY, "ldap_delete_ext\n", 0,0,0 );
55 Debug( LDAP_DEBUG_TRACE, "ldap_delete_ext\n", 0, 0, 0 );
59 assert( LDAP_VALID( ld ) );
61 assert( msgidp != NULL );
63 /* check client controls */
64 rc = ldap_int_client_controls( ld, cctrls );
65 if( rc != LDAP_SUCCESS ) return rc;
67 /* create a message to send */
68 if ( (ber = ldap_alloc_ber_with_options( ld )) == NULL ) {
69 ld->ld_errno = LDAP_NO_MEMORY;
70 return( ld->ld_errno );
73 LDAP_NEXT_MSGID( ld, id );
74 rc = ber_printf( ber, "{its", /* '}' */
75 id, LDAP_REQ_DELETE, dn );
78 ld->ld_errno = LDAP_ENCODING_ERROR;
80 return( ld->ld_errno );
83 /* Put Server Controls */
84 if( ldap_int_put_controls( ld, sctrls, ber ) != LDAP_SUCCESS ) {
89 if ( ber_printf( ber, /*{*/ "N}" ) == -1 ) {
90 ld->ld_errno = LDAP_ENCODING_ERROR;
92 return( ld->ld_errno );
95 /* send the message */
96 *msgidp = ldap_send_initial_request( ld, LDAP_REQ_DELETE, dn, ber, id );
108 LDAPControl **sctrls,
109 LDAPControl **cctrls )
115 rc = ldap_delete_ext( ld, dn, sctrls, cctrls, &msgid );
117 if( rc != LDAP_SUCCESS )
118 return( ld->ld_errno );
120 if ( ldap_result( ld, msgid, 1, (struct timeval *) NULL, &res ) == -1 )
121 return( ld->ld_errno );
123 return( ldap_result2error( ld, res, 1 ) );
126 * ldap_delete - initiate an ldap (and X.500) delete operation. Parameters:
129 * dn DN of the object to delete
132 * msgid = ldap_delete( ld, dn );
135 ldap_delete( LDAP *ld, LDAP_CONST char *dn )
140 * A delete request looks like this:
141 * DelRequet ::= DistinguishedName,
145 LDAP_LOG ( OPERATION, ENTRY, "ldap_delete\n", 0,0,0 );
147 Debug( LDAP_DEBUG_TRACE, "ldap_delete\n", 0, 0, 0 );
150 return ldap_delete_ext( ld, dn, NULL, NULL, &msgid ) == LDAP_SUCCESS
156 ldap_delete_s( LDAP *ld, LDAP_CONST char *dn )
158 return ldap_delete_ext_s( ld, dn, NULL, NULL );