validate object class before checking required and allowed

This commit is contained in:
Gary Williams 1999-08-30 14:19:53 +00:00
parent 40fa9d36ce
commit 6db0228171

View File

@ -28,9 +28,11 @@ int
oc_schema_check( Entry *e ) oc_schema_check( Entry *e )
{ {
Attribute *a, *aoc; Attribute *a, *aoc;
ObjectClass *oc;
int i; int i;
int ret = 0; int ret = 0;
/* find the object class attribute - could error out here */ /* find the object class attribute - could error out here */
if ( (aoc = attr_find( e->e_attrs, "objectclass" )) == NULL ) { if ( (aoc = attr_find( e->e_attrs, "objectclass" )) == NULL ) {
Debug( LDAP_DEBUG_ANY, "No object class for entry (%s)\n", Debug( LDAP_DEBUG_ANY, "No object class for entry (%s)\n",
@ -40,6 +42,14 @@ oc_schema_check( Entry *e )
/* check that the entry has required attrs for each oc */ /* check that the entry has required attrs for each oc */
for ( i = 0; aoc->a_vals[i] != NULL; i++ ) { for ( i = 0; aoc->a_vals[i] != NULL; i++ ) {
if ( (oc = oc_find( aoc->a_vals[i]->bv_val )) == NULL ) {
Debug( LDAP_DEBUG_ANY,
"Objectclass \"%s\" not defined",
aoc->a_vals[i]->bv_val, 0, 0 );
ret = 1;
}
else
{
char *s = oc_check_required( e, aoc->a_vals[i]->bv_val ); char *s = oc_check_required( e, aoc->a_vals[i]->bv_val );
if (s != NULL) { if (s != NULL) {
@ -49,6 +59,7 @@ oc_schema_check( Entry *e )
ret = 1; ret = 1;
} }
} }
}
if ( ret != 0 ) { if ( ret != 0 ) {
return( ret ); return( ret );