X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fadd.c;h=db9b809752342a1baf28f6fe5afdf6c8dadb1d6d;hb=b73915d36f568d349061f60d27fbcc102ecf374a;hp=b69f7a720dedc6c5f4893d21c83132018e30b3bd;hpb=78172aa0cf52dd5beb8994c10ba5ea6bd18a5e65;p=openldap diff --git a/servers/slapd/add.c b/servers/slapd/add.c index b69f7a720d..db9b809752 100644 --- a/servers/slapd/add.c +++ b/servers/slapd/add.c @@ -1,7 +1,7 @@ /* $OpenLDAP$ */ /* This work is part of OpenLDAP Software . * - * Copyright 1998-2006 The OpenLDAP Foundation. + * Copyright 1998-2007 The OpenLDAP Foundation. * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -157,7 +157,7 @@ do_add( Operation *op, SlapReply *rs ) goto done; } - rs->sr_err = slap_mods_check( modlist, &rs->sr_text, + rs->sr_err = slap_mods_check( op, modlist, &rs->sr_text, textbuf, textlen, NULL ); if ( rs->sr_err != LDAP_SUCCESS ) { @@ -315,7 +315,7 @@ fe_op_add( Operation *op, SlapReply *rs ) } - /* check for duplicate values */ + /* check for unmodifiable attributes */ rs->sr_err = slap_mods_no_repl_user_mod_check( op, op->ora_modlist, &rs->sr_text, textbuf, textlen ); if ( rs->sr_err != LDAP_SUCCESS ) { @@ -323,13 +323,6 @@ fe_op_add( Operation *op, SlapReply *rs ) goto done; } - rs->sr_err = slap_mods2entry( *modtail, &op->ora_e, - 0, 0, &rs->sr_text, textbuf, textlen ); - if ( rs->sr_err != LDAP_SUCCESS ) { - send_ldap_result( op, rs ); - goto done; - } - cb.sc_next = op->o_callback; op->o_callback = &cb; } @@ -431,7 +424,7 @@ slap_mods2entry( attr->a_vals = ch_realloc( attr->a_vals, sizeof( struct berval ) * (i+j) ); - /* should check for duplicates */ + /* checked for duplicates in slap_mods_check */ if ( dup ) { for ( j = 0; mods->sml_values[j].bv_val; j++ ) { @@ -470,46 +463,9 @@ slap_mods2entry( #endif } - if( mods->sml_values[1].bv_val != NULL ) { - /* check for duplicates */ - int i, j, rc, match; - MatchingRule *mr = mods->sml_desc->ad_type->sat_equality; - - for ( i = 1; mods->sml_values[i].bv_val != NULL; i++ ) { - /* test asserted values against themselves */ - for( j = 0; j < i; j++ ) { - rc = ordered_value_match( &match, mods->sml_desc, mr, - SLAP_MR_EQUALITY - | SLAP_MR_VALUE_OF_ATTRIBUTE_SYNTAX - | SLAP_MR_ASSERTED_VALUE_NORMALIZED_MATCH - | SLAP_MR_ATTRIBUTE_VALUE_NORMALIZED_MATCH, - mods->sml_nvalues - ? &mods->sml_nvalues[i] - : &mods->sml_values[i], - mods->sml_nvalues - ? &mods->sml_nvalues[j] - : &mods->sml_values[j], - text ); - - if ( rc == LDAP_SUCCESS && match == 0 ) { - /* value exists already */ - snprintf( textbuf, textlen, - "%s: value #%d provided more than once", - mods->sml_desc->ad_cname.bv_val, j ); - *text = textbuf; - return LDAP_TYPE_OR_VALUE_EXISTS; - - } else if ( rc != LDAP_SUCCESS ) { - return rc; - } - } - } - } - attr = attr_alloc( mods->sml_desc ); /* move values to attr structure */ - /* should check for duplicates */ if ( dup ) { int i; for ( i = 0; mods->sml_values[i].bv_val; i++ ) /* EMPTY */; @@ -628,24 +584,6 @@ int slap_add_opattrs( char csnbuf[ LDAP_LUTIL_CSNSTR_BUFSIZE ]; Attribute *a; - a = attr_find( op->ora_e->e_attrs, - slap_schema.si_ad_structuralObjectClass ); - - if ( !a ) { - Attribute *oc; - int rc; - - oc = attr_find( op->ora_e->e_attrs, slap_schema.si_ad_objectClass ); - if ( oc ) { - rc = structural_class( oc->a_vals, &tmp, NULL, text, - textbuf, textlen ); - if( rc != LDAP_SUCCESS ) return rc; - - attr_merge_one( op->ora_e, slap_schema.si_ad_structuralObjectClass, - &tmp, NULL ); - } - } - if ( SLAP_LASTMOD( op->o_bd ) ) { char *ptr; int gotcsn = 0; @@ -736,5 +674,6 @@ int slap_add_opattrs( slap_schema.si_ad_modifyTimestamp, ×tamp, NULL ); } } + return LDAP_SUCCESS; }