]> git.sur5r.net Git - openldap/commitdiff
ITS#6109
authorQuanah Gibson-Mount <quanah@openldap.org>
Mon, 18 May 2009 19:51:55 +0000 (19:51 +0000)
committerQuanah Gibson-Mount <quanah@openldap.org>
Mon, 18 May 2009 19:51:55 +0000 (19:51 +0000)
CHANGES
servers/slapd/backend.c
servers/slapd/bconfig.c

diff --git a/CHANGES b/CHANGES
index a9819d7f9aad315c1c22837276d586229b83b3f7..4bf93961a97b72968f0d34ce9aa0746080ad94ad 100644 (file)
--- a/CHANGES
+++ b/CHANGES
@@ -13,6 +13,7 @@ OpenLDAP 2.4.17 Engineering
        Fixed slapd moduleload with static backends and modules (ITS#6016)
        Fixed slapd normalization of updated schema attributes (ITS#5540)
        Fixed slapd pagedresults stacked control with overlays (ITS#6056)
+       Fixed slapd readonly restrictions (ITS#6109)
        Fixed slapd sending cancelled operations results (ITS#6103)
        Fixed slapd sockets usage on windows (ITS#6039)
        Fixed slapd-hdb freeing of already freed entries (ITS#6074)
index 7e0dbce7d99f9a6648ecc5c486afdb40fd6ea947..ac9dda235f1bd2361d0c8d3c4e9a5dcf86e5ded1 100644 (file)
@@ -1296,7 +1296,8 @@ backend_check_restrictions(
        }
 
        if( ( restrictops & opflag )
-                       || ( exopflag && ( restrictops & exopflag ) ) ) {
+                       || ( exopflag && ( restrictops & exopflag ) )
+                       || (( restrictops & SLAP_RESTRICT_READONLY ) && updateop )) {
                if( ( restrictops & SLAP_RESTRICT_OP_MASK) == SLAP_RESTRICT_OP_READS ) {
                        rs->sr_text = "read operations restricted";
                } else if ( restrictops & exopflag ) {
index cd7f43ab89b8d2b0ea07d2d18f403f8be7bfb41c..569046000d1796c7edb71b3c1d9e6b2cb7f8cd94 100644 (file)
@@ -893,8 +893,7 @@ config_generic(ConfigArgs *c) {
                        if ( !c->rvalue_vals ) rc = 1;
                        break;
                case CFG_RO:
-                       c->value_int = (c->be->be_restrictops & SLAP_RESTRICT_OP_WRITES) ==
-                               SLAP_RESTRICT_OP_WRITES;
+                       c->value_int = (c->be->be_restrictops & SLAP_RESTRICT_READONLY);
                        break;
                case CFG_AZPOLICY:
                        c->value_string = ch_strdup( slap_sasl_getpolicy());
@@ -1466,9 +1465,9 @@ config_generic(ConfigArgs *c) {
 
                case CFG_RO:
                        if(c->value_int)
-                               c->be->be_restrictops |= SLAP_RESTRICT_OP_WRITES;
+                               c->be->be_restrictops |= SLAP_RESTRICT_READONLY;
                        else
-                               c->be->be_restrictops &= ~SLAP_RESTRICT_OP_WRITES;
+                               c->be->be_restrictops &= ~SLAP_RESTRICT_READONLY;
                        break;
 
                case CFG_AZPOLICY: