Make CryptImport/ExportPublicKeyInfoEx behave the way MSDN describes
[wine/gsoc-2012-control.git] / dlls / wldap32 / misc.c
blobf69832a51d5deee9e2fe454ed36332fb4012d9d9
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>
27 #include <stdio.h>
29 #include "windef.h"
30 #include "winbase.h"
31 #include "winnls.h"
33 #ifdef HAVE_LDAP_H
34 #include <ldap.h>
35 #else
36 #define LDAP_SUCCESS 0x00
37 #define LDAP_NOT_SUPPORTED 0x5c
38 #endif
40 #include "winldap_private.h"
41 #include "wldap32.h"
43 WINE_DEFAULT_DEBUG_CHANNEL(wldap32);
45 ULONG WLDAP32_ldap_abandon( WLDAP32_LDAP *ld, ULONG msgid )
47 ULONG ret = LDAP_NOT_SUPPORTED;
48 #ifdef HAVE_LDAP
50 TRACE( "(%p, 0x%08lx)\n", ld, msgid );
52 if (!ld) return ~0UL;
53 ret = ldap_abandon( ld, msgid );
55 #endif
56 return ret;
59 ULONG ldap_check_filterA( WLDAP32_LDAP *ld, PCHAR filter )
61 ULONG ret;
62 WCHAR *filterW = NULL;
64 TRACE( "(%p, %s)\n", ld, debugstr_a(filter) );
66 if (!ld) return WLDAP32_LDAP_PARAM_ERROR;
68 if (filter) {
69 filterW = strAtoW( filter );
70 if (!filterW) return WLDAP32_LDAP_NO_MEMORY;
73 ret = ldap_check_filterW( ld, filterW );
75 strfreeW( filterW );
76 return ret;
79 ULONG ldap_check_filterW( WLDAP32_LDAP *ld, PWCHAR filter )
81 TRACE( "(%p, %s)\n", ld, debugstr_w(filter) );
83 if (!ld) return WLDAP32_LDAP_PARAM_ERROR;
84 return LDAP_SUCCESS;
87 ULONG ldap_cleanup( HANDLE instance )
89 TRACE( "(%p)\n", instance );
90 return LDAP_SUCCESS;
93 WLDAP32_LDAP *ldap_conn_from_msg( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *res )
95 TRACE( "(%p, %p)\n", ld, res );
97 if (!ld || !res) return NULL;
98 return ld; /* FIXME: not always correct */
101 ULONG WLDAP32_ldap_count_entries( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *res )
103 ULONG ret = LDAP_NOT_SUPPORTED;
104 #ifdef HAVE_LDAP
106 TRACE( "(%p, %p)\n", ld, res );
108 if (!ld) return ~0UL;
109 ret = ldap_count_entries( ld, res );
111 #endif
112 return ret;
115 ULONG WLDAP32_ldap_count_references( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *res )
117 ULONG ret = LDAP_NOT_SUPPORTED;
118 #ifdef HAVE_LDAP
120 TRACE( "(%p, %p)\n", ld, res );
122 if (!ld) return 0;
123 ret = ldap_count_references( ld, res );
125 #endif
126 return ret;
129 static ULONG get_escape_size( PCHAR src, ULONG srclen )
131 ULONG i, size = 0;
133 if (src)
135 for (i = 0; i < srclen; i++)
137 if ((src[i] >= '0' && src[i] <= '9') ||
138 (src[i] >= 'A' && src[i] <= 'Z') ||
139 (src[i] >= 'a' && src[i] <= 'z'))
140 size++;
141 else
142 size += 3;
145 return size + 1;
148 static void escape_filter_element( PCHAR src, ULONG srclen, PCHAR dst )
150 ULONG i;
151 char fmt[] = "\\%02X";
152 char *d = dst;
154 for (i = 0; i < srclen; i++)
156 if ((src[i] >= '0' && src[i] <= '9') ||
157 (src[i] >= 'A' && src[i] <= 'Z') ||
158 (src[i] >= 'a' && src[i] <= 'z'))
159 *d++ = src[i];
160 else
162 sprintf( d, fmt, (unsigned char)src[i] );
163 d += 3;
166 *++d = 0;
169 ULONG ldap_escape_filter_elementA( PCHAR src, ULONG srclen, PCHAR dst, ULONG dstlen )
171 ULONG len;
173 TRACE( "(%p, 0x%08lx, %p, 0x%08lx)\n", src, srclen, dst, dstlen );
175 len = get_escape_size( src, srclen );
176 if (!dst) return len;
178 if (!src || dstlen < len)
179 return WLDAP32_LDAP_PARAM_ERROR;
180 else
182 escape_filter_element( src, srclen, dst );
183 return LDAP_SUCCESS;
187 ULONG ldap_escape_filter_elementW( PCHAR src, ULONG srclen, PWCHAR dst, ULONG dstlen )
189 ULONG len;
191 TRACE( "(%p, 0x%08lx, %p, 0x%08lx)\n", src, srclen, dst, dstlen );
193 len = get_escape_size( src, srclen );
194 if (!dst) return len;
196 /* no matter what you throw at it, this is what native returns */
197 return WLDAP32_LDAP_PARAM_ERROR;
200 PCHAR ldap_first_attributeA( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *entry,
201 WLDAP32_BerElement** ptr )
203 PCHAR ret = NULL;
204 #ifdef HAVE_LDAP
205 WCHAR *retW;
207 TRACE( "(%p, %p, %p)\n", ld, entry, ptr );
209 if (!ld || !entry) return NULL;
210 retW = ldap_first_attributeW( ld, entry, ptr );
212 ret = strWtoA( retW );
213 ldap_memfreeW( retW );
215 #endif
216 return ret;
219 PWCHAR ldap_first_attributeW( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *entry,
220 WLDAP32_BerElement** ptr )
222 PWCHAR ret = NULL;
223 #ifdef HAVE_LDAP
224 char *retU;
226 TRACE( "(%p, %p, %p)\n", ld, entry, ptr );
228 if (!ld || !entry) return NULL;
229 retU = ldap_first_attribute( ld, entry, ptr );
231 ret = strUtoW( retU );
232 ldap_memfree( retU );
234 #endif
235 return ret;
238 WLDAP32_LDAPMessage *WLDAP32_ldap_first_entry( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *res )
240 #ifdef HAVE_LDAP
242 TRACE( "(%p, %p)\n", ld, res );
244 if (!ld || !res) return NULL;
245 return ldap_first_entry( ld, res );
247 #endif
248 return NULL;
251 WLDAP32_LDAPMessage *WLDAP32_ldap_first_reference( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *res )
253 #ifdef HAVE_LDAP
255 TRACE( "(%p, %p)\n", ld, res );
257 if (!ld) return NULL;
258 return ldap_first_reference( ld, res );
260 #endif
261 return NULL;
264 void ldap_memfreeA( PCHAR block )
266 TRACE( "(%p)\n", block );
267 strfreeA( block );
270 void ldap_memfreeW( PWCHAR block )
272 TRACE( "(%p)\n", block );
273 strfreeW( block );
276 ULONG WLDAP32_ldap_msgfree( WLDAP32_LDAPMessage *res )
278 ULONG ret = LDAP_SUCCESS;
279 #ifdef HAVE_LDAP
281 TRACE( "(%p)\n", res );
282 ldap_msgfree( res );
284 #endif
285 return ret;
288 PCHAR ldap_next_attributeA( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *entry,
289 WLDAP32_BerElement *ptr )
291 PCHAR ret = NULL;
292 #ifdef HAVE_LDAP
293 WCHAR *retW;
295 TRACE( "(%p, %p, %p)\n", ld, entry, ptr );
297 if (!ld || !entry || !ptr) return NULL;
298 retW = ldap_next_attributeW( ld, entry, ptr );
300 ret = strWtoA( retW );
301 ldap_memfreeW( retW );
303 #endif
304 return ret;
307 PWCHAR ldap_next_attributeW( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *entry,
308 WLDAP32_BerElement *ptr )
310 PWCHAR ret = NULL;
311 #ifdef HAVE_LDAP
312 char *retU;
314 TRACE( "(%p, %p, %p)\n", ld, entry, ptr );
316 if (!ld || !entry || !ptr) return NULL;
317 retU = ldap_next_attribute( ld, entry, ptr );
319 ret = strUtoW( retU );
320 ldap_memfree( retU );
322 #endif
323 return ret;
326 WLDAP32_LDAPMessage *WLDAP32_ldap_next_entry( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *entry )
328 #ifdef HAVE_LDAP
330 TRACE( "(%p, %p)\n", ld, entry );
332 if (!ld || !entry) return NULL;
333 return ldap_next_entry( ld, entry );
335 #endif
336 return NULL;
339 WLDAP32_LDAPMessage *WLDAP32_ldap_next_reference( WLDAP32_LDAP *ld, WLDAP32_LDAPMessage *entry )
341 #ifdef HAVE_LDAP
343 TRACE( "(%p, %p)\n", ld, entry );
345 if (!ld || !entry) return NULL;
346 return ldap_next_reference( ld, entry );
348 #endif
349 return NULL;
352 ULONG WLDAP32_ldap_result( WLDAP32_LDAP *ld, ULONG msgid, ULONG all,
353 struct l_timeval *timeout, WLDAP32_LDAPMessage **res )
355 ULONG ret = WLDAP32_LDAP_NOT_SUPPORTED;
356 #ifdef HAVE_LDAP
358 TRACE( "(%p, 0x%08lx, 0x%08lx, %p, %p)\n", ld, msgid, all, timeout, res );
360 if (!ld || !res) return ~0UL;
361 ret = ldap_result( ld, msgid, all, (struct timeval *)timeout, res );
363 #endif
364 return ret;
367 int LdapUnicodeToUTF8( LPCWSTR src, int srclen, LPSTR dst, int dstlen )
369 return WideCharToMultiByte( CP_UTF8, 0, src, srclen, dst, dstlen, NULL, NULL );
372 int LdapUTF8ToUnicode( LPCSTR src, int srclen, LPWSTR dst, int dstlen )
374 return MultiByteToWideChar( CP_UTF8, 0, src, srclen, dst, dstlen );