mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-06 10:46:21 +08:00
Moved cookie validation into slap_parse_sync_cookie so consumer uses it too
This commit is contained in:
parent
ccdbb52266
commit
73bab2b619
@ -117,31 +117,44 @@ slap_parse_sync_cookie(
|
|||||||
char *csn_ptr;
|
char *csn_ptr;
|
||||||
char *csn_str;
|
char *csn_str;
|
||||||
int csn_str_len;
|
int csn_str_len;
|
||||||
|
int valid = 0;
|
||||||
char *sid_ptr;
|
char *sid_ptr;
|
||||||
char *sid_str;
|
char *sid_str;
|
||||||
char *rid_ptr;
|
char *rid_ptr;
|
||||||
char *rid_str;
|
char *rid_str;
|
||||||
char *cval;
|
char *cval;
|
||||||
struct berval *ctxcsn;
|
struct berval ctxcsn;
|
||||||
|
|
||||||
if ( cookie == NULL )
|
if ( cookie == NULL )
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (( csn_ptr = strstr( cookie->octet_str[0].bv_val, "csn=" )) != NULL ) {
|
while (( csn_ptr = strstr( cookie->octet_str[0].bv_val, "csn=" )) != NULL ) {
|
||||||
csn_str = SLAP_STRNDUP( csn_ptr, LDAP_LUTIL_CSNSTR_BUFSIZE );
|
AttributeDescription *ad = slap_schema.si_ad_modifyTimestamp;
|
||||||
if ( (cval = strchr( csn_str, ',' )) != NULL ) {
|
slap_syntax_validate_func *validate;
|
||||||
*cval = '\0';
|
struct berval stamp;
|
||||||
csn_str_len = cval - csn_str - (sizeof("csn=") - 1);
|
|
||||||
} else {
|
csn_str = csn_ptr + STRLENOF("csn=");
|
||||||
csn_str_len = cookie->octet_str[0].bv_len -
|
cval = strchr( csn_str, ',' );
|
||||||
(csn_ptr - cookie->octet_str[0].bv_val) -
|
if ( cval )
|
||||||
(sizeof("csn=") - 1);
|
csn_str_len = cval - csn_str;
|
||||||
|
else
|
||||||
|
csn_str_len = 0;
|
||||||
|
|
||||||
|
/* FIXME use csnValidate when it gets implemented */
|
||||||
|
csn_ptr = strchr( csn_str, '#' );
|
||||||
|
if ( !csn_ptr ) break;
|
||||||
|
|
||||||
|
stamp.bv_val = csn_str;
|
||||||
|
stamp.bv_len = csn_ptr - csn_str;
|
||||||
|
validate = ad->ad_type->sat_syntax->ssyn_validate;
|
||||||
|
if ( validate( ad->ad_type->sat_syntax, &stamp ) != LDAP_SUCCESS )
|
||||||
|
break;
|
||||||
|
valid = 1;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
ctxcsn = ber_str2bv( csn_str + (sizeof("csn=")-1),
|
if ( valid ) {
|
||||||
csn_str_len, 1, NULL );
|
ber_str2bv( csn_str, csn_str_len, 1, &ctxcsn );
|
||||||
ch_free( csn_str );
|
ber_bvarray_add( &cookie->ctxcsn, &ctxcsn );
|
||||||
ber_bvarray_add( &cookie->ctxcsn, ctxcsn );
|
|
||||||
ch_free( ctxcsn );
|
|
||||||
} else {
|
} else {
|
||||||
cookie->ctxcsn = NULL;
|
cookie->ctxcsn = NULL;
|
||||||
}
|
}
|
||||||
|
@ -1761,33 +1761,9 @@ syncprov_op_search( Operation *op, SlapReply *rs )
|
|||||||
/* If we have a cookie, handle the PRESENT lookups */
|
/* If we have a cookie, handle the PRESENT lookups */
|
||||||
if ( srs->sr_state.ctxcsn ) {
|
if ( srs->sr_state.ctxcsn ) {
|
||||||
sessionlog *sl;
|
sessionlog *sl;
|
||||||
int valid = 0;
|
|
||||||
|
|
||||||
/* Is the CSN in a valid format? */
|
/* The cookie was validated when it was parsed, just use it */
|
||||||
/* FIXME: should use csnValidate when that is implemented */
|
|
||||||
while (!valid) {
|
|
||||||
char *ptr;
|
|
||||||
struct berval timestamp;
|
|
||||||
slap_syntax_validate_func *validate;
|
|
||||||
AttributeDescription *ad = slap_schema.si_ad_modifyTimestamp;
|
|
||||||
|
|
||||||
if ( srs->sr_state.ctxcsn->bv_len >= LDAP_LUTIL_CSNSTR_BUFSIZE )
|
|
||||||
break;
|
|
||||||
ptr = strchr( srs->sr_state.ctxcsn->bv_val, '#' );
|
|
||||||
if ( !ptr )
|
|
||||||
break;
|
|
||||||
timestamp.bv_val = srs->sr_state.ctxcsn->bv_val;
|
|
||||||
timestamp.bv_len = ptr - timestamp.bv_val;
|
|
||||||
validate = ad->ad_type->sat_syntax->ssyn_validate;
|
|
||||||
if ( validate( ad->ad_type->sat_syntax, ×tamp ))
|
|
||||||
break;
|
|
||||||
valid = 1;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
/* Skip any present searches, there's nothing to compare */
|
|
||||||
if ( !valid ) {
|
|
||||||
goto shortcut;
|
|
||||||
}
|
|
||||||
/* If just Refreshing and nothing has changed, shortcut it */
|
/* If just Refreshing and nothing has changed, shortcut it */
|
||||||
if ( bvmatch( srs->sr_state.ctxcsn, &ctxcsn )) {
|
if ( bvmatch( srs->sr_state.ctxcsn, &ctxcsn )) {
|
||||||
nochange = 1;
|
nochange = 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user