xref: /onnv-gate/usr/src/lib/libldap4/common/rename.c (revision 3857:21b9b714e4ab)
10Sstevel@tonic-gate /*
20Sstevel@tonic-gate  *
3*3857Sstevel  * Copyright 1998 Sun Microsystems, Inc.  All rights reserved.
4*3857Sstevel  * Use is subject to license terms.
50Sstevel@tonic-gate  *
60Sstevel@tonic-gate  *
70Sstevel@tonic-gate  * Comments:
80Sstevel@tonic-gate  *
90Sstevel@tonic-gate  */
100Sstevel@tonic-gate 
110Sstevel@tonic-gate #pragma ident	"%Z%%M%	%I%	%E% SMI"
120Sstevel@tonic-gate 
130Sstevel@tonic-gate #include <stdio.h>
140Sstevel@tonic-gate #include <string.h>
150Sstevel@tonic-gate 
160Sstevel@tonic-gate #ifdef MACOS
170Sstevel@tonic-gate #include "macos.h"
180Sstevel@tonic-gate #endif /* MACOS */
190Sstevel@tonic-gate 
200Sstevel@tonic-gate #if !defined( MACOS ) && !defined( DOS )
210Sstevel@tonic-gate #include <sys/types.h>
220Sstevel@tonic-gate #include <sys/socket.h>
230Sstevel@tonic-gate #endif
240Sstevel@tonic-gate 
250Sstevel@tonic-gate #include "lber.h"
260Sstevel@tonic-gate #include "ldap.h"
270Sstevel@tonic-gate #include "ldap-private.h"
280Sstevel@tonic-gate #include "ldap-int.h"
290Sstevel@tonic-gate 
ldap_build_rename_req(LDAP * ld,char * dn,char * newrdn,char * newparent,int deleteoldrdn,LDAPControl ** serverctrls)300Sstevel@tonic-gate BerElement * ldap_build_rename_req ( LDAP *ld, char *dn, char *newrdn, char *newparent,
310Sstevel@tonic-gate 									 int deleteoldrdn, LDAPControl **serverctrls)
320Sstevel@tonic-gate {
330Sstevel@tonic-gate 	BerElement *ber;
340Sstevel@tonic-gate 	int rc;
350Sstevel@tonic-gate 
360Sstevel@tonic-gate 	/*
370Sstevel@tonic-gate 	 * A modify rdn request looks like this:
380Sstevel@tonic-gate 	 *	ModifyRDNRequest ::= SEQUENCE {
390Sstevel@tonic-gate 	 *		entry		LDAPDN,
400Sstevel@tonic-gate 	 *		newrdn		RelativeLDAPDN,
410Sstevel@tonic-gate 	 *		deleteoldrdn	BOOLEAN
420Sstevel@tonic-gate 	 *		newSuperior	[0]	LDAPDN OPTIONAL
430Sstevel@tonic-gate 	 *	}
440Sstevel@tonic-gate 	 */
450Sstevel@tonic-gate 
460Sstevel@tonic-gate 	/* create a message to send */
470Sstevel@tonic-gate 	if ( (ber = alloc_ber_with_options( ld )) == NULLBER ) {
480Sstevel@tonic-gate 		return( NULLBER );
490Sstevel@tonic-gate 	}
500Sstevel@tonic-gate 
510Sstevel@tonic-gate 	if ( ber_printf( ber, "{it{ssb", ++ld->ld_msgid, LDAP_REQ_MODRDN, dn,
520Sstevel@tonic-gate 	    newrdn, deleteoldrdn ) == -1 ) {
530Sstevel@tonic-gate 		ld->ld_errno = LDAP_ENCODING_ERROR;
540Sstevel@tonic-gate 		ber_free( ber, 1 );
550Sstevel@tonic-gate 		return( NULLBER );
560Sstevel@tonic-gate 	}
570Sstevel@tonic-gate 
580Sstevel@tonic-gate 	if (newparent) {
590Sstevel@tonic-gate 		if ( ber_printf( ber, "ts}", LDAP_TAG_NEWPARENT, newparent) == -1){
600Sstevel@tonic-gate 			ld->ld_errno = LDAP_ENCODING_ERROR;
610Sstevel@tonic-gate 			ber_free( ber, 1 );
620Sstevel@tonic-gate 			return( NULLBER );
630Sstevel@tonic-gate 		}
640Sstevel@tonic-gate 
650Sstevel@tonic-gate 	} else if ( ber_printf( ber, "}" ) == -1 ) {
660Sstevel@tonic-gate 		ld->ld_errno = LDAP_ENCODING_ERROR;
670Sstevel@tonic-gate 		ber_free( ber, 1 );
680Sstevel@tonic-gate 		return( NULLBER );
690Sstevel@tonic-gate 	}
700Sstevel@tonic-gate 	/* LDAPv3 */
710Sstevel@tonic-gate 	/* Code controls if any */
720Sstevel@tonic-gate 	if (serverctrls && serverctrls[0]) {
730Sstevel@tonic-gate 		if (ldap_controls_code(ber, serverctrls) != LDAP_SUCCESS){
740Sstevel@tonic-gate 			ld->ld_errno = LDAP_ENCODING_ERROR;
750Sstevel@tonic-gate 			ber_free( ber, 1 );
760Sstevel@tonic-gate 			return( NULLBER );
770Sstevel@tonic-gate 		}
780Sstevel@tonic-gate 	} else if (ld->ld_srvctrls && ld->ld_srvctrls[0]) {
790Sstevel@tonic-gate 		/* Otherwise, is there any global server ctrls ? */
800Sstevel@tonic-gate 		if (ldap_controls_code(ber, ld->ld_srvctrls) != LDAP_SUCCESS){
810Sstevel@tonic-gate 			ld->ld_errno = LDAP_ENCODING_ERROR;
820Sstevel@tonic-gate 			ber_free( ber, 1 );
830Sstevel@tonic-gate 			return( NULLBER );
840Sstevel@tonic-gate 		}
850Sstevel@tonic-gate 	}
860Sstevel@tonic-gate 
870Sstevel@tonic-gate 	if ( ber_printf( ber, "}" ) == -1 ) {
880Sstevel@tonic-gate 		ld->ld_errno = LDAP_ENCODING_ERROR;
890Sstevel@tonic-gate 		ber_free( ber, 1 );
900Sstevel@tonic-gate 		return( NULLBER );
910Sstevel@tonic-gate 	}
920Sstevel@tonic-gate 
930Sstevel@tonic-gate 	return (ber);
940Sstevel@tonic-gate }
950Sstevel@tonic-gate 
960Sstevel@tonic-gate /* ldap_rename - Modify the name of an entry.
970Sstevel@tonic-gate  * Parameters :
980Sstevel@tonic-gate  *     ld : LDAP descriptor.
990Sstevel@tonic-gate  *     dn : DN of the object to rename.
1000Sstevel@tonic-gate  *     newrdn : New RDN to give to the entry.
1010Sstevel@tonic-gate  *     newparent : the parent or superior entry. If NULL only RDN is changed.
1020Sstevel@tonic-gate  *                 "" means the root DN.
1030Sstevel@tonic-gate  *     deleteoldrdn : Boolean to indicate wether or not to remove the old RDN value.
1040Sstevel@tonic-gate  *     serverctrls : List of Server controls.
1050Sstevel@tonic-gate  *     clientctrls : List of client controls.
1060Sstevel@tonic-gate  *     msgidp : the msg id return if renamed succeded.
1070Sstevel@tonic-gate  */
1080Sstevel@tonic-gate 
ldap_rename(LDAP * ld,char * dn,char * newrdn,char * newparent,int deleteoldrdn,LDAPControl ** serverctrls,LDAPControl ** clientctrls,int * msgidp)1090Sstevel@tonic-gate int ldap_rename(LDAP *ld, char *dn, char *newrdn, char *newparent, int deleteoldrdn,
1100Sstevel@tonic-gate 				LDAPControl ** serverctrls, LDAPControl **clientctrls, int *msgidp)
1110Sstevel@tonic-gate {
1120Sstevel@tonic-gate 	BerElement	*ber;
1130Sstevel@tonic-gate 	int rv;
1140Sstevel@tonic-gate 
1150Sstevel@tonic-gate #ifdef _REENTRANT
1160Sstevel@tonic-gate 	LOCK_LDAP(ld);
1170Sstevel@tonic-gate #endif
1180Sstevel@tonic-gate 	Debug( LDAP_DEBUG_TRACE, catgets(slapdcat, 1, 87, "ldap_rename\n"), 0, 0, 0 );
1190Sstevel@tonic-gate 
1200Sstevel@tonic-gate 	if ((ber = ldap_build_rename_req(ld, dn, newrdn, newparent, deleteoldrdn, serverctrls)) == NULLBER){
1210Sstevel@tonic-gate 		rv = ld->ld_errno;
1220Sstevel@tonic-gate 		if (rv == LDAP_SUCCESS)
1230Sstevel@tonic-gate 			rv = LDAP_OTHER;
1240Sstevel@tonic-gate #ifdef _REENTRANT
1250Sstevel@tonic-gate 		UNLOCK_LDAP(ld);
1260Sstevel@tonic-gate #endif
1270Sstevel@tonic-gate 		return (rv);
1280Sstevel@tonic-gate 	}
1290Sstevel@tonic-gate 
1300Sstevel@tonic-gate 	/* send the message */
1310Sstevel@tonic-gate 	rv = send_initial_request( ld, LDAP_REQ_MODRDN, dn, ber );
1320Sstevel@tonic-gate 	if (rv == -1) {
1330Sstevel@tonic-gate 		rv = ld->ld_errno;
1340Sstevel@tonic-gate 		if (rv == LDAP_SUCCESS){
1350Sstevel@tonic-gate 			rv = LDAP_OTHER;
1360Sstevel@tonic-gate 		}
1370Sstevel@tonic-gate 
1380Sstevel@tonic-gate #ifdef  _REENTRANT
1390Sstevel@tonic-gate 		UNLOCK_LDAP(ld);
1400Sstevel@tonic-gate #endif
1410Sstevel@tonic-gate 		return (rv);
1420Sstevel@tonic-gate 	}
1430Sstevel@tonic-gate 
1440Sstevel@tonic-gate 	*msgidp = rv;
1450Sstevel@tonic-gate #ifdef  _REENTRANT
1460Sstevel@tonic-gate 	UNLOCK_LDAP(ld);
1470Sstevel@tonic-gate #endif
1480Sstevel@tonic-gate 	return (LDAP_SUCCESS);
1490Sstevel@tonic-gate 
1500Sstevel@tonic-gate }
1510Sstevel@tonic-gate 
1520Sstevel@tonic-gate 
ldap_rename_s(LDAP * ld,char * dn,char * newrdn,char * newparent,int deleteoldrdn,LDAPControl ** serverctrls,LDAPControl ** clientctrls)1530Sstevel@tonic-gate int ldap_rename_s(LDAP *ld, char *dn, char *newrdn, char *newparent, int deleteoldrdn,
1540Sstevel@tonic-gate 				  LDAPControl ** serverctrls, LDAPControl **clientctrls)
1550Sstevel@tonic-gate {
1560Sstevel@tonic-gate 	int msgid;
1570Sstevel@tonic-gate 	int retcode = LDAP_SUCCESS;
1580Sstevel@tonic-gate 	LDAPMessage *res;
1590Sstevel@tonic-gate 
1600Sstevel@tonic-gate 	if ((retcode = ldap_rename(ld, dn, newrdn, newparent, deleteoldrdn, serverctrls, clientctrls, &msgid)) != LDAP_SUCCESS)
1610Sstevel@tonic-gate 		return (retcode);
1620Sstevel@tonic-gate 	if (ldap_result(ld, msgid, 1, (struct timeval *)NULL, &res ) == -1)
1630Sstevel@tonic-gate 		return (ld->ld_errno );
1640Sstevel@tonic-gate 
1650Sstevel@tonic-gate #ifdef  _REENTRANT
1660Sstevel@tonic-gate 	LOCK_LDAP(ld);
1670Sstevel@tonic-gate #endif
1680Sstevel@tonic-gate 	retcode = ldap_parse_result( ld, res,  &ld->ld_errno, &ld->ld_matched, &ld->ld_error,
1690Sstevel@tonic-gate 								 &ld->ld_referrals, &ld->ld_ret_ctrls, 1);
1700Sstevel@tonic-gate 	if (retcode == LDAP_SUCCESS)
1710Sstevel@tonic-gate 		retcode = ld->ld_errno;
1720Sstevel@tonic-gate #ifdef  _REENTRANT
1730Sstevel@tonic-gate 	UNLOCK_LDAP(ld);
1740Sstevel@tonic-gate #endif
1750Sstevel@tonic-gate 	return (retcode);
1760Sstevel@tonic-gate }
177