/* add.c - ldap backend add function */ /* $OpenLDAP$ */ /* * Copyright 1998-2000 The OpenLDAP Foundation, All Rights Reserved. * COPYING RESTRICTIONS APPLY, see COPYRIGHT file */ /* This is an altered version */ /* * Copyright 1999, Howard Chu, All rights reserved. * * Permission is granted to anyone to use this software for any purpose * on any computer system, and to alter it and redistribute it, subject * to the following restrictions: * * 1. The author is not responsible for the consequences of use of this * software, no matter how awful, even if they arise from flaws in it. * * 2. The origin of this software must not be misrepresented, either by * explicit claim or by omission. Since few users ever read sources, * credits should appear in the documentation. * * 3. Altered versions must be plainly marked as such, and must not be * misrepresented as being the original software. Since few users * ever read sources, credits should appear in the documentation. * * 4. This notice may not be removed or altered. * * * * Copyright 2000, Pierangelo Masarati, All rights reserved. * * This software is being modified by Pierangelo Masarati. * The previously reported conditions apply to the modified code as well. * Changes in the original code are highlighted where required. * Credits for the original code go to the author, Howard Chu. */ #include "portable.h" #include #include #include #include "slap.h" #include "back-ldap.h" int ldap_back_add( Backend *be, Connection *conn, Operation *op, Entry *e ) { struct ldapinfo *li = (struct ldapinfo *) be->be_private; struct ldapconn *lc; int i; Attribute *a; LDAPMod **attrs; char *mdn, *mapped; lc = ldap_back_getconn(li, conn, op); if ( !lc || !ldap_back_dobind( lc, op ) ) { return( -1 ); } mdn = ldap_back_dn_massage( li, ch_strdup( e->e_dn ), 0 ); if ( mdn == NULL ) { return( -1 ); } /* Count number of attributes in entry */ for (i = 1, a = e->e_attrs; a; i++, a = a->a_next) ; /* Create array of LDAPMods for ldap_add() */ attrs = (LDAPMod **)ch_malloc(sizeof(LDAPMod *)*i); for (i=0, a=e->e_attrs; a; a=a->a_next) { mapped = ldap_back_map(&li->at_map, a->a_desc->ad_cname->bv_val, 0); if (mapped != NULL) { attrs[i] = (LDAPMod *)ch_malloc(sizeof(LDAPMod)); if (attrs[i] != NULL) { attrs[i]->mod_op = LDAP_MOD_BVALUES; attrs[i]->mod_type = mapped; attrs[i]->mod_vals.modv_bvals = a->a_vals; i++; } } } attrs[i] = NULL; ldap_add_s(lc->ld, mdn, attrs); for (--i; i>= 0; --i) free(attrs[i]); free(attrs); free( mdn ); return( ldap_back_op_result( lc, op )); }