Modifications *mods = NULL;
const char *text;
int rc = LDAP_SUCCESS;
- struct berval **urls = NULL;
Debug( LDAP_DEBUG_TRACE, "do_add\n", 0, 0, 0 );
}
/* check for referrals */
- rc = backend_check_referrals( be, conn, op, &urls, &text );
+ rc = backend_check_referrals( be, conn, op, e->e_dn, e->e_ndn );
if ( rc != LDAP_SUCCESS ) {
- send_ldap_result( conn, op, rc,
- NULL, text, urls, NULL );
- ber_bvecfree( urls );
goto done;
}
attr = attr_find( (*e)->e_attrs, mods->sml_desc );
if( attr != NULL ) {
+#define SLURPD_FRIENDLY
+#ifdef SLURPD_FRIENDLY
+ ber_len_t i,j;
+
+ for( i=0; attr->a_vals[i]; i++ ) {
+ /* count them */
+ }
+ for( j=0; mods->sml_bvalues[j]; j++ ) {
+ /* count them */
+ }
+ j++; /* NULL */
+
+ attr->a_vals = ch_realloc( attr->a_vals,
+ sizeof( struct berval * ) * (i+j) );
+
+ /* should check for duplicates */
+ memcpy( &attr->a_vals[i], mods->sml_bvalues,
+ sizeof( struct berval * ) * j );
+
+ /* trim the mods array */
+ ch_free( mods->sml_bvalues );
+ mods->sml_bvalues = NULL;
+
+ continue;
+#else
*text = "attribute provided more than once";
- return LDAP_OPERATIONS_ERROR;
+ return LDAP_TYPE_OR_VALUE_EXISTS;
+#endif
}
attr = ch_calloc( 1, sizeof(Attribute) );