]> git.sur5r.net Git - openldap/commitdiff
lookup entry id when equality on entryDN (ITS#5791; fixes previous commit)
authorPierangelo Masarati <ando@openldap.org>
Tue, 4 Nov 2008 12:16:23 +0000 (12:16 +0000)
committerPierangelo Masarati <ando@openldap.org>
Tue, 4 Nov 2008 12:16:23 +0000 (12:16 +0000)
servers/slapd/back-bdb/filterindex.c

index 9c823ad9a6d98430898292d310cbd5d1c92ab5ca..31fd91b342ea411c1a79f4330ea8d69f748e2f8b 100644 (file)
@@ -697,28 +697,6 @@ done:
        return rc;
 }
 
-static int
-dn_equality_candidate(
-       Operation *op,
-       DB_TXN *rtxn,
-       struct berval *ndn,
-       ID *ids )
-{
-       struct bdb_info *bdb = (struct bdb_info *) op->o_bd->be_private;
-       EntryInfo ei = { 0 };
-       DB_LOCK lock;
-       int rc;
-
-       lock.mode = DB_LOCK_NG;
-       rc = bdb_dn2id( op, ndn, &ei, rtxn, &lock );
-       if ( rc == 0 ) {
-               BDB_IDL_RANGE( ids, ei.bei_id, ei.bei_id );
-               bdb_cache_entry_db_unlock( bdb, &lock );
-       }
-
-       return rc;
-}
-
 static int
 equality_candidates(
        Operation *op,
@@ -740,7 +718,13 @@ equality_candidates(
                        ava->aa_desc->ad_cname.bv_val, 0, 0 );
 
        if ( ava->aa_desc == slap_schema.si_ad_entryDN ) {
-               return dn_equality_candidate( op, rtxn, &ava->aa_value, ids );
+               EntryInfo *ei = NULL;
+               rc = bdb_cache_find_ndn( op, rtxn, &ava->aa_value, &ei );
+               if ( rc == LDAP_SUCCESS )
+                       bdb_idl_insert( ids, ei->bei_id );
+               if ( ei )
+                       bdb_cache_entryinfo_unlock( ei );
+               return rc;
        }
 
        BDB_IDL_ALL( bdb, ids );