X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fat.c;h=c262dd6b21e3285c7907622f89a98ffbabb291c6;hb=17f95a3fd30247a0735a3526d85b46178304748d;hp=7e28fb6663fa0332a27e2cb82871d231153e0e76;hpb=8a5b200c447a758d91805827593db72c54bea6e2;p=openldap diff --git a/servers/slapd/at.c b/servers/slapd/at.c index 7e28fb6663..c262dd6b21 100644 --- a/servers/slapd/at.c +++ b/servers/slapd/at.c @@ -1,6 +1,6 @@ /* $OpenLDAP$ */ /* - * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved. + * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved. * COPYING RESTRICTIONS APPLY, see COPYRIGHT file */ /* at.c - routines for dealing with attribute types */ @@ -53,10 +53,12 @@ static AttributeType *attr_list = NULL; static int attr_index_cmp( - struct aindexrec *air1, - struct aindexrec *air2 + const void *v_air1, + const void *v_air2 ) { + const struct aindexrec *air1 = v_air1; + const struct aindexrec *air2 = v_air2; int i = air1->air_name.bv_len - air2->air_name.bv_len; if (i) return i; @@ -65,10 +67,12 @@ attr_index_cmp( static int attr_index_name_cmp( - struct berval *type, - struct aindexrec *air + const void *v_type, + const void *v_air ) { + const struct berval *type = v_type; + const struct aindexrec *air = v_air; int i = type->bv_len - air->air_name.bv_len; if (i) return i; @@ -96,8 +100,7 @@ at_bvfind( { struct aindexrec *air; - air = (struct aindexrec *) avl_find( attr_index, name, - (AVL_CMP) attr_index_name_cmp ); + air = avl_find( attr_index, name, attr_index_name_cmp ); return air != NULL ? air->air_at : NULL; } @@ -267,8 +270,7 @@ at_insert( air->air_name.bv_len = strlen(sat->sat_oid); air->air_at = sat; if ( avl_insert( &attr_index, (caddr_t) air, - (AVL_CMP) attr_index_cmp, - (AVL_DUP) avl_dup_error ) ) { + attr_index_cmp, avl_dup_error ) ) { *err = sat->sat_oid; ldap_memfree(air); return SLAP_SCHERR_ATTR_DUP; @@ -285,8 +287,7 @@ at_insert( air->air_name.bv_len = strlen(*names); air->air_at = sat; if ( avl_insert( &attr_index, (caddr_t) air, - (AVL_CMP) attr_index_cmp, - (AVL_DUP) avl_dup_error ) ) { + attr_index_cmp, avl_dup_error ) ) { *err = *names; ldap_memfree(air); return SLAP_SCHERR_ATTR_DUP; @@ -338,7 +339,6 @@ at_add( ldap_memfree( at->at_syntax_oid ); at->at_syntax_oid = oid; } - } if ( at->at_names && at->at_names[0] ) { @@ -406,6 +406,11 @@ at_add( return SLAP_SCHERR_ATTR_BAD_USAGE; } + if ( supsat->sat_obsolete && !sat->sat_obsolete ) { + /* subtypes must be obsolete if super is */ + return SLAP_SCHERR_ATTR_BAD_SUP; + } + if ( sat->sat_flags & SLAP_AT_FINAL ) { /* cannot subtype a "final" attribute type */ return SLAP_SCHERR_ATTR_BAD_SUP; @@ -526,15 +531,23 @@ at_add( return SLAP_SCHERR_ATTR_BAD_MR; } -#if 0 - if( sat->sat_syntax != mr->smr_syntax ) { - if( mr->smr_compat_syntaxes == NULL ) { + /* due to funky LDAP builtin substring rules, we + * we check against the equality rule assertion + * syntax and compat syntaxes instead of those + * associated with the substrings rule. + */ + if( sat->sat_equality && + sat->sat_syntax != sat->sat_equality->smr_syntax ) + { + if( sat->sat_equality->smr_compat_syntaxes == NULL ) { *err = sat->sat_substr_oid; return SLAP_SCHERR_ATTR_BAD_MR; } - for(i=0; mr->smr_compat_syntaxes[i]; i++) { - if( sat->sat_syntax == mr->smr_compat_syntaxes[i] ) { + for(i=0; sat->sat_equality->smr_compat_syntaxes[i]; i++) { + if( sat->sat_syntax == + sat->sat_equality->smr_compat_syntaxes[i] ) + { i = -1; break; } @@ -545,7 +558,6 @@ at_add( return SLAP_SCHERR_ATTR_BAD_MR; } } -#endif sat->sat_substr = mr; } @@ -556,9 +568,9 @@ at_add( #ifdef LDAP_DEBUG static int -at_index_printnode( struct aindexrec *air ) +at_index_printnode( void *v_air, void *ignore ) { - + struct aindexrec *air = v_air; printf("%s = %s\n", air->air_name.bv_val, ldap_attributetype2str(&air->air_at->sat_atype) ); @@ -569,12 +581,10 @@ static void at_index_print( void ) { printf("Printing attribute type index:\n"); - (void) avl_apply( attr_index, (AVL_APPLY) at_index_printnode, - 0, -1, AVL_INORDER ); + (void) avl_apply( attr_index, at_index_printnode, 0, -1, AVL_INORDER ); } #endif -#if defined( SLAPD_SCHEMA_DN ) int at_schema_info( Entry *e ) { @@ -586,19 +596,15 @@ at_schema_info( Entry *e ) vals[1].bv_val = NULL; for ( at = attr_list; at; at = at->sat_next ) { + if( at->sat_flags & SLAP_AT_HIDE ) continue; + if ( ldap_attributetype2bv( &at->sat_atype, vals ) == NULL ) { return -1; } - if( at->sat_flags & SLAP_AT_HIDE ) continue; - -#if 0 - Debug( LDAP_DEBUG_TRACE, "Merging at [%ld] %s\n", - (long) vals[0].bv_len, vals[0].bv_val, 0 ); -#endif - attr_merge( e, ad_attributeTypes, vals ); + if( attr_merge( e, ad_attributeTypes, vals ) ) + return -1; ldap_memfree( vals[0].bv_val ); } return 0; } -#endif