mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-06 10:46:21 +08:00
Rearrange shortcut check for context with no changes
This commit is contained in:
parent
c14cf9c7c8
commit
4ae3efbdd7
@ -1510,17 +1510,6 @@ syncprov_op_search( Operation *op, SlapReply *rs )
|
||||
send_ldap_error( op, rs, LDAP_OTHER, "invalid sync cookie" );
|
||||
return rs->sr_err;
|
||||
}
|
||||
/* Is the CSN still present in the database? */
|
||||
if ( syncprov_findcsn( op, FIND_CSN ) != LDAP_SUCCESS ) {
|
||||
/* No, so a reload is required */
|
||||
#if 0 /* the consumer doesn't seem to send this hint */
|
||||
if ( op->o_sync_rhint == 0 ) {
|
||||
send_ldap_error( op, rs, LDAP_SYNC_REFRESH_REQUIRED, "sync cookie is stale" );
|
||||
return rs->sr_err;
|
||||
}
|
||||
#endif
|
||||
} else {
|
||||
gotstate = 1;
|
||||
/* If just Refreshing and nothing has changed, shortcut it */
|
||||
if ( bvmatch( srs->sr_state.ctxcsn, &si->si_ctxcsn )) {
|
||||
nochange = 1;
|
||||
@ -1538,7 +1527,18 @@ syncprov_op_search( Operation *op, SlapReply *rs )
|
||||
return rs->sr_err;
|
||||
}
|
||||
goto shortcut;
|
||||
} else
|
||||
}
|
||||
/* Is the CSN still present in the database? */
|
||||
if ( syncprov_findcsn( op, FIND_CSN ) != LDAP_SUCCESS ) {
|
||||
/* No, so a reload is required */
|
||||
#if 0 /* the consumer doesn't seem to send this hint */
|
||||
if ( op->o_sync_rhint == 0 ) {
|
||||
send_ldap_error( op, rs, LDAP_SYNC_REFRESH_REQUIRED, "sync cookie is stale" );
|
||||
return rs->sr_err;
|
||||
}
|
||||
#endif
|
||||
} else {
|
||||
gotstate = 1;
|
||||
/* If context has changed, check for Present UUIDs */
|
||||
if ( syncprov_findcsn( op, FIND_PRESENT ) != LDAP_SUCCESS ) {
|
||||
send_ldap_result( op, rs );
|
||||
|
Loading…
Reference in New Issue
Block a user