ole32: Create moniker enumerator with an initial reference count.
[wine/multimedia.git] / dlls / wldap32 / add.c
blobf9ea06d55a503bee2730e8e7e4c47e786761758e
1 /*
2 * WLDAP32 - LDAP support for Wine
4 * Copyright 2005 Hans Leidekker
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 #include "config.h"
23 #include "wine/port.h"
24 #include "wine/debug.h"
26 #include <stdarg.h>
28 #include "windef.h"
29 #include "winbase.h"
30 #include "winnls.h"
32 #ifdef HAVE_LDAP_H
33 #include <ldap.h>
34 static LDAPMod *nullattrs[] = { NULL };
35 #else
36 #define LDAP_NOT_SUPPORTED 0x5c
37 #endif
39 #include "winldap_private.h"
40 #include "wldap32.h"
42 WINE_DEFAULT_DEBUG_CHANNEL(wldap32);
44 /***********************************************************************
45 * ldap_addA (WLDAP32.@)
47 * See ldap_addW.
49 ULONG ldap_addA( WLDAP32_LDAP *ld, PCHAR dn, LDAPModA *attrs[] )
51 ULONG ret = LDAP_NOT_SUPPORTED;
52 #ifdef HAVE_LDAP
53 WCHAR *dnW = NULL;
54 LDAPModW **attrsW = NULL;
56 ret = WLDAP32_LDAP_NO_MEMORY;
58 TRACE( "(%p, %s, %p)\n", ld, debugstr_a(dn), attrs );
60 if (!ld) return ~0UL;
62 if (dn) {
63 dnW = strAtoW( dn );
64 if (!dnW) goto exit;
66 if (attrs) {
67 attrsW = modarrayAtoW( attrs );
68 if (!attrsW) goto exit;
71 ret = ldap_addW( ld, dnW, attrsW );
73 exit:
74 strfreeW( dnW );
75 modarrayfreeW( attrsW );
77 #endif
78 return ret;
81 /***********************************************************************
82 * ldap_addW (WLDAP32.@)
84 * Add an entry to a directory tree (asynchronous operation).
86 * PARAMS
87 * ld [I] Pointer to an LDAP context.
88 * dn [I] DN of the entry to add.
89 * attrs [I] Pointer to an array of LDAPModW structures, each
90 * specifying an attribute and its values to add.
92 * RETURNS
93 * Success: Message ID of the add operation.
94 * Failure: An LDAP error code.
96 * NOTES
97 * Call ldap_result with the message ID to get the result of
98 * the operation. Cancel the operation by calling ldap_abandon
99 * with the message ID.
101 ULONG ldap_addW( WLDAP32_LDAP *ld, PWCHAR dn, LDAPModW *attrs[] )
103 ULONG ret = LDAP_NOT_SUPPORTED;
104 #ifdef HAVE_LDAP
105 char *dnU = NULL;
106 LDAPMod **attrsU = NULL;
107 int msg;
109 ret = WLDAP32_LDAP_NO_MEMORY;
111 TRACE( "(%p, %s, %p)\n", ld, debugstr_w(dn), attrs );
113 if (!ld) return WLDAP32_LDAP_PARAM_ERROR;
115 if (dn) {
116 dnU = strWtoU( dn );
117 if (!dnU) goto exit;
119 if (attrs) {
120 attrsU = modarrayWtoU( attrs );
121 if (!attrsU) goto exit;
124 ret = ldap_add_ext( ld, dn ? dnU : "", attrs ? attrsU : nullattrs, NULL, NULL, &msg );
126 if (ret == LDAP_SUCCESS)
127 ret = msg;
128 else
129 ret = ~0UL;
131 exit:
132 strfreeU( dnU );
133 modarrayfreeU( attrsU );
135 #endif
136 return ret;
139 /***********************************************************************
140 * ldap_add_extA (WLDAP32.@)
142 * See ldap_add_extW.
144 ULONG ldap_add_extA( WLDAP32_LDAP *ld, PCHAR dn, LDAPModA *attrs[],
145 PLDAPControlA *serverctrls, PLDAPControlA *clientctrls, ULONG *message )
147 ULONG ret = LDAP_NOT_SUPPORTED;
148 #ifdef HAVE_LDAP
149 WCHAR *dnW = NULL;
150 LDAPModW **attrsW = NULL;
151 LDAPControlW **serverctrlsW = NULL, **clientctrlsW = NULL;
153 ret = WLDAP32_LDAP_NO_MEMORY;
155 TRACE( "(%p, %s, %p, %p, %p, %p)\n", ld, debugstr_a(dn), attrs,
156 serverctrls, clientctrls, message );
158 if (!ld) return WLDAP32_LDAP_PARAM_ERROR;
160 if (dn) {
161 dnW = strAtoW( dn );
162 if (!dnW) goto exit;
164 if (attrs) {
165 attrsW = modarrayAtoW( attrs );
166 if (!attrsW) goto exit;
168 if (serverctrls) {
169 serverctrlsW = controlarrayAtoW( serverctrls );
170 if (!serverctrlsW) goto exit;
172 if (clientctrls) {
173 clientctrlsW = controlarrayAtoW( clientctrls );
174 if (!clientctrlsW) goto exit;
177 ret = ldap_add_extW( ld, dnW, attrsW, serverctrlsW, clientctrlsW, message );
179 exit:
180 strfreeW( dnW );
181 modarrayfreeW( attrsW );
182 controlarrayfreeW( serverctrlsW );
183 controlarrayfreeW( clientctrlsW );
185 #endif
186 return ret;
189 /***********************************************************************
190 * ldap_add_extW (WLDAP32.@)
192 * Add an entry to a directory tree (asynchronous operation).
194 * PARAMS
195 * ld [I] Pointer to an LDAP context.
196 * dn [I] DN of the entry to add.
197 * attrs [I] Pointer to an array of LDAPModW structures, each
198 * specifying an attribute and its values to add.
199 * serverctrls [I] Array of LDAP server controls.
200 * clientctrls [I] Array of LDAP client controls.
201 * message [O] Message ID of the add operation.
203 * RETURNS
204 * Success: LDAP_SUCCESS
205 * Failure: An LDAP error code.
207 * NOTES
208 * Call ldap_result with the message ID to get the result of
209 * the operation. The serverctrls and clientctrls parameters are
210 * optional and should be set to NULL if not used.
212 ULONG ldap_add_extW( WLDAP32_LDAP *ld, PWCHAR dn, LDAPModW *attrs[],
213 PLDAPControlW *serverctrls, PLDAPControlW *clientctrls, ULONG *message )
215 ULONG ret = LDAP_NOT_SUPPORTED;
216 #ifdef HAVE_LDAP
217 char *dnU = NULL;
218 LDAPMod **attrsU = NULL;
219 LDAPControl **serverctrlsU = NULL, **clientctrlsU = NULL;
220 int dummy;
222 ret = WLDAP32_LDAP_NO_MEMORY;
224 TRACE( "(%p, %s, %p, %p, %p, %p)\n", ld, debugstr_w(dn), attrs,
225 serverctrls, clientctrls, message );
227 if (!ld) return WLDAP32_LDAP_PARAM_ERROR;
229 if (dn) {
230 dnU = strWtoU( dn );
231 if (!dnU) goto exit;
233 if (attrs) {
234 attrsU = modarrayWtoU( attrs );
235 if (!attrsU) goto exit;
237 if (serverctrls) {
238 serverctrlsU = controlarrayWtoU( serverctrls );
239 if (!serverctrlsU) goto exit;
241 if (clientctrls) {
242 clientctrlsU = controlarrayWtoU( clientctrls );
243 if (!clientctrlsU) goto exit;
246 ret = ldap_add_ext( ld, dn ? dnU : "", attrs ? attrsU : nullattrs, serverctrlsU,
247 clientctrlsU, message ? (int *)message : &dummy );
249 exit:
250 strfreeU( dnU );
251 modarrayfreeU( attrsU );
252 controlarrayfreeU( serverctrlsU );
253 controlarrayfreeU( clientctrlsU );
255 #endif
256 return ret;
259 /***********************************************************************
260 * ldap_add_ext_sA (WLDAP32.@)
262 * See ldap_add_ext_sW.
264 ULONG ldap_add_ext_sA( WLDAP32_LDAP *ld, PCHAR dn, LDAPModA *attrs[],
265 PLDAPControlA *serverctrls, PLDAPControlA *clientctrls )
267 ULONG ret = LDAP_NOT_SUPPORTED;
268 #ifdef HAVE_LDAP
269 WCHAR *dnW = NULL;
270 LDAPModW **attrsW = NULL;
271 LDAPControlW **serverctrlsW = NULL, **clientctrlsW = NULL;
273 ret = WLDAP32_LDAP_NO_MEMORY;
275 TRACE( "(%p, %s, %p, %p, %p)\n", ld, debugstr_a(dn), attrs,
276 serverctrls, clientctrls );
278 if (!ld) return WLDAP32_LDAP_PARAM_ERROR;
280 if (dn) {
281 dnW = strAtoW( dn );
282 if (!dnW) goto exit;
284 if (attrs) {
285 attrsW = modarrayAtoW( attrs );
286 if (!attrsW) goto exit;
288 if (serverctrls) {
289 serverctrlsW = controlarrayAtoW( serverctrls );
290 if (!serverctrlsW) goto exit;
292 if (clientctrls) {
293 clientctrlsW = controlarrayAtoW( clientctrls );
294 if (!clientctrlsW) goto exit;
297 ret = ldap_add_ext_sW( ld, dnW, attrsW, serverctrlsW, clientctrlsW );
299 exit:
300 strfreeW( dnW );
301 modarrayfreeW( attrsW );
302 controlarrayfreeW( serverctrlsW );
303 controlarrayfreeW( clientctrlsW );
305 #endif
306 return ret;
309 /***********************************************************************
310 * ldap_add_ext_sW (WLDAP32.@)
312 * Add an entry to a directory tree (synchronous operation).
314 * PARAMS
315 * ld [I] Pointer to an LDAP context.
316 * dn [I] DN of the entry to add.
317 * attrs [I] Pointer to an array of LDAPModW structures, each
318 * specifying an attribute and its values to add.
319 * serverctrls [I] Array of LDAP server controls.
320 * clientctrls [I] Array of LDAP client controls.
322 * RETURNS
323 * Success: LDAP_SUCCESS
324 * Failure: An LDAP error code.
326 * NOTES
327 * The serverctrls and clientctrls parameters are optional and
328 * should be set to NULL if not used.
330 ULONG ldap_add_ext_sW( WLDAP32_LDAP *ld, PWCHAR dn, LDAPModW *attrs[],
331 PLDAPControlW *serverctrls, PLDAPControlW *clientctrls )
333 ULONG ret = LDAP_NOT_SUPPORTED;
334 #ifdef HAVE_LDAP
335 char *dnU = NULL;
336 LDAPMod **attrsU = NULL;
337 LDAPControl **serverctrlsU = NULL, **clientctrlsU = NULL;
339 ret = WLDAP32_LDAP_NO_MEMORY;
341 TRACE( "(%p, %s, %p, %p, %p)\n", ld, debugstr_w(dn), attrs,
342 serverctrls, clientctrls );
344 if (!ld) return WLDAP32_LDAP_PARAM_ERROR;
346 if (dn) {
347 dnU = strWtoU( dn );
348 if (!dnU) goto exit;
350 if (attrs) {
351 attrsU = modarrayWtoU( attrs );
352 if (!attrsU) goto exit;
354 if (serverctrls) {
355 serverctrlsU = controlarrayWtoU( serverctrls );
356 if (!serverctrlsU) goto exit;
358 if (clientctrls) {
359 clientctrlsU = controlarrayWtoU( clientctrls );
360 if (!clientctrlsU) goto exit;
363 ret = ldap_add_ext_s( ld, dn ? dnU : "", attrs ? attrsU : nullattrs,
364 serverctrlsU, clientctrlsU );
366 exit:
367 strfreeU( dnU );
368 modarrayfreeU( attrsU );
369 controlarrayfreeU( serverctrlsU );
370 controlarrayfreeU( clientctrlsU );
372 #endif
373 return ret;
376 /***********************************************************************
377 * ldap_add_sA (WLDAP32.@)
379 * See ldap_add_sW.
381 ULONG ldap_add_sA( WLDAP32_LDAP *ld, PCHAR dn, LDAPModA *attrs[] )
383 ULONG ret = LDAP_NOT_SUPPORTED;
384 #ifdef HAVE_LDAP
385 WCHAR *dnW = NULL;
386 LDAPModW **attrsW = NULL;
388 ret = WLDAP32_LDAP_NO_MEMORY;
390 TRACE( "(%p, %s, %p)\n", ld, debugstr_a(dn), attrs );
392 if (!ld) return WLDAP32_LDAP_PARAM_ERROR;
394 if (dn) {
395 dnW = strAtoW( dn );
396 if (!dnW) goto exit;
398 if (attrs) {
399 attrsW = modarrayAtoW( attrs );
400 if (!attrsW) goto exit;
403 ret = ldap_add_sW( ld, dnW, attrsW );
405 exit:
406 strfreeW( dnW );
407 modarrayfreeW( attrsW );
409 #endif
410 return ret;
413 /***********************************************************************
414 * ldap_add_sW (WLDAP32.@)
416 * Add an entry to a directory tree (synchronous operation).
418 * PARAMS
419 * ld [I] Pointer to an LDAP context.
420 * dn [I] DN of the entry to add.
421 * attrs [I] Pointer to an array of LDAPModW structures, each
422 * specifying an attribute and its values to add.
424 * RETURNS
425 * Success: LDAP_SUCCESS
426 * Failure: An LDAP error code.
428 ULONG ldap_add_sW( WLDAP32_LDAP *ld, PWCHAR dn, LDAPModW *attrs[] )
430 ULONG ret = LDAP_NOT_SUPPORTED;
431 #ifdef HAVE_LDAP
432 char *dnU = NULL;
433 LDAPMod **attrsU = NULL;
435 ret = WLDAP32_LDAP_NO_MEMORY;
437 TRACE( "(%p, %s, %p)\n", ld, debugstr_w(dn), attrs );
439 if (!ld) return WLDAP32_LDAP_PARAM_ERROR;
441 if (dn) {
442 dnU = strWtoU( dn );
443 if (!dnU) goto exit;
445 if (attrs) {
446 attrsU = modarrayWtoU( attrs );
447 if (!attrsU) goto exit;
450 ret = ldap_add_ext_s( ld, dn ? dnU : "", attrs ? attrsU : nullattrs, NULL, NULL );
452 exit:
453 strfreeU( dnU );
454 modarrayfreeU( attrsU );
456 #endif
457 return ret;