mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-12 10:54:48 +08:00
More syncprov fixes. test019 now passes.
This commit is contained in:
parent
3426a11983
commit
c2b339d456
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -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 * ));
|
||||||
|
@ -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 );
|
||||||
|
Loading…
Reference in New Issue
Block a user