More syncprov fixes. test019 now passes.

This commit is contained in:
Howard Chu 2004-11-26 09:40:22 +00:00
parent 3426a11983
commit c2b339d456
4 changed files with 47 additions and 30 deletions

View File

@ -140,6 +140,26 @@ slap_create_context_csn_entry(
return e; return e;
} }
void
slap_queue_csn(
Operation *op,
struct berval *csn )
{
struct slap_csn_entry *pending;
pending = (struct slap_csn_entry *) ch_calloc( 1,
sizeof( struct slap_csn_entry ));
ldap_pvt_thread_mutex_lock( op->o_bd->be_pcl_mutexp );
pending->ce_csn = ber_dupbv( NULL, csn );
pending->ce_connid = op->o_connid;
pending->ce_opid = op->o_opid;
pending->ce_state = SLAP_CSN_PENDING;
LDAP_TAILQ_INSERT_TAIL( op->o_bd->be_pending_csn_list,
pending, ce_csn_link );
ldap_pvt_thread_mutex_unlock( op->o_bd->be_pcl_mutexp );
}
int int
slap_get_csn( slap_get_csn(
Operation *op, Operation *op,
@ -148,29 +168,13 @@ slap_get_csn(
struct berval *csn, struct berval *csn,
int manage_ctxcsn ) int manage_ctxcsn )
{ {
struct slap_csn_entry *pending;
if ( csn == NULL ) return LDAP_OTHER; if ( csn == NULL ) return LDAP_OTHER;
csn->bv_len = lutil_csnstr( csnbuf, len, 0, 0 ); csn->bv_len = lutil_csnstr( csnbuf, len, 0, 0 );
csn->bv_val = csnbuf; csn->bv_val = csnbuf;
if ( manage_ctxcsn ) { if ( manage_ctxcsn )
pending = (struct slap_csn_entry *) ch_calloc( 1, slap_queue_csn( op, csn );
sizeof( struct slap_csn_entry ));
ldap_pvt_thread_mutex_lock( op->o_bd->be_pcl_mutexp );
#if 0
if ( op->o_sync_csn.bv_val ) free( op->o_sync_csn.bv_val );
ber_dupbv( &op->o_sync_csn, csn );
#endif
pending->ce_csn = ber_dupbv( NULL, csn );
pending->ce_connid = op->o_connid;
pending->ce_opid = op->o_opid;
pending->ce_state = SLAP_CSN_PENDING;
LDAP_TAILQ_INSERT_TAIL( op->o_bd->be_pending_csn_list,
pending, ce_csn_link );
ldap_pvt_thread_mutex_unlock( op->o_bd->be_pcl_mutexp );
}
return LDAP_SUCCESS; return LDAP_SUCCESS;
} }

View File

@ -51,6 +51,7 @@ typedef struct syncprov_info_t {
int si_gotcsn; /* is our ctxcsn up to date? */ int si_gotcsn; /* is our ctxcsn up to date? */
ldap_pvt_thread_mutex_t si_csn_mutex; ldap_pvt_thread_mutex_t si_csn_mutex;
ldap_pvt_thread_mutex_t si_ops_mutex; ldap_pvt_thread_mutex_t si_ops_mutex;
char si_ctxcsnbuf[LDAP_LUTIL_CSNSTR_BUFSIZE];
} syncprov_info_t; } syncprov_info_t;
typedef struct opcookie { typedef struct opcookie {
@ -568,17 +569,16 @@ syncprov_op_response( Operation *op, SlapReply *rs )
{ {
struct berval maxcsn; struct berval maxcsn;
char cbuf[LDAP_LUTIL_CSNSTR_BUFSIZE]; char cbuf[LDAP_LUTIL_CSNSTR_BUFSIZE];
void *memctx = op->o_tmpmemctx;
cbuf[0] = '\0'; cbuf[0] = '\0';
ldap_pvt_thread_mutex_lock( &si->si_csn_mutex ); ldap_pvt_thread_mutex_lock( &si->si_csn_mutex );
op->o_tmpmemctx = NULL;
slap_get_commit_csn( op, &maxcsn ); slap_get_commit_csn( op, &maxcsn );
op->o_tmpmemctx = memctx;
if ( maxcsn.bv_val ) { if ( maxcsn.bv_val ) {
strcpy( cbuf, maxcsn.bv_val ); strcpy( cbuf, maxcsn.bv_val );
free( si->si_ctxcsn.bv_val ); if ( ber_bvcmp( &maxcsn, &si->si_ctxcsn ) > 0 ) {
si->si_ctxcsn = maxcsn; strcpy( si->si_ctxcsnbuf, cbuf );
si->si_ctxcsn.bv_len = maxcsn.bv_len;
}
si->si_gotcsn = 1; si->si_gotcsn = 1;
} }
ldap_pvt_thread_mutex_unlock( &si->si_csn_mutex ); ldap_pvt_thread_mutex_unlock( &si->si_csn_mutex );
@ -731,18 +731,24 @@ syncprov_search_response( Operation *op, SlapReply *rs )
if ( rs->sr_type == REP_SEARCH || rs->sr_type == REP_SEARCHREF ) { if ( rs->sr_type == REP_SEARCH || rs->sr_type == REP_SEARCHREF ) {
int i; int i;
if ( srs->sr_state.ctxcsn ) { struct berval cookie;
Attribute *a = attr_find( rs->sr_entry->e_attrs, Attribute *a = attr_find( rs->sr_entry->e_attrs,
slap_schema.si_ad_entryCSN ); slap_schema.si_ad_entryCSN );
if ( srs->sr_state.ctxcsn ) {
/* Don't send the ctx entry twice */ /* Don't send the ctx entry twice */
if ( bvmatch( &a->a_nvals[0], srs->sr_state.ctxcsn )) if ( bvmatch( &a->a_nvals[0], srs->sr_state.ctxcsn ))
return LDAP_SUCCESS; return LDAP_SUCCESS;
} }
slap_compose_sync_cookie( op, &cookie, a->a_nvals,
srs->sr_state.sid, srs->sr_state.rid );
rs->sr_ctrls = op->o_tmpalloc( sizeof(LDAPControl *)*2, rs->sr_ctrls = op->o_tmpalloc( sizeof(LDAPControl *)*2,
op->o_tmpmemctx ); op->o_tmpmemctx );
rs->sr_ctrls[1] = NULL; rs->sr_ctrls[1] = NULL;
rs->sr_err = slap_build_sync_state_ctrl( op, rs, rs->sr_entry, rs->sr_err = slap_build_sync_state_ctrl( op, rs, rs->sr_entry,
LDAP_SYNC_ADD, rs->sr_ctrls, 0, 0, NULL ); LDAP_SYNC_ADD, rs->sr_ctrls, 0, 1, &cookie );
} else if ( rs->sr_type == REP_RESULT && rs->sr_err == LDAP_SUCCESS ) { } else if ( rs->sr_type == REP_RESULT && rs->sr_err == LDAP_SUCCESS ) {
struct berval cookie; struct berval cookie;
@ -862,6 +868,7 @@ syncprov_op_search( Operation *op, SlapReply *rs )
ctrls[1] = NULL; ctrls[1] = NULL;
slap_build_sync_done_ctrl( op, rs, ctrls, 0, 0, slap_build_sync_done_ctrl( op, rs, ctrls, 0, 0,
NULL, LDAP_SYNC_REFRESH_DELETES ); NULL, LDAP_SYNC_REFRESH_DELETES );
rs->sr_ctrls = ctrls;
rs->sr_err = LDAP_SUCCESS; rs->sr_err = LDAP_SUCCESS;
send_ldap_result( op, rs ); send_ldap_result( op, rs );
return rs->sr_err; return rs->sr_err;
@ -990,6 +997,7 @@ syncprov_db_init(
on->on_bi.bi_private = si; on->on_bi.bi_private = si;
ldap_pvt_thread_mutex_init( &si->si_csn_mutex ); ldap_pvt_thread_mutex_init( &si->si_csn_mutex );
ldap_pvt_thread_mutex_init( &si->si_ops_mutex ); ldap_pvt_thread_mutex_init( &si->si_ops_mutex );
si->si_ctxcsn.bv_val = si->si_ctxcsnbuf;
csn_anlist[0].an_desc = slap_schema.si_ad_entryCSN; csn_anlist[0].an_desc = slap_schema.si_ad_entryCSN;
csn_anlist[0].an_name = slap_schema.si_ad_entryCSN->ad_cname; csn_anlist[0].an_name = slap_schema.si_ad_entryCSN->ad_cname;

View File

@ -486,6 +486,7 @@ LDAP_SLAPD_F (void) slap_rewind_commit_csn LDAP_P(( Operation * ));
LDAP_SLAPD_F (void) slap_graduate_commit_csn LDAP_P(( Operation * )); LDAP_SLAPD_F (void) slap_graduate_commit_csn LDAP_P(( Operation * ));
LDAP_SLAPD_F (Entry *) slap_create_context_csn_entry LDAP_P(( Backend *, struct berval *)); LDAP_SLAPD_F (Entry *) slap_create_context_csn_entry LDAP_P(( Backend *, struct berval *));
LDAP_SLAPD_F (int) slap_get_csn LDAP_P(( Operation *, char *, int, struct berval *, int )); LDAP_SLAPD_F (int) slap_get_csn LDAP_P(( Operation *, char *, int, struct berval *, int ));
LDAP_SLAPD_F (void) slap_queue_csn LDAP_P(( Operation *, struct berval * ));
/* /*
* daemon.c * daemon.c
@ -1265,7 +1266,8 @@ LDAP_SLAPD_F (int) syncrepl_message_to_entry LDAP_P((
LDAP_SLAPD_F (int) syncrepl_entry LDAP_P(( LDAP_SLAPD_F (int) syncrepl_entry LDAP_P((
syncinfo_t *, Operation*, Entry*, syncinfo_t *, Operation*, Entry*,
Modifications*,int, struct berval*, Modifications*,int, struct berval*,
struct sync_cookie * )); struct sync_cookie *,
struct berval * ));
LDAP_SLAPD_F (void) syncrepl_updateCookie LDAP_P(( LDAP_SLAPD_F (void) syncrepl_updateCookie LDAP_P((
syncinfo_t *, Operation *, struct berval *, syncinfo_t *, Operation *, struct berval *,
struct sync_cookie * )); struct sync_cookie * ));

View File

@ -613,7 +613,7 @@ do_syncrep2(
if ( syncrepl_message_to_entry( si, op, msg, if ( syncrepl_message_to_entry( si, op, msg,
&modlist, &entry, syncstate ) == LDAP_SUCCESS ) { &modlist, &entry, syncstate ) == LDAP_SUCCESS ) {
rc_efree = syncrepl_entry( si, op, entry, modlist, rc_efree = syncrepl_entry( si, op, entry, modlist,
syncstate, &syncUUID, &syncCookie_req ); syncstate, &syncUUID, &syncCookie_req, syncCookie.ctxcsn );
if ( syncCookie.octet_str && if ( syncCookie.octet_str &&
!BER_BVISNULL( &syncCookie.octet_str[0] ) ) !BER_BVISNULL( &syncCookie.octet_str[0] ) )
{ {
@ -1162,7 +1162,8 @@ syncrepl_entry(
Modifications* modlist, Modifications* modlist,
int syncstate, int syncstate,
struct berval* syncUUID, struct berval* syncUUID,
struct sync_cookie* syncCookie_req ) struct sync_cookie* syncCookie_req,
struct berval* syncCSN )
{ {
Backend *be = op->o_bd; Backend *be = op->o_bd;
slap_callback cb = { NULL }; slap_callback cb = { NULL };
@ -1447,7 +1448,6 @@ syncrepl_entry(
} }
done : done :
if ( !BER_BVISNULL( &syncUUID_strrep ) ) { if ( !BER_BVISNULL( &syncUUID_strrep ) ) {
slap_sl_free( syncUUID_strrep.bv_val, op->o_tmpmemctx ); slap_sl_free( syncUUID_strrep.bv_val, op->o_tmpmemctx );
BER_BVZERO( &syncUUID_strrep ); BER_BVZERO( &syncUUID_strrep );
@ -1885,6 +1885,8 @@ syncrepl_updateCookie(
op->o_req_dn = e->e_name; op->o_req_dn = e->e_name;
op->o_req_ndn = e->e_nname; op->o_req_ndn = e->e_nname;
slap_queue_csn( op, syncCookie->ctxcsn );
/* update persistent cookie */ /* update persistent cookie */
update_cookie_retry: update_cookie_retry:
op->o_tag = LDAP_REQ_MODIFY; op->o_tag = LDAP_REQ_MODIFY;
@ -1919,6 +1921,7 @@ update_cookie_retry:
"be_modify failed (%d)\n", rs_modify.sr_err, 0, 0 ); "be_modify failed (%d)\n", rs_modify.sr_err, 0, 0 );
} }
} }
slap_graduate_commit_csn( op );
if ( e != NULL ) { if ( e != NULL ) {
entry_free( e ); entry_free( e );