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