X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fschema_check.c;h=0cc2b886ed6c90c8dcc05a32d933dd389be5e77e;hb=f1e2d35bd6cd10afd0a3a1f6041f871e4ec5a69b;hp=40ca1d54a156440d8afcd68bbd954d4ed45e9599;hpb=9e7749541bb2d2d1a74f421f9f7cc908d6da9f59;p=openldap diff --git a/servers/slapd/schema_check.c b/servers/slapd/schema_check.c index 40ca1d54a1..0cc2b886ed 100644 --- a/servers/slapd/schema_check.c +++ b/servers/slapd/schema_check.c @@ -1,8 +1,17 @@ /* schema_check.c - routines to enforce schema definitions */ /* $OpenLDAP$ */ -/* - * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved. - * COPYING RESTRICTIONS APPLY, see COPYRIGHT file +/* This work is part of OpenLDAP Software . + * + * Copyright 1998-2005 The OpenLDAP Foundation. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted only as authorized by the OpenLDAP + * Public License. + * + * A copy of this license is available in the file LICENSE in the + * top-level directory of the distribution or, alternatively, at + * . */ #include "portable.h" @@ -14,7 +23,6 @@ #include #include "slap.h" -#include "ldap_pvt.h" static char * oc_check_required( Entry *e, @@ -95,14 +103,9 @@ entry_schema_check( "attribute '%s' cannot have multiple values", type ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn=\"%s\" %s\n", e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "Entry (%s), %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_CONSTRAINT_VIOLATION; } @@ -114,15 +117,9 @@ entry_schema_check( /* find the structural object class attribute */ asc = attr_find( e->e_attrs, ad_structuralObjectClass ); if ( asc == NULL ) { -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: No structuralObjectClass for entry (%s)\n", - e->e_dn, 0, 0 ); -#else Debug( LDAP_DEBUG_ANY, "No structuralObjectClass for entry (%s)\n", e->e_dn, 0, 0 ); -#endif *text = "no structuralObjectClass operational attribute"; return LDAP_OTHER; @@ -138,14 +135,9 @@ entry_schema_check( "unrecognized structuralObjectClass '%s'", asc->a_vals[0].bv_val ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn (%s), %s\n", e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "entry_check_schema(%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -155,14 +147,9 @@ entry_schema_check( "structuralObjectClass '%s' is not STRUCTURAL", asc->a_vals[0].bv_val ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn (%s), %s\n", e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "entry_check_schema(%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OTHER; } @@ -172,14 +159,9 @@ entry_schema_check( "structuralObjectClass '%s' is OBSOLETE", asc->a_vals[0].bv_val ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn (%s), %s\n", e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "entry_check_schema(%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -187,14 +169,8 @@ entry_schema_check( /* find the object class attribute */ aoc = attr_find( e->e_attrs, ad_objectClass ); if ( aoc == NULL ) { -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: No objectClass for entry (%s).\n", - e->e_dn, 0, 0 ); -#else Debug( LDAP_DEBUG_ANY, "No objectClass for entry (%s)\n", e->e_dn, 0, 0 ); -#endif *text = "no objectClass attribute"; return LDAP_OBJECT_CLASS_VIOLATION; @@ -227,14 +203,14 @@ entry_schema_check( } /* naming check */ - if ( !is_entry_objectclass ( e, slap_schema.si_oc_glue, 0 ) ) { - rc = entry_naming_check( e, text, textbuf, textlen ); - if( rc != LDAP_SUCCESS ) { - return rc; - } - } else { - /* Glue Entry */ - } + if ( !is_entry_objectclass ( e, slap_schema.si_oc_glue, 0 ) ) { + rc = entry_naming_check( e, text, textbuf, textlen ); + if( rc != LDAP_SUCCESS ) { + return rc; + } + } else { + /* Glue Entry */ + } /* find the content rule for the structural class */ cr = cr_find( sc->soc_oid ); @@ -249,14 +225,9 @@ entry_schema_check( "content rule '%s' is obsolete", ldap_contentrule2name( &cr->scr_crule )); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn=\"%s\" %s", e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "Entry (%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -277,14 +248,9 @@ entry_schema_check( ldap_contentrule2name( &cr->scr_crule ), at->sat_cname.bv_val ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn=\"%s\" %s", e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "Entry (%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -306,14 +272,9 @@ entry_schema_check( ldap_contentrule2name( &cr->scr_crule ), at->sat_cname.bv_val ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn=\"%s\" %s", e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "Entry (%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -327,14 +288,9 @@ entry_schema_check( "unrecognized objectClass '%s'", aoc->a_vals[i].bv_val ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn (%s), %s\n", e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "entry_check_schema(%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -345,14 +301,9 @@ entry_schema_check( "objectClass '%s' is OBSOLETE", aoc->a_vals[i].bv_val ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn (%s), %s\n", e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "entry_check_schema(%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -380,15 +331,9 @@ entry_schema_check( "unrecognized objectClass '%s'", aoc->a_vals[i].bv_val ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn (%s), %s\n", - e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "entry_check_schema(%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -413,15 +358,9 @@ entry_schema_check( "abstract objectClass '%s' not allowed", aoc->a_vals[i].bv_val ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn (%s), %s\n", - e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "entry_check_schema(%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -457,15 +396,9 @@ entry_schema_check( ldap_contentrule2name( &cr->scr_crule ), oc->soc_cname.bv_val ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn=\"%s\" %s", - e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "Entry (%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -477,14 +410,9 @@ entry_schema_check( "object class '%s' requires attribute '%s'", aoc->a_vals[i].bv_val, s ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn=\"%s\" %s", e->e_dn, textbuf, 0 ); -#else Debug( LDAP_DEBUG_ANY, "Entry (%s): %s\n", e->e_dn, textbuf, 0 ); -#endif return LDAP_OBJECT_CLASS_VIOLATION; } @@ -496,6 +424,7 @@ entry_schema_check( } if( extensible ) { + *text = NULL; return LDAP_SUCCESS; } @@ -535,19 +464,15 @@ entry_schema_check( "attribute '%s' not allowed", type ); -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, INFO, - "entry_schema_check: dn=\"%s\" %s\n", e->e_dn, textbuf, 0); -#else Debug( LDAP_DEBUG_ANY, "Entry (%s), %s\n", e->e_dn, textbuf, 0 ); -#endif return ret; } } + *text = NULL; return LDAP_SUCCESS; } @@ -561,15 +486,9 @@ oc_check_required( int i; Attribute *a; -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, ENTRY, - "oc_check_required: dn (%s), objectClass \"%s\"\n", - e->e_dn, ocname->bv_val, 0 ); -#else Debug( LDAP_DEBUG_TRACE, "oc_check_required entry (%s), objectClass \"%s\"\n", e->e_dn, ocname->bv_val, 0 ); -#endif /* check for empty oc_required */ @@ -602,14 +521,9 @@ int oc_check_allowed( { int i, j; -#ifdef NEW_LOGGING - LDAP_LOG( OPERATION, ENTRY, - "oc_check_allowed: type \"%s\"\n", at->sat_cname.bv_val, 0, 0 ); -#else Debug( LDAP_DEBUG_TRACE, "oc_check_allowed type \"%s\"\n", at->sat_cname.bv_val, 0, 0 ); -#endif /* always allow objectClass attribute */ if ( strcasecmp( at->sat_cname.bv_val, "objectClass" ) == 0 ) { @@ -719,7 +633,7 @@ int structural_class( if( xc == NULL ) { snprintf( textbuf, textlen, "unrecognized objectClass '%s'", - ocs[i].bv_val ); + ocs[j].bv_val ); *text = textbuf; return LDAP_OBJECT_CLASS_VIOLATION; } @@ -772,6 +686,8 @@ int structural_class( return LDAP_OBJECT_CLASS_VIOLATION; } + *text = NULL; + return LDAP_SUCCESS; } @@ -801,12 +717,12 @@ int mods_structural_class( return LDAP_OBJECT_CLASS_VIOLATION; } - if( ocmod->sml_bvalues == NULL || ocmod->sml_bvalues[0].bv_val == NULL ) { + if( ocmod->sml_values == NULL || ocmod->sml_values[0].bv_val == NULL ) { *text = "objectClass attribute has no values"; return LDAP_OBJECT_CLASS_VIOLATION; } - return structural_class( ocmod->sml_bvalues, sc, NULL, + return structural_class( ocmod->sml_values, sc, NULL, text, textbuf, textlen ); } @@ -854,7 +770,31 @@ entry_naming_check( break; } - if( desc->ad_type->sat_equality == NULL ) { + if( desc->ad_type->sat_usage ) { + snprintf( textbuf, textlen, + "naming attribute '%s' is operational", + ava->la_attr.bv_val ); + rc = LDAP_NAMING_VIOLATION; + break; + } + + if( desc->ad_type->sat_collective ) { + snprintf( textbuf, textlen, + "naming attribute '%s' is collective", + ava->la_attr.bv_val ); + rc = LDAP_NAMING_VIOLATION; + break; + } + + if( desc->ad_type->sat_obsolete ) { + snprintf( textbuf, textlen, + "naming attribute '%s' is obsolete", + ava->la_attr.bv_val ); + rc = LDAP_NAMING_VIOLATION; + break; + } + + if( !desc->ad_type->sat_equality ) { snprintf( textbuf, textlen, "naming attribute '%s' has no equality matching rule", ava->la_attr.bv_val ); @@ -862,7 +802,7 @@ entry_naming_check( break; } - if( desc->ad_type->sat_equality->smr_match == NULL ) { + if( !desc->ad_type->sat_equality->smr_match ) { snprintf( textbuf, textlen, "naming attribute '%s' has unsupported equality matching rule", ava->la_attr.bv_val );