2 ldb database library utility
4 Copyright (C) Matthieu Patou 2009
6 ** NOTE! The following LGPL license applies to the ldb
7 ** library. This does NOT imply that all of Samba is released
10 This library is free software; you can redistribute it and/or
11 modify it under the terms of the GNU Lesser General Public
12 License as published by the Free Software Foundation; either
13 version 3 of the License, or (at your option) any later version.
15 This library is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 Lesser General Public License for more details.
20 You should have received a copy of the GNU Lesser General Public
21 License along with this library; if not, see <http://www.gnu.org/licenses/>.
27 * Description: Common function used by ldb_add/ldb_modify/ldb_delete
29 * Author: Matthieu Patou
34 #include "ldb_module.h"
38 /* autostarts a transacion if none active */
39 static int ldb_do_autotransaction(struct ldb_context
*ldb
,
40 struct ldb_request
*req
)
44 ret
= ldb_transaction_start(ldb
);
45 if (ret
!= LDB_SUCCESS
) {
49 ret
= ldb_request(ldb
, req
);
50 if (ret
== LDB_SUCCESS
) {
51 ret
= ldb_wait(req
->handle
, LDB_WAIT_ALL
);
54 if (ret
== LDB_SUCCESS
) {
55 return ldb_transaction_commit(ldb
);
57 ldb_transaction_cancel(ldb
);
59 if (ldb_errstring(ldb
) == NULL
) {
60 /* no error string was setup by the backend */
61 ldb_asprintf_errstring(ldb
, "%s (%d)", ldb_strerror(ret
), ret
);
67 Same as ldb_add but accept control
69 int ldb_add_ctrl(struct ldb_context
*ldb
,
70 const struct ldb_message
*message
,
71 struct ldb_control
**controls
)
73 struct ldb_request
*req
;
76 ret
= ldb_msg_sanity_check(ldb
, message
);
77 if (ret
!= LDB_SUCCESS
) {
81 ret
= ldb_build_add_req(&req
, ldb
, ldb
,
85 ldb_op_default_callback
,
88 if (ret
!= LDB_SUCCESS
) return ret
;
90 /* do request and autostart a transaction */
91 ret
= ldb_do_autotransaction(ldb
, req
);
98 same as ldb_delete but accept control
100 int ldb_delete_ctrl(struct ldb_context
*ldb
, struct ldb_dn
*dn
,
101 struct ldb_control
**controls
)
103 struct ldb_request
*req
;
106 ret
= ldb_build_del_req(&req
, ldb
, ldb
,
110 ldb_op_default_callback
,
113 if (ret
!= LDB_SUCCESS
) return ret
;
115 /* do request and autostart a transaction */
116 ret
= ldb_do_autotransaction(ldb
, req
);
124 same as ldb_modify, but accepts controls
126 int ldb_modify_ctrl(struct ldb_context
*ldb
,
127 const struct ldb_message
*message
,
128 struct ldb_control
**controls
)
130 struct ldb_request
*req
;
133 ret
= ldb_msg_sanity_check(ldb
, message
);
134 if (ret
!= LDB_SUCCESS
) {
138 ret
= ldb_build_mod_req(&req
, ldb
, ldb
,
142 ldb_op_default_callback
,
145 if (ret
!= LDB_SUCCESS
) return ret
;
147 /* do request and autostart a transaction */
148 ret
= ldb_do_autotransaction(ldb
, req
);
156 ldb_search with controls
158 int ldb_search_ctrl(struct ldb_context
*ldb
, TALLOC_CTX
*mem_ctx
,
159 struct ldb_result
**result
, struct ldb_dn
*base
,
160 enum ldb_scope scope
, const char * const *attrs
,
161 struct ldb_control
**controls
,
162 const char *exp_fmt
, ...)
164 struct ldb_request
*req
;
165 struct ldb_result
*res
;
174 res
= talloc_zero(mem_ctx
, struct ldb_result
);
176 return LDB_ERR_OPERATIONS_ERROR
;
180 va_start(ap
, exp_fmt
);
181 expression
= talloc_vasprintf(mem_ctx
, exp_fmt
, ap
);
186 return LDB_ERR_OPERATIONS_ERROR
;
190 ret
= ldb_build_search_req(&req
, ldb
, mem_ctx
,
191 base
?base
:ldb_get_default_basedn(ldb
),
197 ldb_search_default_callback
,
199 ldb_req_set_location(req
, "ldb_search_ctrl");
201 if (ret
!= LDB_SUCCESS
) goto done
;
203 ret
= ldb_request(ldb
, req
);
205 if (ret
== LDB_SUCCESS
) {
206 ret
= ldb_wait(req
->handle
, LDB_WAIT_ALL
);
210 if (ret
!= LDB_SUCCESS
) {
215 talloc_free(expression
);