2 Unix SMB/CIFS implementation.
4 provide hooks into smbd C calls from ejs scripts
6 Copyright (C) Jelmer Vernooij 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/samba3/samba3.h"
29 static struct MprVar mprRegistry(struct samba3_regdb *reg)
31 struct MprVar mpv = mprObject("registry"), ks, vs, k, v;
34 ks = mprObject("array");
36 for (i = 0; i < reg->key_count; i++) {
37 k = mprObject("regkey");
39 mprSetVar(&k, "name", mprString(reg->keys[i].name));
41 vs = mprObject("array");
43 for (j = 0; j < reg->keys[i].value_count; j++) {
44 v = mprObject("regval");
46 mprSetVar(&v, "name", mprString(reg->keys[i].values[j].name));
47 mprSetVar(&v, "type", mprCreateIntegerVar(reg->keys[i].values[j].type));
48 mprSetVar(&v, "data", mprDataBlob(reg->keys[i].values[j].data));
50 mprAddArray(&vs, j, v);
53 mprSetVar(&k, "values", vs);
55 mprAddArray(&ks, i, k);
58 mprSetVar(&mpv, "keys", ks);
63 static struct MprVar mprPolicy(struct samba3_policy *pol)
65 struct MprVar mpv = mprObject("policy");
67 mprSetVar(&mpv, "min_password_length", mprCreateIntegerVar(pol->min_password_length));
68 mprSetVar(&mpv, "password_history", mprCreateIntegerVar(pol->password_history));
69 mprSetVar(&mpv, "user_must_logon_to_change_password", mprCreateIntegerVar(pol->user_must_logon_to_change_password));
70 mprSetVar(&mpv, "maximum_password_age", mprCreateIntegerVar(pol->maximum_password_age));
71 mprSetVar(&mpv, "minimum_password_age", mprCreateIntegerVar(pol->minimum_password_age));
72 mprSetVar(&mpv, "lockout_duration", mprCreateIntegerVar(pol->lockout_duration));
73 mprSetVar(&mpv, "reset_count_minutes", mprCreateIntegerVar(pol->reset_count_minutes));
74 mprSetVar(&mpv, "bad_lockout_minutes", mprCreateIntegerVar(pol->bad_lockout_minutes));
75 mprSetVar(&mpv, "disconnect_time", mprCreateIntegerVar(pol->disconnect_time));
76 mprSetVar(&mpv, "refuse_machine_password_change", mprCreateIntegerVar(pol->refuse_machine_password_change));
81 static struct MprVar mprIdmapDb(struct samba3_idmapdb *db)
83 struct MprVar mpv = mprObject("idmapdb"), mps, mp;
86 mprSetVar(&mpv, "user_hwm", mprCreateIntegerVar(db->user_hwm));
87 mprSetVar(&mpv, "group_hwm", mprCreateIntegerVar(db->group_hwm));
89 mps = mprObject("array");
91 for (i = 0; i < db->mapping_count; i++) {
93 mp = mprObject("idmap");
95 mprSetVar(&mp, "IDMAP_GROUP", mprCreateIntegerVar(IDMAP_GROUP));
96 mprSetVar(&mp, "IDMAP_USER", mprCreateIntegerVar(IDMAP_USER));
97 mprSetVar(&mp, "type", mprCreateIntegerVar(db->mappings[i].type));
98 mprSetVar(&mp, "unix_id", mprCreateIntegerVar(db->mappings[i].unix_id));
100 tmp = dom_sid_string(NULL, db->mappings[i].sid);
101 mprSetVar(&mp, "sid", mprString(tmp));
104 mprAddArray(&mps, i, mp);
107 mprSetVar(&mpv, "mappings", mps);
112 static struct MprVar mprGroupMappings(struct samba3_groupdb *db)
114 struct MprVar mpv = mprObject("array"), g;
117 for (i = 0; i < db->groupmap_count; i++) {
119 g = mprObject("group");
121 mprSetVar(&g, "gid", mprCreateIntegerVar(db->groupmappings[i].gid));
123 tmp = dom_sid_string(NULL, db->groupmappings[i].sid);
124 mprSetVar(&g, "sid", mprString(tmp));
127 mprSetVar(&g, "sid_name_use", mprCreateIntegerVar(db->groupmappings[i].sid_name_use));
128 mprSetVar(&g, "nt_name", mprString(db->groupmappings[i].nt_name));
129 mprSetVar(&g, "comment", mprString(db->groupmappings[i].comment));
131 mprAddArray(&mpv, i, g);
137 static struct MprVar mprAliases(struct samba3_groupdb *db)
139 struct MprVar mpv = mprObject("array"), a, am;
142 for (i = 0; i < db->alias_count; i++) {
144 a = mprObject("alias");
146 tmp = dom_sid_string(NULL, db->aliases[i].sid);
147 mprSetVar(&a, "sid", mprString(tmp));
150 am = mprObject("array");
152 for (j = 0; j < db->aliases[i].member_count; j++) {
153 tmp = dom_sid_string(NULL, db->aliases[i].members[j]);
154 mprAddArray(&am, j, mprString(tmp));
158 mprSetVar(&a, "members", am);
164 static struct MprVar mprDomainSecrets(struct samba3_domainsecrets *ds)
166 struct MprVar v, e = mprObject("domainsecrets");
169 mprSetVar(&e, "name", mprString(ds->name));
171 tmp = dom_sid_string(NULL, &ds->sid);
172 mprSetVar(&e, "sid", mprString(tmp));
175 tmp = GUID_string(NULL, &ds->guid);
176 mprSetVar(&e, "guid", mprString(tmp));
179 mprSetVar(&e, "plaintext_pw", mprString(ds->plaintext_pw));
181 mprSetVar(&e, "last_change_time", mprCreateIntegerVar(ds->last_change_time));
182 mprSetVar(&e, "sec_channel_type", mprCreateIntegerVar(ds->sec_channel_type));
184 v = mprObject("hash_pw");
186 mprSetVar(&v, "hash", mprData(ds->hash_pw.hash, 16));
188 mprSetVar(&v, "mod_time", mprCreateIntegerVar(ds->hash_pw.mod_time));
190 mprSetVar(&e, "hash_pw", v);
195 static struct MprVar mprSecrets(struct samba3_secrets *sec)
197 struct MprVar mpv = mprObject("samba3_secrets"), es, e;
200 es = mprObject("array");
202 for (i = 0; i < sec->ldappw_count; i++) {
203 e = mprObject("ldappw");
205 mprSetVar(&e, "dn", mprString(sec->ldappws[i].dn));
206 mprSetVar(&e, "password", mprString(sec->ldappws[i].password));
208 mprAddArray(&es, i, e);
211 mprSetVar(&mpv, "ldappws", es);
213 for (i = 0; i < sec->domain_count; i++) {
214 mprAddArray(&es, i, mprDomainSecrets(&sec->domains[i]));
217 mprSetVar(&mpv, "domains", es);
219 es = mprObject("trusted_domains");
221 for (i = 0; i < sec->trusted_domain_count; i++) {
225 e = mprObject("trusted_domain");
227 ns = mprObject("array");
229 for (j = 0; j < sec->trusted_domains[i].uni_name_len; j++) {
230 mprAddArray(&ns, j, mprString(sec->trusted_domains[i].uni_name[j]));
233 mprSetVar(&e, "uni_name", ns);
235 mprSetVar(&e, "pass", mprString(sec->trusted_domains[i].pass));
236 mprSetVar(&e, "mod_time", mprCreateIntegerVar(sec->trusted_domains[i].mod_time));
238 tmp = dom_sid_string(NULL, &sec->trusted_domains[i].domain_sid);
239 mprSetVar(&e, "domains_sid", mprString(tmp));
242 mprAddArray(&es, i, e);
245 mprSetVar(&mpv, "trusted_domains", es);
247 es = mprObject("array");
249 for (i = 0; i < sec->afs_keyfile_count; i++) {
252 e = mprObject("afs_keyfile");
254 mprSetVar(&e, "cell", mprString(sec->afs_keyfiles[i].cell));
256 ks = mprObject("array");
258 for (j = 0; j < 8; j++) {
259 struct MprVar k = mprObject("entry");
261 mprSetVar(&k, "kvno", mprCreateIntegerVar(sec->afs_keyfiles[i].entry[j].kvno));
262 mprSetVar(&k, "key", mprData((uint8_t*)sec->afs_keyfiles[i].entry[j].key, 8));
264 mprAddArray(&ks, j, k);
267 mprSetVar(&e, "entry", ks);
269 mprSetVar(&e, "nkeys", mprCreateIntegerVar(sec->afs_keyfiles[i].nkeys));
271 mprAddArray(&es, i, e);
274 mprSetVar(&mpv, "afs_keyfiles", es);
276 mprSetVar(&mpv, "ipc_cred", mprCredentials(sec->ipc_cred));
281 static struct MprVar mprShares(struct samba3 *samba3)
283 struct MprVar mpv = mprObject("array"), s, ps, p;
286 for (i = 0; i < samba3->share_count; i++) {
287 s = mprObject("share");
289 mprSetVar(&s, "name", mprString(samba3->shares[i].name));
293 ps = mprObject("array");
295 for (j = 0; j < samba3->shares[i].parameter_count; j++) {
296 p = mprObject("parameter");
298 mprSetVar(&p, "name", mprString(samba3->shares[i].parameters[j].name));
299 mprSetVar(&p, "value", mprString(samba3->shares[i].parameters[j].value));
301 mprAddArray(&ps, j, p);
304 mprSetVar(&s, "parameters", ps);
310 static struct MprVar mprSamAccounts(struct samba3 *samba3)
312 struct MprVar mpv = mprObject("array"), m;
315 for (i = 0; i < samba3->samaccount_count; i++) {
316 struct samba3_samaccount *a = &samba3->samaccounts[i];
318 m = mprObject("samba3_samaccount");
320 mprSetVar(&m, "logon_time", mprCreateIntegerVar(a->logon_time));
321 mprSetVar(&m, "logoff_time", mprCreateIntegerVar(a->logoff_time));
322 mprSetVar(&m, "kickoff_time", mprCreateIntegerVar(a->kickoff_time));
323 mprSetVar(&m, "bad_password_time", mprCreateIntegerVar(a->bad_password_time));
324 mprSetVar(&m, "pass_last_set_time", mprCreateIntegerVar(a->pass_last_set_time));
325 mprSetVar(&m, "pass_can_change_time", mprCreateIntegerVar(a->pass_can_change_time));
326 mprSetVar(&m, "pass_must_change_time", mprCreateIntegerVar(a->pass_must_change_time));
327 mprSetVar(&m, "user_rid", mprCreateIntegerVar(a->user_rid));
328 mprSetVar(&m, "group_rid", mprCreateIntegerVar(a->group_rid));
329 mprSetVar(&m, "acct_ctrl", mprCreateIntegerVar(a->acct_ctrl));
330 mprSetVar(&m, "logon_divs", mprCreateIntegerVar(a->logon_divs));
331 mprSetVar(&m, "bad_password_count", mprCreateIntegerVar(a->bad_password_count));
332 mprSetVar(&m, "logon_count", mprCreateIntegerVar(a->logon_count));
333 mprSetVar(&m, "username", mprString(a->username));
334 mprSetVar(&m, "domain", mprString(a->domain));
335 mprSetVar(&m, "nt_username", mprString(a->nt_username));
336 mprSetVar(&m, "dir_drive", mprString(a->dir_drive));
337 mprSetVar(&m, "munged_dial", mprString(a->munged_dial));
338 mprSetVar(&m, "fullname", mprString(a->fullname));
339 mprSetVar(&m, "homedir", mprString(a->homedir));
340 mprSetVar(&m, "logon_script", mprString(a->logon_script));
341 mprSetVar(&m, "profile_path", mprString(a->profile_path));
342 mprSetVar(&m, "acct_desc", mprString(a->acct_desc));
343 mprSetVar(&m, "workstations", mprString(a->workstations));
345 /* FIXME: lm_pw_ptr, nt_pw_ptr */
347 mprAddArray(&mpv, i, m);
353 static struct MprVar mprWinsEntries(struct samba3 *samba3)
355 struct MprVar mpv = mprObject("array");
358 for (i = 0; i < samba3->winsdb_count; i++) {
359 struct MprVar w = mprObject("wins_entry"), ips;
361 mprSetVar(&w, "name", mprString(samba3->winsdb_entries[i].name));
362 mprSetVar(&w, "nb_flags", mprCreateIntegerVar(samba3->winsdb_entries[i].nb_flags));
363 mprSetVar(&w, "type", mprCreateIntegerVar(samba3->winsdb_entries[i].type));
364 mprSetVar(&w, "ttl", mprCreateIntegerVar(samba3->winsdb_entries[i].ttl));
366 ips = mprObject("array");
368 for (j = 0; j < samba3->winsdb_entries[i].ip_count; j++) {
369 mprAddArray(&ips, j, mprString(iface_n_ip(i)));
372 mprSetVar(&w, "ips", ips);
374 mprAddArray(&mpv, i, w);
380 static int ejs_get_param(MprVarHandle eid, int argc, struct MprVar **argv)
382 struct samba3 *samba3;
386 ejsSetErrorMsg(eid, "get_param invalid arguments");
390 samba3 = mprGetThisPtr(eid, "samba3");
392 tmp = samba3_get_param(samba3, mprToString(argv[0]), mprToString(argv[1]));
395 mpr_Return(eid, mprCreateUndefinedVar());
397 mpr_Return(eid, mprString(tmp));
403 static int ejs_find_domainsecrets(MprVarHandle eid, int argc, struct MprVar **argv)
405 struct samba3 *samba3 = NULL;
406 struct samba3_domainsecrets *sec;
409 ejsSetErrorMsg(eid, "find_domainsecrets invalid arguments");
413 samba3 = mprGetThisPtr(eid, "samba3");
415 sec = samba3_find_domainsecrets(samba3, mprToString(argv[0]));
418 mpr_Return(eid, mprCreateUndefinedVar());
420 mpr_Return(eid, mprDomainSecrets(sec));
429 initialise samba3 ejs subsystem
431 static int ejs_samba3_read(MprVarHandle eid, int argc, struct MprVar **argv)
433 struct MprVar mpv = mprObject("samba3");
434 struct samba3 *samba3;
438 ejsSetErrorMsg(eid, "samba3_read invalid arguments");
442 status = samba3_read(mprToString(argv[0]), mprToString(argv[0]), mprMemCtx(), &samba3);
444 if (NT_STATUS_IS_ERR(status)) {
445 ejsSetErrorMsg(eid, "samba3_read: error");
451 mprSetThisPtr(eid, "samba3", samba3);
452 mprSetVar(&mpv, "winsentries", mprWinsEntries(samba3));
453 mprSetVar(&mpv, "samaccounts", mprSamAccounts(samba3));
454 mprSetVar(&mpv, "shares", mprShares(samba3));
455 mprSetVar(&mpv, "secrets", mprSecrets(&samba3->secrets));
456 mprSetVar(&mpv, "groupmappings", mprGroupMappings(&samba3->group));
457 mprSetVar(&mpv, "aliases", mprAliases(&samba3->group));
458 mprSetVar(&mpv, "idmapdb", mprIdmapDb(&samba3->idmap));
459 mprSetVar(&mpv, "policy", mprPolicy(&samba3->policy));
460 mprSetVar(&mpv, "registry", mprRegistry(&samba3->registry));
461 mprSetCFunction(&mpv, "get_param", ejs_get_param);
462 mprSetCFunction(&mpv, "find_domainsecrets", ejs_find_domainsecrets);
464 mpr_Return(eid, mpv);
471 setup C functions that be called from ejs
473 void smb_setup_ejs_samba3(void)
475 ejsDefineCFunction(-1, "samba3_read", ejs_samba3_read, NULL, MPR_VAR_SCRIPT_HANDLE);