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 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 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 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