mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-12-23 16:19:35 -05:00
lookup entry id when equality on entryDN (proposed fix for ITS#5791; does not work for back-hdb, though)
This commit is contained in:
parent
d4970fcb6f
commit
45aaaddb16
1 changed files with 26 additions and 0 deletions
|
|
@ -697,6 +697,28 @@ 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,
|
||||
|
|
@ -717,6 +739,10 @@ equality_candidates(
|
|||
Debug( LDAP_DEBUG_TRACE, "=> bdb_equality_candidates (%s)\n",
|
||||
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 );
|
||||
}
|
||||
|
||||
BDB_IDL_ALL( bdb, ids );
|
||||
|
||||
rc = bdb_index_param( op->o_bd, ava->aa_desc, LDAP_FILTER_EQUALITY,
|
||||
|
|
|
|||
Loading…
Reference in a new issue