[Fedora-directory-commits] ldapserver/ldap/servers/slapd/back-ldbm ldbm_modrdn.c, 1.7, 1.8

Noriko Hosoi (nhosoi) fedora-directory-commits at redhat.com
Tue Jul 29 20:37:25 UTC 2008


Author: nhosoi

Update of /cvs/dirsec/ldapserver/ldap/servers/slapd/back-ldbm
In directory cvs-int.fedora.redhat.com:/tmp/cvs-serv27301

Modified Files:
	ldbm_modrdn.c 
Log Message:
Resolves: #428232
Summary: DN Rename with case change only fails
Description: The modrdn operation allows the source dn and the target dn are
identical or the same except the cases.



Index: ldbm_modrdn.c
===================================================================
RCS file: /cvs/dirsec/ldapserver/ldap/servers/slapd/back-ldbm/ldbm_modrdn.c,v
retrieving revision 1.7
retrieving revision 1.8
diff -u -r1.7 -r1.8
--- ldbm_modrdn.c	18 Oct 2007 22:40:18 -0000	1.7
+++ ldbm_modrdn.c	29 Jul 2008 20:37:22 -0000	1.8
@@ -263,12 +263,14 @@
 	    ldap_result_code= -1;
 	    goto error_return; /* error result sent by find_entry2modify() */
 	}
-
     /* Check that an entry with the same DN doesn't already exist. */
 	{
 		Slapi_Entry *entry;
 		slapi_pblock_get( pb, SLAPI_MODRDN_EXISTING_ENTRY, &entry);
-		if(entry!=NULL)
+		if((entry != NULL) && 
+			/* allow modrdn even if the src dn and dest dn are identical */
+		   (0 != slapi_sdn_compare((const Slapi_DN *)&dn_newdn,
+								   (const Slapi_DN *)&dn_olddn)))
 		{
 			ldap_result_code= LDAP_ALREADY_EXISTS;
 			goto error_return;
@@ -279,14 +281,14 @@
 	oldparent_addr.dn = (char*)slapi_sdn_get_dn (&dn_parentdn);
 	oldparent_addr.uniqueid = NULL;    		
 	parententry = find_entry2modify_only( pb, be, &oldparent_addr, NULL );
-   	modify_init(&parent_modify_context,parententry);
+	modify_init(&parent_modify_context,parententry);
 
 	/* Fetch and lock the new parent of the entry that is moving */    		
 	if(slapi_sdn_get_ndn(&dn_newsuperiordn)!=NULL)
 	{
 		slapi_pblock_get (pb, SLAPI_MODRDN_NEWSUPERIOR_ADDRESS, &newsuperior_addr);
 		newparententry = find_entry2modify_only( pb, be, newsuperior_addr, NULL);
-	   	modify_init(&newparent_modify_context,newparententry);
+		modify_init(&newparent_modify_context,newparententry);
 	}
 
 	opcsn = operation_get_csn (operation);
@@ -414,21 +416,25 @@
 		goto error_return;
 	}
 
-   	slapi_entry_set_sdn( ec->ep_entry, &dn_newdn );
+	slapi_entry_set_sdn( ec->ep_entry, &dn_newdn );
 
 	/* create it in the cache - prevents others from creating it */
-	if ( cache_add_tentative( &inst->inst_cache, ec, NULL ) != 0 ) {
+	if (( cache_add_tentative( &inst->inst_cache, ec, NULL ) != 0 ) &&
+		/* allow modrdn even if the src dn and dest dn are identical */
+		( 0 != slapi_sdn_compare((const Slapi_DN *)&dn_newdn,
+							     (const Slapi_DN *)&dn_olddn)) )
+	{
 		/* somebody must've created it between dn2entry() and here */
 		/* JCMREPL - Hmm... we can't permit this to happen...? */
 		ldap_result_code= LDAP_ALREADY_EXISTS;
 		goto error_return;
 	}
-    ec_in_cache= 1;
+	ec_in_cache= 1;
 
     /* Build the list of modifications required to the existing entry */
 	{
-	   	slapi_mods_init(&smods_generated,4);
-	   	slapi_mods_init(&smods_generated_wsi,4);
+		slapi_mods_init(&smods_generated,4);
+		slapi_mods_init(&smods_generated_wsi,4);
 		ldap_result_code = moddn_newrdn_mods(pb, slapi_sdn_get_ndn(&dn_olddn), ec, &smods_generated, &smods_generated_wsi, 
 						     is_replicated_operation);
 		if (ldap_result_code != LDAP_SUCCESS) {




More information about the Fedora-directory-commits mailing list