]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/backover.c
ITS#5972 Added newCookie sync info messages.
[openldap] / servers / slapd / backover.c
index 8194e9869fb0fc7948966b348a2f0683d176332f..1be6cfa3e9000e8034454bd54e9ac0a83a65832b 100644 (file)
@@ -103,6 +103,8 @@ over_db_config(
        ca.be = be;
        snprintf( ca.log, sizeof( ca.log ), "%s: line %d",
                        ca.fname, ca.lineno );
+       ca.op = SLAP_CONFIG_ADD;
+       ca.valx = -1;
 
        for (; on; on=on->on_next) {
                rc = SLAP_CONF_UNKNOWN;
@@ -138,25 +140,22 @@ over_db_open(
 {
        slap_overinfo *oi = be->bd_info->bi_private;
        slap_overinst *on = oi->oi_list;
-       BackendInfo *bi_orig = be->bd_info;
+       BackendDB db = *be;
        int rc = 0;
 
-       be->be_flags |= SLAP_DBFLAG_OVERLAY;
-       be->bd_info = oi->oi_orig;
-       if ( be->bd_info->bi_db_open ) {
-               rc = be->bd_info->bi_db_open( be, cr );
+       db.be_flags |= SLAP_DBFLAG_OVERLAY;
+       db.bd_info = oi->oi_orig;
+       if ( db.bd_info->bi_db_open ) {
+               rc = db.bd_info->bi_db_open( &db, cr );
        }
 
        for (; on && rc == 0; on=on->on_next) {
-               be->bd_info = &on->on_bi;
-               if ( be->bd_info->bi_db_open ) {
-                       rc = be->bd_info->bi_db_open( be, cr );
+               db.bd_info = &on->on_bi;
+               if ( db.bd_info->bi_db_open ) {
+                       rc = db.bd_info->bi_db_open( &db, cr );
                }
        }
 
-       be->bd_info = bi_orig;
-       be->be_flags ^= SLAP_DBFLAG_OVERLAY;
-
        return rc;
 }