2 Unix SMB/CIFS implementation.
4 common share info functions
6 Copyright (C) Andrew Tridgell 2004
7 Copyright (C) Tim Potter 2004
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/>.
24 #include "lib/ldb/include/ldb.h"
25 #include "../lib/util/util_ldb.h"
27 search the sam for the specified attributes - va_list variant
29 int gendb_search_v(struct ldb_context
*ldb
,
31 struct ldb_dn
*basedn
,
32 struct ldb_message
***msgs
,
33 const char * const *attrs
,
37 enum ldb_scope scope
= LDB_SCOPE_SUBTREE
;
38 struct ldb_result
*res
;
43 expr
= talloc_vasprintf(mem_ctx
, format
, ap
);
48 scope
= LDB_SCOPE_BASE
;
53 ret
= ldb_search(ldb
, mem_ctx
, &res
, basedn
, scope
, attrs
,
54 expr
?"%s":NULL
, expr
);
56 if (ret
== LDB_SUCCESS
) {
57 talloc_steal(mem_ctx
, res
->msgs
);
59 DEBUG(6,("gendb_search_v: %s %s -> %d\n",
60 basedn
?ldb_dn_get_linearized(basedn
):"NULL",
61 expr
?expr
:"NULL", res
->count
));
66 } else if (scope
== LDB_SCOPE_BASE
&& ret
== LDB_ERR_NO_SUCH_OBJECT
) {
70 DEBUG(4,("gendb_search_v: search failed: %s\n",
81 search the LDB for the specified attributes - varargs variant
83 int gendb_search(struct ldb_context
*ldb
,
85 struct ldb_dn
*basedn
,
86 struct ldb_message
***res
,
87 const char * const *attrs
,
88 const char *format
, ...)
94 count
= gendb_search_v(ldb
, mem_ctx
, basedn
, res
, attrs
, format
, ap
);
101 search the LDB for a specified record (by DN)
104 int gendb_search_dn(struct ldb_context
*ldb
,
107 struct ldb_message
***res
,
108 const char * const *attrs
)
110 return gendb_search(ldb
, mem_ctx
, dn
, res
, attrs
, NULL
);
114 setup some initial ldif in a ldb
116 int gendb_add_ldif(struct ldb_context
*ldb
, const char *ldif_string
)
118 struct ldb_ldif
*ldif
;
119 const char *s
= ldif_string
;
121 while (s
&& *s
!= '\0') {
122 ldif
= ldb_ldif_read_string(ldb
, &s
);
123 if (ldif
== NULL
) return -1;
124 ret
= ldb_add(ldb
, ldif
->msg
);
130 char *wrap_casefold(void *context
, void *mem_ctx
, const char *s
, size_t n
)
132 return strupper_talloc_n(mem_ctx
, s
, n
);
138 search the LDB for a single record, with the extended_dn control
139 return LDB_SUCCESS on success, or an ldb error code on error
141 if the search returns 0 entries, return LDB_ERR_NO_SUCH_OBJECT
142 if the search returns more than 1 entry, return LDB_ERR_CONSTRAINT_VIOLATION
144 int gendb_search_single_extended_dn(struct ldb_context
*ldb
,
146 struct ldb_dn
*basedn
,
147 enum ldb_scope scope
,
148 struct ldb_message
**msg
,
149 const char * const *attrs
,
150 const char *format
, ...)
154 struct ldb_request
*req
;
157 struct ldb_result
*res
;
158 struct ldb_extended_dn_control
*ctrl
;
160 tmp_ctx
= talloc_new(mem_ctx
);
162 res
= talloc_zero(tmp_ctx
, struct ldb_result
);
164 return LDB_ERR_OPERATIONS_ERROR
;
167 va_start(ap
, format
);
168 filter
= talloc_vasprintf(tmp_ctx
, format
, ap
);
171 if (filter
== NULL
) {
172 talloc_free(tmp_ctx
);
173 return LDB_ERR_OPERATIONS_ERROR
;
176 ret
= ldb_build_search_req(&req
, ldb
, tmp_ctx
,
183 ldb_search_default_callback
,
185 if (ret
!= LDB_SUCCESS
) {
186 talloc_free(tmp_ctx
);
190 ctrl
= talloc(tmp_ctx
, struct ldb_extended_dn_control
);
192 talloc_free(tmp_ctx
);
193 return LDB_ERR_OPERATIONS_ERROR
;
198 ret
= ldb_request_add_control(req
, LDB_CONTROL_EXTENDED_DN_OID
, true, ctrl
);
199 if (ret
!= LDB_SUCCESS
) {
203 ret
= ldb_request(ldb
, req
);
204 if (ret
== LDB_SUCCESS
) {
205 ret
= ldb_wait(req
->handle
, LDB_WAIT_ALL
);
208 if (ret
!= LDB_SUCCESS
) {
209 talloc_free(tmp_ctx
);
213 if (res
->count
== 0) {
214 talloc_free(tmp_ctx
);
215 return LDB_ERR_NO_SUCH_OBJECT
;
218 if (res
->count
> 1) {
219 /* the function is only supposed to return a single entry */
220 DEBUG(0,(__location__
": More than one return for baseDN %s filter %s\n",
221 ldb_dn_get_linearized(basedn
), filter
));
222 talloc_free(tmp_ctx
);
223 return LDB_ERR_CONSTRAINT_VIOLATION
;
226 *msg
= talloc_steal(mem_ctx
, res
->msgs
[0]);
228 talloc_free(tmp_ctx
);