2 Unix SMB/CIFS implementation.
4 provide hooks into smbd C calls from ejs scripts
6 Copyright (C) Andrew Tridgell 2005
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
24 #include "scripting/ejs/smbcalls.h"
25 #include "lib/appweb/ejs/ejs.h"
26 #include "lib/ldb/include/ldb.h"
31 static struct ldb_context *ejs_get_ldb_context(int eid)
33 struct ldb_context *ldb = mprGetThisPtr(eid, "db");
35 ejsSetErrorMsg(eid, "invalid ldb connection");
41 perform an ldb search, returning an array of results
44 res = ldb.search("expression");
45 var attrs = new Array("attr1", "attr2", "attr3");
46 ldb.search("expression", attrs);
47 var basedn = "cn=this,dc=is,dc=a,dc=test";
48 ldb.search("expression", attrs, ldb.SCOPE_SUBTREE, basedn);
50 static int ejs_ldbSearch(MprVarHandle eid, int argc, struct MprVar **argv)
52 const char **attrs = NULL;
53 const char *expression;
54 const char *base = NULL;
55 struct ldb_dn *basedn = NULL;
56 int scope = LDB_SCOPE_DEFAULT;
57 TALLOC_CTX *tmp_ctx = talloc_new(mprMemCtx());
58 struct ldb_context *ldb;
60 struct ldb_message **res;
62 /* validate arguments */
63 if (argc < 1 || argc > 4) {
64 ejsSetErrorMsg(eid, "ldb.search invalid number of arguments");
67 if (argc > 3 && argv[3]->type != MPR_TYPE_OBJECT) {
68 ejsSetErrorMsg(eid, "ldb.search attributes must be an object");
72 ldb = ejs_get_ldb_context(eid);
77 expression = mprToString(argv[0]);
79 base = mprToString(argv[1]);
80 /* a null basedn is valid */
83 basedn = ldb_dn_explode(tmp_ctx, base);
85 ejsSetErrorMsg(eid, "ldb.search malformed base dn");
90 scope = mprToInt(argv[2]);
92 case LDB_SCOPE_DEFAULT:
94 case LDB_SCOPE_ONELEVEL:
95 case LDB_SCOPE_SUBTREE:
98 ejsSetErrorMsg(eid, "ldb.search invalid scope");
103 attrs = mprToList(tmp_ctx, argv[3]);
105 ret = ldb_search(ldb, basedn, scope, expression, attrs, &res);
107 ejsSetErrorMsg(eid, "ldb.search failed - %s", ldb_errstring(ldb));
108 mpr_Return(eid, mprCreateUndefinedVar());
110 mpr_Return(eid, mprLdbArray(ldb, res, ret, "ldb_message"));
113 talloc_free(tmp_ctx);
117 talloc_free(tmp_ctx);
123 perform an ldb add or modify
125 static int ejs_ldbAddModify(MprVarHandle eid, int argc, struct MprVar **argv,
126 int fn(struct ldb_context *, const struct ldb_message *))
128 const char *ldifstring;
129 struct ldb_context *ldb;
130 struct ldb_ldif *ldif;
134 ejsSetErrorMsg(eid, "ldb.add/modify invalid arguments");
138 ldifstring = mprToString(argv[0]);
139 if (ldifstring == NULL) {
140 ejsSetErrorMsg(eid, "ldb.add/modify invalid arguments");
144 ldb = ejs_get_ldb_context(eid);
149 while ((ldif = ldb_ldif_read_string(ldb, &ldifstring))) {
150 ret = fn(ldb, ldif->msg);
155 mpr_Return(eid, mprCreateBoolVar(ret == 0));
161 perform an ldb delete
165 static int ejs_ldbDelete(MprVarHandle eid, int argc, struct MprVar **argv)
168 struct ldb_context *ldb;
172 ejsSetErrorMsg(eid, "ldb.delete invalid arguments");
176 ldb = ejs_get_ldb_context(eid);
181 dn = ldb_dn_explode(ldb, mprToString(argv[0]));
183 ejsSetErrorMsg(eid, "ldb.delete malformed dn");
187 ret = ldb_delete(ldb, dn);
191 mpr_Return(eid, mprCreateBoolVar(ret == 0));
196 perform an ldb rename
198 ok = ldb.rename(dn1, dn2);
200 static int ejs_ldbRename(MprVarHandle eid, int argc, struct MprVar **argv)
202 struct ldb_dn *dn1, *dn2;
203 struct ldb_context *ldb;
207 ejsSetErrorMsg(eid, "ldb.rename invalid arguments");
211 ldb = ejs_get_ldb_context(eid);
216 dn1 = ldb_dn_explode(ldb, mprToString(argv[0]));
217 dn2 = ldb_dn_explode(ldb, mprToString(argv[1]));
218 if (dn1 == NULL || dn2 == NULL) {
219 ejsSetErrorMsg(eid, "ldb.rename invalid or malformed arguments");
223 ret = ldb_rename(ldb, dn1, dn2);
228 mpr_Return(eid, mprCreateBoolVar(ret == 0));
233 get last error message
235 ok = ldb.errstring();
237 static int ejs_ldbErrstring(MprVarHandle eid, int argc, struct MprVar **argv)
239 struct ldb_context *ldb;
241 ldb = ejs_get_ldb_context(eid);
246 mpr_Return(eid, mprString(ldb_errstring(ldb)));
251 perform an ldb modify
254 ok = ldb.modify(ldifstring);
256 static int ejs_ldbAdd(MprVarHandle eid, int argc, struct MprVar **argv)
258 return ejs_ldbAddModify(eid, argc, argv, ldb_add);
265 ok = ldb.add(ldifstring);
267 static int ejs_ldbModify(MprVarHandle eid, int argc, struct MprVar **argv)
269 return ejs_ldbAddModify(eid, argc, argv, ldb_modify);
273 connect to a database
275 ok = ldb.connect(dbfile);
276 ok = ldb.connect(dbfile, "modules:modlist");
278 static int ejs_ldbConnect(MprVarHandle eid, int argc, char **argv)
280 struct ldb_context *ldb;
284 ejsSetErrorMsg(eid, "ldb.connect invalid arguments");
290 ldb = ldb_wrap_connect(mprMemCtx(), dbfile, 0, (const char **)(argv+1));
292 ejsSetErrorMsg(eid, "ldb.connect failed to open %s", dbfile);
295 mprSetThisPtr(eid, "db", ldb);
296 mpr_Return(eid, mprCreateBoolVar(ldb != NULL));
302 initialise ldb ejs subsystem
304 static int ejs_ldb_init(MprVarHandle eid, int argc, struct MprVar **argv)
306 struct MprVar *ldb = mprInitObject(eid, "ldb", argc, argv);
308 mprSetStringCFunction(ldb, "connect", ejs_ldbConnect);
309 mprSetCFunction(ldb, "search", ejs_ldbSearch);
310 mprSetCFunction(ldb, "add", ejs_ldbAdd);
311 mprSetCFunction(ldb, "modify", ejs_ldbModify);
312 mprSetCFunction(ldb, "del", ejs_ldbDelete);
313 mprSetCFunction(ldb, "rename", ejs_ldbRename);
314 mprSetCFunction(ldb, "errstring", ejs_ldbErrstring);
315 mprSetVar(ldb, "SCOPE_BASE", mprCreateNumberVar(LDB_SCOPE_BASE));
316 mprSetVar(ldb, "SCOPE_ONE", mprCreateNumberVar(LDB_SCOPE_ONELEVEL));
317 mprSetVar(ldb, "SCOPE_SUBTREE", mprCreateNumberVar(LDB_SCOPE_SUBTREE));
324 setup C functions that be called from ejs
326 void smb_setup_ejs_ldb(void)
328 ejsDefineCFunction(-1, "ldb_init", ejs_ldb_init, NULL, MPR_VAR_SCRIPT_HANDLE);