From 00073c8cac60fa0e50b0a15c4a0c535141f6cd48 Mon Sep 17 00:00:00 2001 From: Pierangelo Masarati Date: Fri, 24 Mar 2006 22:49:51 +0000 Subject: [PATCH] fix operational attrs return with chain overlay (ITS#4431); misc cleanup --- servers/slapd/back-ldap/chain.c | 40 +++++++------------------------- servers/slapd/back-ldap/config.c | 4 ++++ servers/slapd/backend.c | 10 ++++---- servers/slapd/slap.h | 6 ++++- 4 files changed, 24 insertions(+), 36 deletions(-) diff --git a/servers/slapd/back-ldap/chain.c b/servers/slapd/back-ldap/chain.c index ddcc2a231c..399278f9a0 100644 --- a/servers/slapd/back-ldap/chain.c +++ b/servers/slapd/back-ldap/chain.c @@ -219,25 +219,6 @@ ldap_chain_uri_dup( void *c1, void *c2 ) return 0; } -static int -ldap_chain_operational( Operation *op, SlapReply *rs ) -{ - /* Trap entries generated by back-ldap. - * - * FIXME: we need a better way to recognize them; a cleaner - * solution would be to be able to intercept the response - * of be_operational(), so that we can divert only those - * calls that fail because operational attributes were - * requested for entries that do not belong to the underlying - * database. This fix is likely to intercept also entries - * generated by back-perl and so. */ - if ( rs->sr_entry->e_private == NULL ) { - return 0; - } - - return SLAP_CB_CONTINUE; -} - /* * Search specific response that strips entryDN from entries */ @@ -269,6 +250,10 @@ ldap_chain_cb_search_response( Operation *op, SlapReply *rs ) break; } } + + /* tell the frontend not to add generated + * operational attributes */ + rs->sr_flags |= REP_NO_OPERATIONALS; return SLAP_CB_CONTINUE; @@ -786,7 +771,11 @@ cleanup:; case LDAP_SUCCESS: case LDAP_REFERRAL: /* slapd-ldap sent response */ - assert( sc2.sc_private == LDAP_CH_RES ); + if ( !op->o_abandon ) { + /* FIXME: should we send response? */ + Debug( LDAP_DEBUG_ANY, "%s: ldap_chain_response: overlay should have sent result.\n", + op->o_log_prefix, 0, 0 ); + } break; default: @@ -1807,17 +1796,6 @@ chain_initialize( void ) ldapchain.on_bi.bi_db_close = ldap_chain_db_close; ldapchain.on_bi.bi_db_destroy = ldap_chain_db_destroy; - /* ... otherwise the underlying backend's function would be called, - * likely passing an invalid entry; on the contrary, the requested - * operational attributes should have been returned while chasing - * the referrals. This all in all is a bit messy, because part - * of the operational attributes are generated by the backend; - * part by the frontend; back-ldap should receive all the available - * ones from the remote server, but then, on its own, it strips those - * it assumes will be (re)generated by the frontend (e.g. - * subschemaSubentry.) */ - ldapchain.on_bi.bi_operational = ldap_chain_operational; - ldapchain.on_bi.bi_connection_destroy = ldap_chain_connection_destroy; ldapchain.on_response = ldap_chain_response; diff --git a/servers/slapd/back-ldap/config.c b/servers/slapd/back-ldap/config.c index 6dd8363a19..a00d820b64 100644 --- a/servers/slapd/back-ldap/config.c +++ b/servers/slapd/back-ldap/config.c @@ -314,6 +314,10 @@ ldap_back_cf_gen( ConfigArgs *c ) struct berval bv = BER_BVNULL; rc = 0; + if ( li == NULL ) { + return 1; + } + switch( c->type ) { case LDAP_BACK_CFG_URI: if ( li->li_uri != NULL ) { diff --git a/servers/slapd/backend.c b/servers/slapd/backend.c index eeb2b5dd9a..e4df383b0c 100644 --- a/servers/slapd/backend.c +++ b/servers/slapd/backend.c @@ -1709,15 +1709,17 @@ fe_aux_operational( * and the backend supports specific operational attributes, * add them to the attribute list */ - if ( SLAP_OPATTRS( rs->sr_attr_flags ) || ( rs->sr_attrs && - ad_inlist( slap_schema.si_ad_entryDN, rs->sr_attrs ) ) ) + if ( !( rs->sr_flags & REP_NO_ENTRYDN ) + && ( SLAP_OPATTRS( rs->sr_attr_flags ) || ( rs->sr_attrs && + ad_inlist( slap_schema.si_ad_entryDN, rs->sr_attrs ) ) ) ) { *ap = slap_operational_entryDN( rs->sr_entry ); ap = &(*ap)->a_next; } - if ( SLAP_OPATTRS( rs->sr_attr_flags ) || ( rs->sr_attrs && - ad_inlist( slap_schema.si_ad_subschemaSubentry, rs->sr_attrs ) ) ) + if ( !( rs->sr_flags & REP_NO_SUBSCHEMA) + && ( SLAP_OPATTRS( rs->sr_attr_flags ) || ( rs->sr_attrs && + ad_inlist( slap_schema.si_ad_subschemaSubentry, rs->sr_attrs ) ) ) ) { *ap = slap_operational_subschemaSubentry( op->o_bd ); ap = &(*ap)->a_next; diff --git a/servers/slapd/slap.h b/servers/slapd/slap.h index d1529f9d75..bf9eb8a263 100644 --- a/servers/slapd/slap.h +++ b/servers/slapd/slap.h @@ -1971,7 +1971,11 @@ typedef struct slap_rep { #define REP_ENTRY_MUSTBEFREED 0x0002U #define REP_ENTRY_MUSTRELEASE 0x0004U #define REP_MATCHED_MUSTBEFREED 0x0010U -#define REP_REF_MUSTBEFREED 0x0020U +#define REP_REF_MUSTBEFREED 0x0020U + +#define REP_NO_ENTRYDN 0x1000U +#define REP_NO_SUBSCHEMA 0x2000U +#define REP_NO_OPERATIONALS (REP_NO_ENTRYDN|REP_NO_SUBSCHEMA) } SlapReply; /* short hands for response members */