mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-06 10:46:21 +08:00
Update uniqueMemberMatch to be consistent with latest
draft-ietf-ldapbis-syntaxes Add uniqueMemberMatch approximate support Add uniqueMemberMatch indexing support
This commit is contained in:
parent
71c2c1c9fe
commit
e7e8ec90b6
@ -186,7 +186,7 @@ static int test_mra_filter(
|
|||||||
const char *text;
|
const char *text;
|
||||||
|
|
||||||
rc = value_match( &ret, slap_schema.si_ad_entryDN, mra->ma_rule,
|
rc = value_match( &ret, slap_schema.si_ad_entryDN, mra->ma_rule,
|
||||||
0, &e->e_nname, &mra->ma_value, &text );
|
SLAP_MR_EXT, &e->e_nname, &mra->ma_value, &text );
|
||||||
|
|
||||||
|
|
||||||
if( rc != LDAP_SUCCESS ) return rc;
|
if( rc != LDAP_SUCCESS ) return rc;
|
||||||
@ -264,7 +264,8 @@ static int test_mra_filter(
|
|||||||
if ( !a->a_comp_data->cd_tree[i] ) {
|
if ( !a->a_comp_data->cd_tree[i] ) {
|
||||||
return LDAP_OPERATIONS_ERROR;
|
return LDAP_OPERATIONS_ERROR;
|
||||||
}
|
}
|
||||||
rc = value_match( &ret, a->a_desc, mra->ma_rule, 0,
|
rc = value_match( &ret, a->a_desc, mra->ma_rule,
|
||||||
|
SLAP_MR_COMPONENT,
|
||||||
(struct berval*)a->a_comp_data->cd_tree[i++],
|
(struct berval*)a->a_comp_data->cd_tree[i++],
|
||||||
(void*)mra, &text );
|
(void*)mra, &text );
|
||||||
} else
|
} else
|
||||||
@ -308,8 +309,8 @@ static int test_mra_filter(
|
|||||||
nbv = *bv;
|
nbv = *bv;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = value_match( &ret, a->a_desc, mra->ma_rule, 0,
|
rc = value_match( &ret, a->a_desc, mra->ma_rule,
|
||||||
&nbv, &mra->ma_value, &text );
|
SLAP_MR_EXT, &nbv, &mra->ma_value, &text );
|
||||||
|
|
||||||
if ( nbv.bv_val != bv->bv_val ) {
|
if ( nbv.bv_val != bv->bv_val ) {
|
||||||
memfree( nbv.bv_val, memctx );
|
memfree( nbv.bv_val, memctx );
|
||||||
@ -356,7 +357,8 @@ static int test_mra_filter(
|
|||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
rc = value_match( &ret, a->a_desc, mra->ma_rule, 0,
|
rc = value_match( &ret, a->a_desc, mra->ma_rule,
|
||||||
|
SLAP_MR_COMPONENT,
|
||||||
(struct berval*)a, (void*)mra, &text );
|
(struct berval*)a, (void*)mra, &text );
|
||||||
if ( rc != LDAP_SUCCESS ) break;
|
if ( rc != LDAP_SUCCESS ) break;
|
||||||
|
|
||||||
@ -397,8 +399,8 @@ static int test_mra_filter(
|
|||||||
nbv = *bv;
|
nbv = *bv;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = value_match( &ret, a->a_desc, mra->ma_rule, 0,
|
rc = value_match( &ret, a->a_desc, mra->ma_rule,
|
||||||
&nbv, &value, &text );
|
SLAP_MR_EXT, &nbv, &value, &text );
|
||||||
|
|
||||||
if ( nbv.bv_val != bv->bv_val ) {
|
if ( nbv.bv_val != bv->bv_val ) {
|
||||||
memfree( nbv.bv_val, memctx );
|
memfree( nbv.bv_val, memctx );
|
||||||
@ -494,7 +496,7 @@ static int test_mra_filter(
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* check match */
|
/* check match */
|
||||||
rc = value_match( &ret, ad, mra->ma_rule, 0,
|
rc = value_match( &ret, ad, mra->ma_rule, SLAP_MR_EXT,
|
||||||
&nbv, &value, &text );
|
&nbv, &value, &text );
|
||||||
|
|
||||||
cleanup:;
|
cleanup:;
|
||||||
@ -588,8 +590,8 @@ test_ava_filter(
|
|||||||
mr = slap_schema.si_ad_entryDN->ad_type->sat_equality;
|
mr = slap_schema.si_ad_entryDN->ad_type->sat_equality;
|
||||||
assert( mr );
|
assert( mr );
|
||||||
|
|
||||||
rc = value_match( &match, slap_schema.si_ad_entryDN, mr, 0,
|
rc = value_match( &match, slap_schema.si_ad_entryDN, mr,
|
||||||
&e->e_nname, &ava->aa_value, &text );
|
SLAP_MR_EXT, &e->e_nname, &ava->aa_value, &text );
|
||||||
|
|
||||||
if( rc != LDAP_SUCCESS ) return rc;
|
if( rc != LDAP_SUCCESS ) return rc;
|
||||||
if( match == 0 ) return LDAP_COMPARE_TRUE;
|
if( match == 0 ) return LDAP_COMPARE_TRUE;
|
||||||
@ -613,6 +615,7 @@ test_ava_filter(
|
|||||||
a != NULL;
|
a != NULL;
|
||||||
a = attrs_find( a->a_next, ava->aa_desc ) )
|
a = attrs_find( a->a_next, ava->aa_desc ) )
|
||||||
{
|
{
|
||||||
|
int use;
|
||||||
MatchingRule *mr;
|
MatchingRule *mr;
|
||||||
struct berval *bv;
|
struct berval *bv;
|
||||||
|
|
||||||
@ -623,19 +626,24 @@ test_ava_filter(
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
use = SLAP_MR_EQUALITY;
|
||||||
|
|
||||||
switch ( type ) {
|
switch ( type ) {
|
||||||
case LDAP_FILTER_APPROX:
|
case LDAP_FILTER_APPROX:
|
||||||
|
use = SLAP_MR_EQUALITY_APPROX;
|
||||||
mr = a->a_desc->ad_type->sat_approx;
|
mr = a->a_desc->ad_type->sat_approx;
|
||||||
if( mr != NULL ) break;
|
if( mr != NULL ) break;
|
||||||
|
|
||||||
/* use EQUALITY matching rule if no APPROX rule */
|
/* fallthru: use EQUALITY matching rule if no APPROX rule */
|
||||||
|
|
||||||
case LDAP_FILTER_EQUALITY:
|
case LDAP_FILTER_EQUALITY:
|
||||||
|
/* use variable set above so fall thru use is not clobbered */
|
||||||
mr = a->a_desc->ad_type->sat_equality;
|
mr = a->a_desc->ad_type->sat_equality;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LDAP_FILTER_GE:
|
case LDAP_FILTER_GE:
|
||||||
case LDAP_FILTER_LE:
|
case LDAP_FILTER_LE:
|
||||||
|
use = SLAP_MR_ORDERING;
|
||||||
mr = a->a_desc->ad_type->sat_ordering;
|
mr = a->a_desc->ad_type->sat_ordering;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -700,8 +708,10 @@ test_ava_filter(
|
|||||||
return LDAP_OPERATIONS_ERROR;
|
return LDAP_OPERATIONS_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = value_match( &match, a->a_desc, cf_mr, 0,
|
ret = value_match( &match, a->a_desc, cf_mr,
|
||||||
(struct berval*)a->a_comp_data->cd_tree[i++], (void*)&mra, &text );
|
SLAP_MR_COMPONENT,
|
||||||
|
(struct berval*)a->a_comp_data->cd_tree[i++],
|
||||||
|
(void*)&mra, &text );
|
||||||
if ( ret == LDAP_INAPPROPRIATE_MATCHING ) {
|
if ( ret == LDAP_INAPPROPRIATE_MATCHING ) {
|
||||||
/* cached component tree is broken, just remove it */
|
/* cached component tree is broken, just remove it */
|
||||||
free_ComponentData ( a );
|
free_ComponentData ( a );
|
||||||
@ -709,12 +719,11 @@ test_ava_filter(
|
|||||||
}
|
}
|
||||||
if ( a_alias )
|
if ( a_alias )
|
||||||
ava->aa_desc = a_alias->aa_aliasing_ad;
|
ava->aa_desc = a_alias->aa_aliasing_ad;
|
||||||
}
|
|
||||||
else
|
} else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
|
ret = value_match( &match, a->a_desc, mr, use,
|
||||||
ret = value_match( &match, a->a_desc, mr, 0,
|
|
||||||
bv, &ava->aa_value, &text );
|
bv, &ava->aa_value, &text );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -909,7 +918,7 @@ test_substrings_filter(
|
|||||||
int ret, match;
|
int ret, match;
|
||||||
const char *text;
|
const char *text;
|
||||||
|
|
||||||
ret = value_match( &match, a->a_desc, mr, 0,
|
ret = value_match( &match, a->a_desc, mr, SLAP_MR_SUBSTR,
|
||||||
bv, f->f_sub, &text );
|
bv, f->f_sub, &text );
|
||||||
|
|
||||||
if( ret != LDAP_SUCCESS ) {
|
if( ret != LDAP_SUCCESS ) {
|
||||||
|
@ -1060,6 +1060,7 @@ uniqueMemberMatch(
|
|||||||
struct berval assertedUID = BER_BVNULL;
|
struct berval assertedUID = BER_BVNULL;
|
||||||
struct berval valueDN = BER_BVNULL;
|
struct berval valueDN = BER_BVNULL;
|
||||||
struct berval valueUID = BER_BVNULL;
|
struct berval valueUID = BER_BVNULL;
|
||||||
|
int approx = ((flags & SLAP_MR_EQUALITY_APPROX) == SLAP_MR_EQUALITY_APPROX);
|
||||||
|
|
||||||
if ( !BER_BVISEMPTY( asserted ) ) {
|
if ( !BER_BVISEMPTY( asserted ) ) {
|
||||||
assertedUID.bv_val = strrchr( assertedDN.bv_val, '#' );
|
assertedUID.bv_val = strrchr( assertedDN.bv_val, '#' );
|
||||||
@ -1107,11 +1108,109 @@ uniqueMemberMatch(
|
|||||||
*matchp = match;
|
*matchp = match;
|
||||||
return LDAP_SUCCESS;
|
return LDAP_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} else if ( !approx && valueUID.bv_len ) {
|
||||||
|
match = -1;
|
||||||
|
*matchp = match;
|
||||||
|
return LDAP_SUCCESS;
|
||||||
|
|
||||||
|
} else if ( !approx && assertedUID.bv_len ) {
|
||||||
|
match = 1;
|
||||||
|
*matchp = match;
|
||||||
|
return LDAP_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
return dnMatch( matchp, flags, syntax, mr, &valueDN, &assertedDN );
|
return dnMatch( matchp, flags, syntax, mr, &valueDN, &assertedDN );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
uniqueMemberIndexer(
|
||||||
|
slap_mask_t use,
|
||||||
|
slap_mask_t flags,
|
||||||
|
Syntax *syntax,
|
||||||
|
MatchingRule *mr,
|
||||||
|
struct berval *prefix,
|
||||||
|
BerVarray values,
|
||||||
|
BerVarray *keysp,
|
||||||
|
void *ctx )
|
||||||
|
{
|
||||||
|
BerVarray dnvalues;
|
||||||
|
int rc;
|
||||||
|
int i;
|
||||||
|
for( i=0; !BER_BVISNULL( &values[i] ); i++ ) {
|
||||||
|
/* just count them */
|
||||||
|
}
|
||||||
|
assert( i > 0 );
|
||||||
|
|
||||||
|
dnvalues = slap_sl_malloc( sizeof( struct berval ) * (i+1), ctx );
|
||||||
|
|
||||||
|
for( i=0; !BER_BVISNULL( &values[i] ); i++ ) {
|
||||||
|
struct berval assertedDN = values[i];
|
||||||
|
struct berval assertedUID = BER_BVNULL;
|
||||||
|
|
||||||
|
if ( !BER_BVISEMPTY( &assertedDN ) ) {
|
||||||
|
assertedUID.bv_val = strrchr( assertedDN.bv_val, '#' );
|
||||||
|
if ( !BER_BVISNULL( &assertedUID ) ) {
|
||||||
|
assertedUID.bv_val++;
|
||||||
|
assertedUID.bv_len = assertedDN.bv_len
|
||||||
|
- ( assertedUID.bv_val - assertedDN.bv_val );
|
||||||
|
|
||||||
|
if ( bitStringValidate( NULL, &assertedUID ) == LDAP_SUCCESS ) {
|
||||||
|
assertedDN.bv_len -= assertedUID.bv_len + 1;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
BER_BVZERO( &assertedUID );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
dnvalues[i] = assertedDN;
|
||||||
|
}
|
||||||
|
BER_BVZERO( &dnvalues[i] );
|
||||||
|
|
||||||
|
rc = octetStringIndexer( use, flags, syntax, mr, prefix,
|
||||||
|
dnvalues, keysp, ctx );
|
||||||
|
|
||||||
|
slap_sl_free( dnvalues, ctx );
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
uniqueMemberFilter(
|
||||||
|
slap_mask_t use,
|
||||||
|
slap_mask_t flags,
|
||||||
|
Syntax *syntax,
|
||||||
|
MatchingRule *mr,
|
||||||
|
struct berval *prefix,
|
||||||
|
void * assertedValue,
|
||||||
|
BerVarray *keysp,
|
||||||
|
void *ctx )
|
||||||
|
{
|
||||||
|
struct berval *asserted = (struct berval *) assertedValue;
|
||||||
|
struct berval assertedDN = *asserted;
|
||||||
|
struct berval assertedUID = BER_BVNULL;
|
||||||
|
|
||||||
|
if ( !BER_BVISEMPTY( asserted ) ) {
|
||||||
|
assertedUID.bv_val = strrchr( assertedDN.bv_val, '#' );
|
||||||
|
if ( !BER_BVISNULL( &assertedUID ) ) {
|
||||||
|
assertedUID.bv_val++;
|
||||||
|
assertedUID.bv_len = assertedDN.bv_len
|
||||||
|
- ( assertedUID.bv_val - assertedDN.bv_val );
|
||||||
|
|
||||||
|
if ( bitStringValidate( NULL, &assertedUID ) == LDAP_SUCCESS ) {
|
||||||
|
assertedDN.bv_len -= assertedUID.bv_len + 1;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
BER_BVZERO( &assertedUID );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return octetStringFilter( use, flags, syntax, mr, prefix,
|
||||||
|
&assertedDN, keysp, ctx );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Handling boolean syntax and matching is quite rigid.
|
* Handling boolean syntax and matching is quite rigid.
|
||||||
* A more flexible approach would be to allow a variety
|
* A more flexible approach would be to allow a variety
|
||||||
@ -3638,7 +3737,7 @@ static slap_mrule_defs_rec mrule_defs[] = {
|
|||||||
"SYNTAX 1.3.6.1.4.1.1466.115.121.1.34 )",
|
"SYNTAX 1.3.6.1.4.1.1466.115.121.1.34 )",
|
||||||
SLAP_MR_EQUALITY | SLAP_MR_EXT, NULL,
|
SLAP_MR_EQUALITY | SLAP_MR_EXT, NULL,
|
||||||
NULL, uniqueMemberNormalize, uniqueMemberMatch,
|
NULL, uniqueMemberNormalize, uniqueMemberMatch,
|
||||||
NULL, NULL,
|
uniqueMemberIndexer, uniqueMemberFilter,
|
||||||
NULL },
|
NULL },
|
||||||
|
|
||||||
{"( 2.5.13.24 NAME 'protocolInformationMatch' "
|
{"( 2.5.13.24 NAME 'protocolInformationMatch' "
|
||||||
|
Loading…
Reference in New Issue
Block a user