mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-24 13:24:56 +08:00
Added SLAP_MR_VALUE_NORMALIZED_MATCH, avoid redundant normalize when
calling value_find with already-normalized DNs
This commit is contained in:
parent
5efa571ad2
commit
09679eb715
@ -888,7 +888,8 @@ dn_match_cleanup:;
|
|||||||
at != NULL;
|
at != NULL;
|
||||||
at = attrs_find( at->a_next, b->a_dn_at ) )
|
at = attrs_find( at->a_next, b->a_dn_at ) )
|
||||||
{
|
{
|
||||||
if( value_find( b->a_dn_at, at->a_vals, &bv ) == 0 ) {
|
if( value_find_ex( b->a_dn_at,
|
||||||
|
SLAP_MR_VALUE_NORMALIZED_MATCH, at->a_vals, &bv ) == 0 ) {
|
||||||
/* found it */
|
/* found it */
|
||||||
match = 1;
|
match = 1;
|
||||||
break;
|
break;
|
||||||
@ -1801,7 +1802,7 @@ aci_mask(
|
|||||||
at != NULL;
|
at != NULL;
|
||||||
at = attrs_find( at->a_next, ad ) )
|
at = attrs_find( at->a_next, ad ) )
|
||||||
{
|
{
|
||||||
if (value_find( ad, at->a_vals, &bv) == 0 ) {
|
if (value_find( ad, SLAP_MR_VALUE_NORMALIZED_MATCH, at->a_vals, &bv) == 0 ) {
|
||||||
rc = 1;
|
rc = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -205,7 +205,8 @@ dn2entry_retry:
|
|||||||
group_oc_name, group_at_name, 0 );
|
group_oc_name, group_at_name, 0 );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if( value_find( group_at, attr->a_vals, op_ndn ) != LDAP_SUCCESS ) {
|
if( value_find_ex( group_at, SLAP_MR_VALUE_NORMALIZED_MATCH,
|
||||||
|
attr->a_vals, op_ndn ) != LDAP_SUCCESS ) {
|
||||||
#ifdef NEW_LOGGING
|
#ifdef NEW_LOGGING
|
||||||
LDAP_LOG( BACK_BDB, DETAIL1,
|
LDAP_LOG( BACK_BDB, DETAIL1,
|
||||||
"bdb_group: \"%s\" not in \"%s\": %s\n",
|
"bdb_group: \"%s\" not in \"%s\": %s\n",
|
||||||
|
@ -82,7 +82,8 @@ ldap_back_group(
|
|||||||
* attribute has not been required
|
* attribute has not been required
|
||||||
*/
|
*/
|
||||||
if ((attr = attr_find(target->e_attrs, group_at)) != NULL) {
|
if ((attr = attr_find(target->e_attrs, group_at)) != NULL) {
|
||||||
if( value_find( group_at, attr->a_vals, op_ndn ) != LDAP_SUCCESS )
|
if( value_find_ex( group_at, SLAP_MR_VALUE_NORMALIZED_MATCH,
|
||||||
|
attr->a_vals, op_ndn ) != LDAP_SUCCESS )
|
||||||
return(1);
|
return(1);
|
||||||
return(0);
|
return(0);
|
||||||
} /* else: repeat the search */
|
} /* else: repeat the search */
|
||||||
|
@ -178,7 +178,8 @@ ldbm_back_group(
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
if( value_find( group_at, attr->a_vals, op_ndn ) != LDAP_SUCCESS ) {
|
if( value_find_ex( group_at, SLAP_MR_VALUE_NORMALIZED_MATCH,
|
||||||
|
attr->a_vals, op_ndn ) != LDAP_SUCCESS ) {
|
||||||
#ifdef NEW_LOGGING
|
#ifdef NEW_LOGGING
|
||||||
LDAP_LOG( BACK_LDBM, DETAIL1,
|
LDAP_LOG( BACK_LDBM, DETAIL1,
|
||||||
"ldbm_back_group: \"%s\" not in \"%s\": %s\n",
|
"ldbm_back_group: \"%s\" not in \"%s\": %s\n",
|
||||||
|
@ -144,8 +144,9 @@ meta_back_group(
|
|||||||
*/
|
*/
|
||||||
attr = attr_find( target->e_attrs, group_at );
|
attr = attr_find( target->e_attrs, group_at );
|
||||||
if ( attr != NULL ) {
|
if ( attr != NULL ) {
|
||||||
rc = value_find( group_at, attr->a_vals,
|
rc = value_find_ex( group_at,
|
||||||
op_ndn );
|
SLAP_MR_VALUE_SYNTAX_CONVERTED_MATCH,
|
||||||
|
attr->a_vals, op_ndn );
|
||||||
if ( rc != LDAP_SUCCESS ) {
|
if ( rc != LDAP_SUCCESS ) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -439,6 +439,7 @@ typedef struct slap_matching_rule {
|
|||||||
#define SLAP_MR_ASSERTION_SYNTAX_MATCH 0x0000U
|
#define SLAP_MR_ASSERTION_SYNTAX_MATCH 0x0000U
|
||||||
#define SLAP_MR_VALUE_SYNTAX_MATCH 0x0001U
|
#define SLAP_MR_VALUE_SYNTAX_MATCH 0x0001U
|
||||||
#define SLAP_MR_VALUE_SYNTAX_CONVERTED_MATCH 0x0003U
|
#define SLAP_MR_VALUE_SYNTAX_CONVERTED_MATCH 0x0003U
|
||||||
|
#define SLAP_MR_VALUE_NORMALIZED_MATCH 0x0004U
|
||||||
|
|
||||||
#define SLAP_IS_MR_ASSERTION_SYNTAX_MATCH( usage ) \
|
#define SLAP_IS_MR_ASSERTION_SYNTAX_MATCH( usage ) \
|
||||||
(!((usage) & SLAP_MR_VALUE_SYNTAX_MATCH))
|
(!((usage) & SLAP_MR_VALUE_SYNTAX_MATCH))
|
||||||
|
@ -391,7 +391,8 @@ int value_find_ex(
|
|||||||
flags |= SLAP_MR_VALUE_SYNTAX_CONVERTED_MATCH;
|
flags |= SLAP_MR_VALUE_SYNTAX_CONVERTED_MATCH;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( mr->smr_syntax->ssyn_normalize ) {
|
if( !(flags & SLAP_MR_VALUE_NORMALIZED_MATCH) &&
|
||||||
|
mr->smr_syntax->ssyn_normalize ) {
|
||||||
struct berval nval_tmp = { 0, NULL };
|
struct berval nval_tmp = { 0, NULL };
|
||||||
|
|
||||||
rc = mr->smr_syntax->ssyn_normalize(
|
rc = mr->smr_syntax->ssyn_normalize(
|
||||||
|
Loading…
Reference in New Issue
Block a user