From: Kurt Zeilenga Date: Wed, 21 Dec 2005 04:29:42 +0000 (+0000) Subject: additional ITS#4255 changes from HEAD X-Git-Tag: OPENLDAP_REL_ENG_2_3_14~27 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=0067004d8d866ee2710943f273e7383519414702;p=openldap additional ITS#4255 changes from HEAD --- diff --git a/servers/slapd/aclparse.c b/servers/slapd/aclparse.c index 5a666a4650..fc1b6676b4 100644 --- a/servers/slapd/aclparse.c +++ b/servers/slapd/aclparse.c @@ -475,7 +475,8 @@ parse_acl( } } else if ( strncasecmp( left, "val", 3 ) == 0 ) { - char *mr; + struct berval bv; + char *mr; if ( !BER_BVISEMPTY( &a->acl_attrval ) ) { Debug( LDAP_DEBUG_ANY, @@ -491,7 +492,7 @@ parse_acl( return acl_usage(); } - ber_str2bv( right, 0, 1, &a->acl_attrval ); + ber_str2bv( right, 0, 0, &bv ); a->acl_attrval_style = ACL_STYLE_BASE; mr = strchr( left, '/' ); @@ -525,7 +526,7 @@ parse_acl( if ( style != NULL ) { if ( strcasecmp( style, "regex" ) == 0 ) { - int e = regcomp( &a->acl_attrval_re, a->acl_attrval.bv_val, + int e = regcomp( &a->acl_attrval_re, bv.bv_val, REG_EXTENDED | REG_ICASE | REG_NOSUB ); if ( e ) { char err[SLAP_TEXT_BUFLEN], @@ -553,8 +554,6 @@ parse_acl( } else if ( a->acl_attrs[0].an_desc->ad_type-> sat_syntax == slap_schema.si_syn_distinguishedName ) { - struct berval bv; - if ( !strcasecmp( style, "baseObject" ) || !strcasecmp( style, "base" ) ) { @@ -576,8 +575,10 @@ parse_acl( snprintf( buf, sizeof( buf ), "unknown val.