mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-30 13:30:57 +08:00
Initial dontUseCopy implementation
Needs to be extended to compare
This commit is contained in:
parent
97fa3f1efd
commit
a1eb25c595
@ -177,7 +177,7 @@ static struct slap_control control_defs[] = {
|
||||
#ifdef SLAP_DONTUSECOPY
|
||||
{ LDAP_CONTROL_DONTUSECOPY,
|
||||
(int)offsetof(struct slap_control_ids, sc_dontUseCopy),
|
||||
SLAP_CTRL_INTROGATE|SLAP_CTRL_HIDE,
|
||||
SLAP_CTRL_GLOBAL|SLAP_CTRL_INTROGATE|SLAP_CTRL_HIDE,
|
||||
NULL, NULL,
|
||||
parseDontUseCopy, LDAP_SLIST_ENTRY_INITIALIZER(next) },
|
||||
#endif
|
||||
@ -864,7 +864,7 @@ static int parseDontUseCopy (
|
||||
return LDAP_PROTOCOL_ERROR;
|
||||
}
|
||||
|
||||
if ( ctrl->ldctl_iscritical != SLAP_CONTROL_CRITICAL ) {
|
||||
if ( !ctrl->ldctl_iscritical ) {
|
||||
rs->sr_text = "dontUseCopy criticality of FALSE not allowed";
|
||||
return LDAP_PROTOCOL_ERROR;
|
||||
}
|
||||
|
@ -349,9 +349,28 @@ fe_op_search( Operation *op, SlapReply *rs )
|
||||
goto return_results;
|
||||
}
|
||||
|
||||
/* actually do the search and send the result(s) */
|
||||
if ( op->o_bd->be_search ) {
|
||||
if ( SLAP_SHADOW(op->o_bd) && get_dontUseCopy(op) ) {
|
||||
/* don't use shadow copy */
|
||||
BerVarray defref = op->o_bd->be_update_refs
|
||||
? op->o_bd->be_update_refs : default_referral;
|
||||
|
||||
if( defref != NULL ) {
|
||||
rs->sr_ref = referral_rewrite( defref,
|
||||
NULL, &op->o_req_dn, op->ors_scope );
|
||||
if( !rs->sr_ref) rs->sr_ref = defref;
|
||||
rs->sr_err = LDAP_REFERRAL;
|
||||
send_ldap_result( op, rs );
|
||||
|
||||
if (rs->sr_ref != defref) ber_bvarray_free( rs->sr_ref );
|
||||
|
||||
} else {
|
||||
send_ldap_error( op, rs, LDAP_UNWILLING_TO_PERFORM,
|
||||
"copy not used; no referral information available" );
|
||||
}
|
||||
|
||||
} else if ( op->o_bd->be_search ) {
|
||||
if ( limits_check( op, rs ) == 0 ) {
|
||||
/* actually do the search and send the result(s) */
|
||||
(op->o_bd->be_search)( op, rs );
|
||||
}
|
||||
/* else limits_check() sends error */
|
||||
|
Loading…
Reference in New Issue
Block a user