Diff for /servers/slapd/overlays/syncprov.c between versions 1.172 and 1.176

version 1.172, 2007/02/05 08:19:46 version 1.176, 2007/02/06 03:19:56
Line 1 Line 1
 /* $OpenLDAP: pkg/ldap/servers/slapd/overlays/syncprov.c,v 1.171 2007/02/05 03:50:07 hyc Exp $ */  /* $OpenLDAP: pkg/ldap/servers/slapd/overlays/syncprov.c,v 1.175 2007/02/06 00:18:17 hyc Exp $ */
 /* syncprov.c - syncrepl provider */  /* syncprov.c - syncrepl provider */
 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.  /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
  *   *
Line 59  typedef struct syncops { Line 59  typedef struct syncops {
         ID              s_eid;          /* entryID of search base */          ID              s_eid;          /* entryID of search base */
         Operation       *s_op;          /* search op */          Operation       *s_op;          /* search op */
         int             s_rid;          int             s_rid;
           int             s_sid;
         struct berval s_filterstr;          struct berval s_filterstr;
         int             s_flags;        /* search status */          int             s_flags;        /* search status */
 #define PS_IS_REFRESHING        0x01  #define PS_IS_REFRESHING        0x01
Line 403  syncprov_findbase( Operation *op, fbase_ Line 404  syncprov_findbase( Operation *op, fbase_
                 slap_callback cb = {0};                  slap_callback cb = {0};
                 Operation fop;                  Operation fop;
                 SlapReply frs = { REP_RESULT };                  SlapReply frs = { REP_RESULT };
                   BackendInfo *bi;
                 int rc;                  int rc;
   
                 fc->fss->s_flags ^= PS_FIND_BASE;                  fc->fss->s_flags ^= PS_FIND_BASE;
Line 414  syncprov_findbase( Operation *op, fbase_ Line 416  syncprov_findbase( Operation *op, fbase_
                 fop.o_bd = op->o_bd;                  fop.o_bd = op->o_bd;
                 fop.o_time = op->o_time;                  fop.o_time = op->o_time;
                 fop.o_tincr = op->o_tincr;                  fop.o_tincr = op->o_tincr;
                   bi = op->o_bd->bd_info;
   
                 cb.sc_response = findbase_cb;                  cb.sc_response = findbase_cb;
                 cb.sc_private = fc;                  cb.sc_private = fc;
Line 431  syncprov_findbase( Operation *op, fbase_ Line 434  syncprov_findbase( Operation *op, fbase_
                 fop.ors_filter = &generic_filter;                  fop.ors_filter = &generic_filter;
                 fop.ors_filterstr = generic_filterstr;                  fop.ors_filterstr = generic_filterstr;
   
                 fop.o_bd->bd_info = on->on_info->oi_orig;                  rc = overlay_op_walk( &fop, &frs, op_search, on->on_info, on );
                 rc = fop.o_bd->be_search( &fop, &frs );                  op->o_bd->bd_info = bi;
                 fop.o_bd->bd_info = (BackendInfo *)on;  
         } else {          } else {
                 ldap_pvt_thread_mutex_unlock( &fc->fss->s_mutex );                  ldap_pvt_thread_mutex_unlock( &fc->fss->s_mutex );
                 fc->fbase = 1;                  fc->fbase = 1;
Line 769  syncprov_sendresp( Operation *op, opcook Line 771  syncprov_sendresp( Operation *op, opcook
         ctrls[1] = NULL;          ctrls[1] = NULL;
         csns[0] = opc->sctxcsn;          csns[0] = opc->sctxcsn;
         BER_BVZERO( &csns[1] );          BER_BVZERO( &csns[1] );
         slap_compose_sync_cookie( op, &cookie, csns, so->s_rid );          slap_compose_sync_cookie( op, &cookie, csns, so->s_rid, so->s_sid );
   
         e_uuid.e_attrs = &a_uuid;          e_uuid.e_attrs = &a_uuid;
         a_uuid.a_desc = slap_schema.si_ad_entryUUID;          a_uuid.a_desc = slap_schema.si_ad_entryUUID;
Line 838  syncprov_qplay( Operation *op, slap_over Line 840  syncprov_qplay( Operation *op, slap_over
         int rc = 0;          int rc = 0;
   
         opc.son = on;          opc.son = on;
         op->o_bd->bd_info = (BackendInfo *)on->on_info;  
   
         for (;;) {          for (;;) {
                 ldap_pvt_thread_mutex_lock( &so->s_mutex );                  ldap_pvt_thread_mutex_lock( &so->s_mutex );
Line 860  syncprov_qplay( Operation *op, slap_over Line 861  syncprov_qplay( Operation *op, slap_over
                 e = NULL;                  e = NULL;
   
                 if ( sr->s_mode != LDAP_SYNC_DELETE ) {                  if ( sr->s_mode != LDAP_SYNC_DELETE ) {
                         rc = be_entry_get_rw( op, &opc.sndn, NULL, NULL, 0, &e );                          rc = overlay_entry_get_ov( op, &opc.sndn, NULL, NULL, 0, &e, on );
                         if ( rc ) {                          if ( rc ) {
                                 Debug( LDAP_DEBUG_SYNC, "syncprov_qplay: failed to get %s, "                                  Debug( LDAP_DEBUG_SYNC, "syncprov_qplay: failed to get %s, "
                                         "error (%d), ignoring...\n", opc.sndn.bv_val, rc, 0 );                                          "error (%d), ignoring...\n", opc.sndn.bv_val, rc, 0 );
Line 872  syncprov_qplay( Operation *op, slap_over Line 873  syncprov_qplay( Operation *op, slap_over
                 rc = syncprov_sendresp( op, &opc, so, &e, sr->s_mode );                  rc = syncprov_sendresp( op, &opc, so, &e, sr->s_mode );
   
                 if ( e ) {                  if ( e ) {
                         be_entry_release_rw( op, e, 0 );                          overlay_entry_release_ov( op, e, 0, on );
                 }                  }
   
                 ch_free( sr );                  ch_free( sr );
Line 880  syncprov_qplay( Operation *op, slap_over Line 881  syncprov_qplay( Operation *op, slap_over
                 if ( rc )                  if ( rc )
                         break;                          break;
         }          }
         op->o_bd->bd_info = (BackendInfo *)on;  
         return rc;          return rc;
 }  }
   
Line 977  static int Line 977  static int
 syncprov_qresp( opcookie *opc, syncops *so, int mode )  syncprov_qresp( opcookie *opc, syncops *so, int mode )
 {  {
         syncres *sr;          syncres *sr;
           int sid;
   
           /* Don't send changes back to their originator */
           sid = slap_parse_csn_sid( &opc->sctxcsn );
           if ( sid == so->s_sid )
                   return LDAP_SUCCESS;
   
         sr = ch_malloc(sizeof(syncres) + opc->suuid.bv_len + 1 +          sr = ch_malloc(sizeof(syncres) + opc->suuid.bv_len + 1 +
                 opc->sdn.bv_len + 1 + opc->sndn.bv_len + 1 + opc->sctxcsn.bv_len + 1 );                  opc->sdn.bv_len + 1 + opc->sndn.bv_len + 1 + opc->sctxcsn.bv_len + 1 );
Line 1091  syncprov_matchops( Operation *op, opcook Line 1097  syncprov_matchops( Operation *op, opcook
   
         fbase_cookie fc;          fbase_cookie fc;
         syncops *ss, *sprev, *snext;          syncops *ss, *sprev, *snext;
         Entry *e;          Entry *e = NULL;
         Attribute *a;          Attribute *a;
         int rc;          int rc;
         struct berval newdn;          struct berval newdn;
Line 1113  syncprov_matchops( Operation *op, opcook Line 1119  syncprov_matchops( Operation *op, opcook
                         db = *op->o_bd;                          db = *op->o_bd;
                         op->o_bd = &db;                          op->o_bd = &db;
                 }                  }
                 op->o_bd->bd_info = (BackendInfo *)on->on_info;                  rc = overlay_entry_get_ov( op, fc.fdn, NULL, NULL, 0, &e, on );
                 rc = be_entry_get_rw( op, fc.fdn, NULL, NULL, 0, &e );  
                 /* If we're sending responses now, make a copy and unlock the DB */                  /* If we're sending responses now, make a copy and unlock the DB */
                 if ( e && !saveit ) {                  if ( e && !saveit ) {
                         Entry *e2 = entry_dup( e );                          Entry *e2 = entry_dup( e );
                         be_entry_release_rw( op, e, 0 );                          overlay_entry_release_ov( op, e, 0, on );
                         e = e2;                          e = e2;
                 }                  }
                 op->o_bd->bd_info = (BackendInfo *)on;  
                 if ( rc ) {                  if ( rc ) {
                         op->o_bd = b0;                          op->o_bd = b0;
                         return;                          return;
Line 1523  syncprov_playlog( Operation *op, SlapRep Line 1527  syncprov_playlog( Operation *op, SlapRep
         if ( ndel ) {          if ( ndel ) {
                 struct berval cookie;                  struct berval cookie;
   
                 slap_compose_sync_cookie( op, &cookie, delcsn, srs->sr_state.rid );                  slap_compose_sync_cookie( op, &cookie, delcsn, srs->sr_state.rid,
                           srs->sr_state.sid );
                 uuids[ndel].bv_val = NULL;                  uuids[ndel].bv_val = NULL;
                 syncprov_sendinfo( op, rs, LDAP_TAG_SYNC_ID_SET, &cookie, 0, uuids, 1 );                  syncprov_sendinfo( op, rs, LDAP_TAG_SYNC_ID_SET, &cookie, 0, uuids, 1 );
                 op->o_tmpfree( cookie.bv_val, op->o_tmpmemctx );                  op->o_tmpfree( cookie.bv_val, op->o_tmpmemctx );
Line 1919  syncprov_search_response( Operation *op, Line 1924  syncprov_search_response( Operation *op,
                         int i, sid;                          int i, sid;
                         sid = slap_parse_csn_sid( &a->a_nvals[0] );                          sid = slap_parse_csn_sid( &a->a_nvals[0] );
   
                           /* Don't send changed entries back to the originator */
                           if ( sid == srs->sr_state.sid && srs->sr_state.numcsns ) {
                                   Debug( LDAP_DEBUG_SYNC,
                                           "Entry %s changed by peer, ignored\n",
                                           rs->sr_entry->e_name.bv_val, 0, 0 );
                                   return LDAP_SUCCESS;
                           }
                         /* Make sure entry is less than the snapshot'd contextCSN */                          /* Make sure entry is less than the snapshot'd contextCSN */
                         for ( i=0; i<ss->ss_numcsns; i++ ) {                          for ( i=0; i<ss->ss_numcsns; i++ ) {
                                 if ( sid == ss->ss_sids[i] && ber_bvcmp( &a->a_nvals[0],                                  if ( sid == ss->ss_sids[i] && ber_bvcmp( &a->a_nvals[0],
Line 1957  syncprov_search_response( Operation *op, Line 1969  syncprov_search_response( Operation *op,
                 struct berval cookie;                  struct berval cookie;
   
                 slap_compose_sync_cookie( op, &cookie, ss->ss_ctxcsn,                  slap_compose_sync_cookie( op, &cookie, ss->ss_ctxcsn,
                         srs->sr_state.rid );                          srs->sr_state.rid, srs->sr_state.sid );
   
                 /* Is this a regular refresh? */                  /* Is this a regular refresh? */
                 if ( !ss->ss_so ) {                  if ( !ss->ss_so ) {
Line 2051  syncprov_op_search( Operation *op, SlapR Line 2063  syncprov_op_search( Operation *op, SlapR
                 *sop = so;                  *sop = so;
                 ldap_pvt_thread_mutex_init( &sop->s_mutex );                  ldap_pvt_thread_mutex_init( &sop->s_mutex );
                 sop->s_rid = srs->sr_state.rid;                  sop->s_rid = srs->sr_state.rid;
                   sop->s_sid = srs->sr_state.sid;
                 sop->s_inuse = 1;                  sop->s_inuse = 1;
   
                 ldap_pvt_thread_mutex_lock( &si->si_ops_mutex );                  ldap_pvt_thread_mutex_lock( &si->si_ops_mutex );
Line 2488  syncprov_db_open( Line 2501  syncprov_db_open(
         Connection conn = { 0 };          Connection conn = { 0 };
         OperationBuffer opbuf = { 0 };          OperationBuffer opbuf = { 0 };
         Operation *op = (Operation *) &opbuf;          Operation *op = (Operation *) &opbuf;
         Entry *e;          Entry *e = NULL;
         Attribute *a;          Attribute *a;
         int rc;          int rc;
         void *thrctx = NULL;          void *thrctx = NULL;
Line 2514  syncprov_db_open( Line 2527  syncprov_db_open(
         op->o_dn = be->be_rootdn;          op->o_dn = be->be_rootdn;
         op->o_ndn = be->be_rootndn;          op->o_ndn = be->be_rootndn;
   
         op->o_bd->bd_info = on->on_info->oi_orig;          rc = overlay_entry_get_ov( op, be->be_nsuffix, NULL,
         rc = be_entry_get_rw( op, be->be_nsuffix, NULL,                  slap_schema.si_ad_contextCSN, 0, &e, on );
                 slap_schema.si_ad_contextCSN, 0, &e );  
   
         if ( e ) {          if ( e ) {
                 ldap_pvt_thread_t tid;                  ldap_pvt_thread_t tid;
Line 2529  syncprov_db_open( Line 2541  syncprov_db_open(
                         si->si_numcsns = i;                          si->si_numcsns = i;
                         si->si_sids = slap_parse_csn_sids( si->si_ctxcsn, i );                          si->si_sids = slap_parse_csn_sids( si->si_ctxcsn, i );
                 }                  }
                 be_entry_release_rw( op, e, 0 );                  overlay_entry_release_ov( op, e, 0, on );
                 if ( si->si_ctxcsn ) {                  if ( si->si_ctxcsn ) {
                         op->o_bd->bd_info = (BackendInfo *)on;  
                         op->o_req_dn = be->be_suffix[0];                          op->o_req_dn = be->be_suffix[0];
                         op->o_req_ndn = be->be_nsuffix[0];                          op->o_req_ndn = be->be_nsuffix[0];
                         op->ors_scope = LDAP_SCOPE_SUBTREE;                          op->ors_scope = LDAP_SCOPE_SUBTREE;

Removed from v.1.172  
changed lines
  Added in v.1.176


______________
© Copyright 1998-2020, OpenLDAP Foundation, info@OpenLDAP.org