2 Unix SMB/CIFS implementation.
3 ldap filter argument escaping
5 Copyright (C) 1998, 1999, 2000 Luke Howard <lukeh@padl.com>,
6 Copyright (C) 2003 Andrew Bartlett <abartlet@samba.org>
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 3 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program. If not, see <http://www.gnu.org/licenses/>.
26 * Escape a parameter to an LDAP filter string, so they cannot contain
27 * embedded ( ) * or \ chars which may cause it not to parse correctly.
29 * @param s The input string
31 * @return A string allocated with talloc(), containing the escaped string,
32 * and to be talloc_free()ed by the caller.
35 char *escape_ldap_string(TALLOC_CTX
*mem_ctx
, const char *s
)
37 size_t len
= strlen(s
)+1;
38 char *output
= talloc_array(mem_ctx
, char, len
);
71 tmp
= talloc_realloc(mem_ctx
, output
, char, len
);
95 char *escape_rdn_val_string_alloc(const char *s
)
99 /* The maximum size of the escaped string can be twice the actual size */
100 output
= (char *)SMB_MALLOC(2*strlen(s
) + 1);
102 if (output
== NULL
) {
134 /* resize the string to the actual final size */
135 output
= (char *)SMB_REALLOC(output
, strlen(output
) + 1);