version 1.115.2.6, 2004/03/17 20:59:57
|
version 1.115.2.7, 2004/05/21 02:11:38
|
Line 1
|
Line 1
|
/* filter.c - routines for parsing and dealing with filters */ |
/* filter.c - routines for parsing and dealing with filters */ |
/* $OpenLDAP: pkg/ldap/servers/slapd/filter.c,v 1.115.2.5 2004/02/23 22:08:05 kurt Exp $ */ |
/* $OpenLDAP: pkg/ldap/servers/slapd/filter.c,v 1.115.2.6 2004/03/17 20:59:57 kurt Exp $ */ |
/* This work is part of OpenLDAP Software <http://www.openldap.org/>. |
/* This work is part of OpenLDAP Software <http://www.openldap.org/>. |
* |
* |
* Copyright 1998-2004 The OpenLDAP Foundation. |
* Copyright 1998-2004 The OpenLDAP Foundation. |
Line 776 filter2bv_x( Operation *op, Filter *f, s
|
Line 776 filter2bv_x( Operation *op, Filter *f, s
|
filter_escape_value_x( &f->f_sub_initial, &tmp, op->o_tmpmemctx ); |
filter_escape_value_x( &f->f_sub_initial, &tmp, op->o_tmpmemctx ); |
|
|
fstr->bv_len += tmp.bv_len; |
fstr->bv_len += tmp.bv_len; |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, op->o_tmpmemctx ); |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, |
|
op->o_tmpmemctx ); |
|
|
snprintf( &fstr->bv_val[len-2], tmp.bv_len+3, |
snprintf( &fstr->bv_val[len-2], tmp.bv_len+3, |
/* "(attr=" */ "%s*)", |
/* "(attr=" */ "%s*)", |
Line 788 filter2bv_x( Operation *op, Filter *f, s
|
Line 789 filter2bv_x( Operation *op, Filter *f, s
|
if ( f->f_sub_any != NULL ) { |
if ( f->f_sub_any != NULL ) { |
for ( i = 0; f->f_sub_any[i].bv_val != NULL; i++ ) { |
for ( i = 0; f->f_sub_any[i].bv_val != NULL; i++ ) { |
len = fstr->bv_len; |
len = fstr->bv_len; |
filter_escape_value_x( &f->f_sub_any[i], &tmp, op->o_tmpmemctx ); |
filter_escape_value_x( &f->f_sub_any[i], |
|
&tmp, op->o_tmpmemctx ); |
|
|
fstr->bv_len += tmp.bv_len + 1; |
fstr->bv_len += tmp.bv_len + 1; |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, op->o_tmpmemctx ); |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, |
|
op->o_tmpmemctx ); |
|
|
snprintf( &fstr->bv_val[len-1], tmp.bv_len+3, |
snprintf( &fstr->bv_val[len-1], tmp.bv_len+3, |
/* "(attr=[init]*[any*]" */ "%s*)", |
/* "(attr=[init]*[any*]" */ "%s*)", |
Line 806 filter2bv_x( Operation *op, Filter *f, s
|
Line 809 filter2bv_x( Operation *op, Filter *f, s
|
filter_escape_value_x( &f->f_sub_final, &tmp, op->o_tmpmemctx ); |
filter_escape_value_x( &f->f_sub_final, &tmp, op->o_tmpmemctx ); |
|
|
fstr->bv_len += tmp.bv_len; |
fstr->bv_len += tmp.bv_len; |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, op->o_tmpmemctx ); |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, |
|
op->o_tmpmemctx ); |
|
|
snprintf( &fstr->bv_val[len-1], tmp.bv_len+3, |
snprintf( &fstr->bv_val[len-1], tmp.bv_len+3, |
/* "(attr=[init*][any*]" */ "%s)", |
/* "(attr=[init*][any*]" */ "%s)", |
Line 842 filter2bv_x( Operation *op, Filter *f, s
|
Line 846 filter2bv_x( Operation *op, Filter *f, s
|
filter2bv_x( op, p, &tmp ); |
filter2bv_x( op, p, &tmp ); |
|
|
fstr->bv_len += tmp.bv_len; |
fstr->bv_len += tmp.bv_len; |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, op->o_tmpmemctx ); |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, |
|
op->o_tmpmemctx ); |
|
|
snprintf( &fstr->bv_val[len-1], tmp.bv_len + 2, |
snprintf( &fstr->bv_val[len-1], tmp.bv_len + 2, |
/*"("*/ "%s)", tmp.bv_val ); |
/*"("*/ "%s)", tmp.bv_val ); |
Line 853 filter2bv_x( Operation *op, Filter *f, s
|
Line 858 filter2bv_x( Operation *op, Filter *f, s
|
break; |
break; |
|
|
case LDAP_FILTER_EXT: { |
case LDAP_FILTER_EXT: { |
struct berval ad; |
struct berval ad; |
filter_escape_value_x( &f->f_mr_value, &tmp, op->o_tmpmemctx ); |
filter_escape_value_x( &f->f_mr_value, &tmp, op->o_tmpmemctx ); |
|
|
if ( f->f_mr_desc ) { |
if ( f->f_mr_desc ) { |
ad = f->f_mr_desc->ad_cname; |
ad = f->f_mr_desc->ad_cname; |
} else { |
} else { |
ad.bv_len = 0; |
ad.bv_len = 0; |
ad.bv_val = ""; |
ad.bv_val = ""; |
} |
} |
|
|
fstr->bv_len = ad.bv_len + |
fstr->bv_len = ad.bv_len + |
( f->f_mr_dnattrs ? sizeof(":dn")-1 : 0 ) + |
( f->f_mr_dnattrs ? sizeof(":dn")-1 : 0 ) + |
( f->f_mr_rule_text.bv_len ? f->f_mr_rule_text.bv_len+1 : 0 ) + |
( f->f_mr_rule_text.bv_len ? f->f_mr_rule_text.bv_len+1 : 0 ) + |
tmp.bv_len + ( sizeof("(:=)") - 1 ); |
tmp.bv_len + ( sizeof("(:=)") - 1 ); |
fstr->bv_val = op->o_tmpalloc( fstr->bv_len + 1, op->o_tmpmemctx ); |
fstr->bv_val = op->o_tmpalloc( fstr->bv_len + 1, op->o_tmpmemctx ); |
|
|
snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s%s%s%s:=%s)", |
snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s%s%s%s:=%s)", |
ad.bv_val, |
ad.bv_val, |
f->f_mr_dnattrs ? ":dn" : "", |
f->f_mr_dnattrs ? ":dn" : "", |
f->f_mr_rule_text.bv_len ? ":" : "", |
f->f_mr_rule_text.bv_len ? ":" : "", |
f->f_mr_rule_text.bv_len ? f->f_mr_rule_text.bv_val : "", |
f->f_mr_rule_text.bv_len ? f->f_mr_rule_text.bv_val : "", |
tmp.bv_val ); |
tmp.bv_val ); |
ber_memfree_x( tmp.bv_val, op->o_tmpmemctx ); |
ber_memfree_x( tmp.bv_val, op->o_tmpmemctx ); |
} break; |
} break; |
|
|
case SLAPD_FILTER_COMPUTED: |
case SLAPD_FILTER_COMPUTED: |
Line 1263 vrFilter_free( Operation *op, ValuesRetu
|
Line 1268 vrFilter_free( Operation *op, ValuesRetu
|
|
|
default: |
default: |
#ifdef NEW_LOGGING |
#ifdef NEW_LOGGING |
LDAP_LOG( FILTER, ERR, |
LDAP_LOG( FILTER, ERR, "filter_free: unknown filter type %lu\n", |
"filter_free: unknown filter type %lu\n", vrf->vrf_choice, 0, 0 ); |
vrf->vrf_choice, 0, 0 ); |
#else |
#else |
Debug( LDAP_DEBUG_ANY, "filter_free: unknown filter type=%lu\n", |
Debug( LDAP_DEBUG_ANY, "filter_free: unknown filter type=%lu\n", |
vrf->vrf_choice, 0, 0 ); |
vrf->vrf_choice, 0, 0 ); |
Line 1300 vrFilter2bv( Operation *op, ValuesReturn
|
Line 1305 vrFilter2bv( Operation *op, ValuesReturn
|
simple_vrFilter2bv( op, p, &tmp ); |
simple_vrFilter2bv( op, p, &tmp ); |
|
|
fstr->bv_len += tmp.bv_len; |
fstr->bv_len += tmp.bv_len; |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, op->o_tmpmemctx ); |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, |
|
op->o_tmpmemctx ); |
|
|
snprintf( &fstr->bv_val[len-1], tmp.bv_len + 2, |
snprintf( &fstr->bv_val[len-1], tmp.bv_len + 2, |
/*"("*/ "%s)", tmp.bv_val ); |
/*"("*/ "%s)", tmp.bv_val ); |
Line 1316 simple_vrFilter2bv( Operation *op, Value
|
Line 1322 simple_vrFilter2bv( Operation *op, Value
|
ber_len_t len; |
ber_len_t len; |
|
|
if ( vrf == NULL ) { |
if ( vrf == NULL ) { |
ber_str2bv_x( "No filter!", sizeof("No filter!")-1, 1, fstr, op->o_tmpmemctx ); |
ber_str2bv_x( "No filter!", sizeof("No filter!")-1, 1, fstr, |
|
op->o_tmpmemctx ); |
return; |
return; |
} |
} |
|
|
Line 1390 simple_vrFilter2bv( Operation *op, Value
|
Line 1397 simple_vrFilter2bv( Operation *op, Value
|
filter_escape_value_x( &vrf->vrf_sub_initial, &tmp, op->o_tmpmemctx ); |
filter_escape_value_x( &vrf->vrf_sub_initial, &tmp, op->o_tmpmemctx ); |
|
|
fstr->bv_len += tmp.bv_len; |
fstr->bv_len += tmp.bv_len; |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, op->o_tmpmemctx ); |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, |
|
op->o_tmpmemctx ); |
|
|
snprintf( &fstr->bv_val[len-2], tmp.bv_len+3, |
snprintf( &fstr->bv_val[len-2], tmp.bv_len+3, |
/* "(attr=" */ "%s*)", |
/* "(attr=" */ "%s*)", |
Line 1403 simple_vrFilter2bv( Operation *op, Value
|
Line 1411 simple_vrFilter2bv( Operation *op, Value
|
int i; |
int i; |
for ( i = 0; vrf->vrf_sub_any[i].bv_val != NULL; i++ ) { |
for ( i = 0; vrf->vrf_sub_any[i].bv_val != NULL; i++ ) { |
len = fstr->bv_len; |
len = fstr->bv_len; |
filter_escape_value_x( &vrf->vrf_sub_any[i], &tmp, op->o_tmpmemctx ); |
filter_escape_value_x( &vrf->vrf_sub_any[i], &tmp, |
|
op->o_tmpmemctx ); |
|
|
fstr->bv_len += tmp.bv_len + 1; |
fstr->bv_len += tmp.bv_len + 1; |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, op->o_tmpmemctx ); |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, |
|
fstr->bv_len + 1, op->o_tmpmemctx ); |
|
|
snprintf( &fstr->bv_val[len-1], tmp.bv_len+3, |
snprintf( &fstr->bv_val[len-1], tmp.bv_len+3, |
/* "(attr=[init]*[any*]" */ "%s*)", |
/* "(attr=[init]*[any*]" */ "%s*)", |
Line 1421 simple_vrFilter2bv( Operation *op, Value
|
Line 1431 simple_vrFilter2bv( Operation *op, Value
|
filter_escape_value_x( &vrf->vrf_sub_final, &tmp, op->o_tmpmemctx ); |
filter_escape_value_x( &vrf->vrf_sub_final, &tmp, op->o_tmpmemctx ); |
|
|
fstr->bv_len += tmp.bv_len; |
fstr->bv_len += tmp.bv_len; |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, op->o_tmpmemctx ); |
fstr->bv_val = op->o_tmprealloc( fstr->bv_val, fstr->bv_len + 1, |
|
op->o_tmpmemctx ); |
|
|
snprintf( &fstr->bv_val[len-1], tmp.bv_len+3, |
snprintf( &fstr->bv_val[len-1], tmp.bv_len+3, |
/* "(attr=[init*][any*]" */ "%s)", |
/* "(attr=[init*][any*]" */ "%s)", |
Line 1454 simple_vrFilter2bv( Operation *op, Value
|
Line 1465 simple_vrFilter2bv( Operation *op, Value
|
|
|
fstr->bv_len = ad.bv_len + |
fstr->bv_len = ad.bv_len + |
( vrf->vrf_mr_dnattrs ? sizeof(":dn")-1 : 0 ) + |
( vrf->vrf_mr_dnattrs ? sizeof(":dn")-1 : 0 ) + |
( vrf->vrf_mr_rule_text.bv_len ? vrf->vrf_mr_rule_text.bv_len+1 : 0 ) + |
( vrf->vrf_mr_rule_text.bv_len |
|
? vrf->vrf_mr_rule_text.bv_len+1 : 0 ) + |
tmp.bv_len + ( sizeof("(:=)") - 1 ); |
tmp.bv_len + ( sizeof("(:=)") - 1 ); |
fstr->bv_val = op->o_tmpalloc( fstr->bv_len + 1, op->o_tmpmemctx ); |
fstr->bv_val = op->o_tmpalloc( fstr->bv_len + 1, op->o_tmpmemctx ); |
|
|
Line 1472 simple_vrFilter2bv( Operation *op, Value
|
Line 1484 simple_vrFilter2bv( Operation *op, Value
|
ber_str2bv_x( |
ber_str2bv_x( |
vrf->vrf_result == LDAP_COMPARE_FALSE ? "(?=false)" : |
vrf->vrf_result == LDAP_COMPARE_FALSE ? "(?=false)" : |
vrf->vrf_result == LDAP_COMPARE_TRUE ? "(?=true)" : |
vrf->vrf_result == LDAP_COMPARE_TRUE ? "(?=true)" : |
vrf->vrf_result == SLAPD_COMPARE_UNDEFINED ? "(?=undefined)" : |
vrf->vrf_result == SLAPD_COMPARE_UNDEFINED |
"(?=error)", |
? "(?=undefined)" : "(?=error)", |
vrf->vrf_result == LDAP_COMPARE_FALSE ? sizeof("(?=false)")-1 : |
vrf->vrf_result == LDAP_COMPARE_FALSE ? sizeof("(?=false)")-1 : |
vrf->vrf_result == LDAP_COMPARE_TRUE ? sizeof("(?=true)")-1 : |
vrf->vrf_result == LDAP_COMPARE_TRUE ? sizeof("(?=true)")-1 : |
vrf->vrf_result == SLAPD_COMPARE_UNDEFINED ? sizeof("(?=undefined)")-1 : |
vrf->vrf_result == SLAPD_COMPARE_UNDEFINED |
sizeof("(?=error)")-1, |
? sizeof("(?=undefined)")-1 : sizeof("(?=error)")-1, |
1, fstr, op->o_tmpmemctx ); |
1, fstr, op->o_tmpmemctx ); |
break; |
break; |
|
|