X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fat.c;h=27facafff50b885212e29f62ec22abf0c11f39a5;hb=014ba5ac80497d02b83514f30dabe3824e9facdc;hp=238b91f68443d23c19ef5f722b5540f6db0c1a20;hpb=69ba1a21bc6186fcb26e6f1e75226f9d4e69316a;p=openldap diff --git a/servers/slapd/at.c b/servers/slapd/at.c index 238b91f684..27facafff5 100644 --- a/servers/slapd/at.c +++ b/servers/slapd/at.c @@ -338,7 +338,6 @@ at_add( ldap_memfree( at->at_syntax_oid ); at->at_syntax_oid = oid; } - } if ( at->at_names && at->at_names[0] ) { @@ -406,6 +405,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; @@ -581,7 +585,6 @@ at_index_print( void ) } #endif -#if defined( SLAPD_SCHEMA_DN ) int at_schema_info( Entry *e ) { @@ -593,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