From 9b0585f393bd126f83b5468a51b4017db9d94e35 Mon Sep 17 00:00:00 2001 From: Kurt Zeilenga Date: Wed, 9 Jan 2002 19:21:07 +0000 Subject: [PATCH] Add very basic subentry search support. --- servers/slapd/back-bdb/search.c | 39 +++++++++++++++++++++++---------- servers/slapd/proto-slap.h | 3 --- servers/slapd/slap.h | 4 +++- 3 files changed, 31 insertions(+), 15 deletions(-) diff --git a/servers/slapd/back-bdb/search.c b/servers/slapd/back-bdb/search.c index cd904105e7..d444c7844c 100644 --- a/servers/slapd/back-bdb/search.c +++ b/servers/slapd/back-bdb/search.c @@ -20,11 +20,11 @@ static int base_candidate( ID *ids ); static int search_candidates( BackendDB *be, + Operation *op, Entry *e, Filter *filter, int scope, int deref, - int manageDSAit, ID *ids ); int @@ -233,8 +233,8 @@ bdb_search( } else { BDB_IDL_ALL( bdb, candidates ); - rc = search_candidates( be, e, filter, - scope, deref, manageDSAit, candidates ); + rc = search_candidates( be, op, e, filter, + scope, deref, candidates ); } /* need normalized dn below */ @@ -503,23 +503,31 @@ static int oc_filter( static int search_candidates( BackendDB *be, + Operation *op, Entry *e, Filter *filter, int scope, int deref, - int manageDSAit, ID *ids ) { int rc; - Filter f, fand, rf, xf; + Filter f, scopef, sf, rf, xf; ID tmp[BDB_IDL_UM_SIZE]; AttributeAssertion aa_ref; + AttributeAssertion aa_subentry; struct bdb_info *bdb = (struct bdb_info *) be->be_private; #ifdef BDB_ALIASES Filter af; AttributeAssertion aa_alias; #endif + /* + * This routine takes as input a filter (user-filter) + * and rewrites it as follows: + * (&(scope=DN)[(objectClass=subentry)] + * (|[(objectClass=referral)(objectClass=alias)](user-filter)) + */ + Debug(LDAP_DEBUG_TRACE, "search_candidates: base=\"%s\" (0x%08lx) scope=%d\n", e->e_dn, (long) e->e_id, scope ); @@ -531,8 +539,8 @@ static int search_candidates( /* If the user's filter doesn't mention objectClass, or if * it just uses objectClass=*, these clauses are redundant. */ - if (oc_filter(filter)) { - if( !manageDSAit ) { /* match referrals */ + if (oc_filter(filter) && !get_subentries_visibility(op) ) { + if( !get_manageDSAit(op) ) { /* match referrals */ struct berval bv_ref = { sizeof("REFERRAL")-1, "REFERRAL" }; rf.f_choice = LDAP_FILTER_EQUALITY; rf.f_ava = &aa_ref; @@ -557,13 +565,22 @@ static int search_candidates( f.f_next = NULL; f.f_choice = LDAP_FILTER_AND; - f.f_and = &fand; - fand.f_choice = scope == LDAP_SCOPE_SUBTREE + f.f_and = &scopef; + scopef.f_choice = scope == LDAP_SCOPE_SUBTREE ? SLAPD_FILTER_DN_SUBTREE : SLAPD_FILTER_DN_ONE; - fand.f_dn = &e->e_nname; - fand.f_next = xf.f_or == filter ? filter : &xf ; + scopef.f_dn = &e->e_nname; + scopef.f_next = xf.f_or == filter ? filter : &xf ; + if( get_subentries_visibility( op ) ) { + struct berval bv_subentry = { sizeof("SUBENTRY")-1, "SUBENTRY" }; + sf.f_choice = LDAP_FILTER_EQUALITY; + sf.f_ava = &aa_subentry; + sf.f_av_desc = slap_schema.si_ad_objectClass; + sf.f_av_value = bv_subentry; + sf.f_next = scopef.f_next; + scopef.f_next = &sf; + } #ifdef BDB_FILTER_INDICES rc = bdb_filter_candidates( be, &f, ids, tmp ); diff --git a/servers/slapd/proto-slap.h b/servers/slapd/proto-slap.h index 0bf1aa33d2..315ed85df2 100644 --- a/servers/slapd/proto-slap.h +++ b/servers/slapd/proto-slap.h @@ -294,9 +294,6 @@ LDAP_SLAPD_F (int) get_ctrls LDAP_P(( LDAP_SLAPD_F (char *) get_supported_ctrl LDAP_P((int index)); -LDAP_SLAPD_F (int) get_manageDSAit LDAP_P(( Operation *op )); -LDAP_SLAPD_F (int) get_subentries LDAP_P(( Operation *op, int *visibility )); - /* * config.c */ diff --git a/servers/slapd/slap.h b/servers/slapd/slap.h index 8fc0fc5b20..6a24385ed4 100644 --- a/servers/slapd/slap.h +++ b/servers/slapd/slap.h @@ -1325,7 +1325,9 @@ typedef struct slap_op { char o_subentries_visibility; } Operation; -#define get_manageDSAit(op) ((int)(op)->o_managedsait) +#define get_manageDSAit(op) ((int)(op)->o_managedsait) +#define get_subentries(op) ((int)(op)->o_subentries) +#define get_subentries_visibility(op) ((int)(op)->o_subentries_visibility) /* * Caches the result of a backend_group check for ACL evaluation