r9724: Rewrite samba3dump in JS. The summary works now, but the full output
[kai/samba.git] / source4 / scripting / ejs / smbcalls_samba3.c
1 /* 
2    Unix SMB/CIFS implementation.
3
4    provide hooks into smbd C calls from ejs scripts
5
6    Copyright (C) Jelmer Vernooij 2005
7    
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.
12    
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.
17    
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.
21 */
22
23 #include "includes.h"
24 #include "scripting/ejs/smbcalls.h"
25 #include "lib/appweb/ejs/ejs.h"
26 #include "lib/samba3/samba3.h"
27
28
29 #if 0
30
31 struct samba3_secrets
32 {
33 };
34
35 #endif 
36
37 static struct MprVar mprRegistry(struct samba3_regdb *reg)
38 {
39         struct MprVar mpv = mprObject("registry"), ks, vs, k, v;
40         int i, j;
41
42         ks = mprObject("array");
43
44         for (i = 0; i < reg->key_count; i++) {
45                 k = mprObject("regkey");
46
47                 mprSetVar(&k, "name", mprString(reg->keys[i].name));
48
49                 vs = mprObject("array");
50                 
51                 for (j = 0; j < reg->keys[i].value_count; j++) {
52                         v = mprObject("regval");
53
54                         mprSetVar(&v, "name", mprString(reg->keys[i].values[j].name));
55                         mprSetVar(&v, "type", mprCreateIntegerVar(reg->keys[i].values[j].type));
56                         mprSetVar(&v, "data", mprDataBlob(reg->keys[i].values[j].data));
57
58                         mprAddArray(&vs, j, v);
59                 }
60
61                 mprSetVar(&k, "values", vs);
62
63                 mprAddArray(&ks, i, k);
64         }
65
66         mprSetVar(&mpv, "keys", ks);
67
68         return mpv;
69 }
70
71 static struct MprVar mprPolicy(struct samba3_policy *pol)
72 {
73         struct MprVar mpv = mprObject("policy");
74
75         mprSetVar(&mpv, "min_password_length", mprCreateIntegerVar(pol->min_password_length));
76         mprSetVar(&mpv, "password_history", mprCreateIntegerVar(pol->password_history));
77         mprSetVar(&mpv, "user_must_logon_to_change_password", mprCreateIntegerVar(pol->user_must_logon_to_change_password));
78         mprSetVar(&mpv, "maximum_password_age", mprCreateIntegerVar(pol->maximum_password_age));
79         mprSetVar(&mpv, "minimum_password_age", mprCreateIntegerVar(pol->minimum_password_age));
80         mprSetVar(&mpv, "lockout_duration", mprCreateIntegerVar(pol->lockout_duration));
81         mprSetVar(&mpv, "reset_count_minutes", mprCreateIntegerVar(pol->reset_count_minutes));
82         mprSetVar(&mpv, "bad_lockout_minutes", mprCreateIntegerVar(pol->bad_lockout_minutes));
83         mprSetVar(&mpv, "disconnect_time", mprCreateIntegerVar(pol->disconnect_time));
84         mprSetVar(&mpv, "refuse_machine_password_change", mprCreateIntegerVar(pol->refuse_machine_password_change));
85
86         return mpv;
87 }
88
89 static struct MprVar mprIdmapDb(struct samba3_idmapdb *db)
90 {
91         struct MprVar mpv = mprObject("idmapdb"), mps, mp;
92         int i;
93
94         mprSetVar(&mpv, "user_hwm", mprCreateIntegerVar(db->user_hwm));
95         mprSetVar(&mpv, "group_hwm", mprCreateIntegerVar(db->group_hwm));
96
97         mps = mprObject("array");
98
99         for (i = 0; i < db->mapping_count; i++) {
100                 char *tmp;
101                 mp = mprObject("idmap");
102
103                 mprSetVar(&mp, "type", mprCreateIntegerVar(db->mappings[i].type));
104                 mprSetVar(&mp, "unix_id", mprCreateIntegerVar(db->mappings[i].unix_id));
105
106                 tmp = dom_sid_string(NULL, db->mappings[i].sid);
107                 mprSetVar(&mp, "sid", mprString(tmp));
108                 talloc_free(tmp);
109
110                 mprAddArray(&mps, i, mp);
111         }
112
113         mprSetVar(&mpv, "mappings", mps);
114
115         return mpv;
116 }
117
118 static struct MprVar mprGroupMappings(struct samba3_groupdb *db)
119 {
120         struct MprVar mpv = mprObject("array"), g;
121         int i;
122
123         for (i = 0; i < db->groupmap_count; i++) {
124                 char *tmp;
125                 g = mprObject("group");
126
127                 mprSetVar(&g, "gid", mprCreateIntegerVar(db->groupmappings[i].gid));
128
129                 tmp = dom_sid_string(NULL, db->groupmappings[i].sid);
130                 mprSetVar(&g, "sid", mprString(tmp));
131                 talloc_free(tmp);
132
133                 mprSetVar(&g, "sid_name_use", mprCreateIntegerVar(db->groupmappings[i].sid_name_use));
134                 mprSetVar(&g, "nt_name", mprString(db->groupmappings[i].nt_name));
135                 mprSetVar(&g, "comment", mprString(db->groupmappings[i].comment));
136
137                 mprAddArray(&mpv, i, g);
138         }
139
140         return mpv;
141 }
142
143 static struct MprVar mprAliases(struct samba3_groupdb *db)
144 {
145         struct MprVar mpv = mprObject("array"), a, am;
146         int i, j;
147
148         for (i = 0; i < db->alias_count; i++) {
149                 char *tmp;
150                 a = mprObject("alias");
151
152                 tmp = dom_sid_string(NULL, db->aliases[i].sid);
153                 mprSetVar(&a, "sid", mprString(tmp));
154                 talloc_free(tmp);
155
156                 am = mprObject("array");
157
158                 for (j = 0; j < db->aliases[i].member_count; j++) {
159                         tmp = dom_sid_string(NULL, db->aliases[i].members[j]);
160                         mprAddArray(&am, j, mprString(tmp));
161                         talloc_free(tmp);
162                 }
163
164                 mprSetVar(&a, "members", am);
165         }
166
167         return mpv;
168 }
169
170 static struct MprVar mprSecrets(struct samba3_secrets *sec)
171 {
172         struct MprVar mpv = mprObject("samba3_secrets"), es, e;
173         int i;
174
175         es = mprObject("array");
176
177         for (i = 0; i < sec->ldappw_count; i++) {
178                 e = mprObject("ldappw");
179
180                 mprSetVar(&e, "dn", mprString(sec->ldappws[i].dn));
181                 mprSetVar(&e, "password", mprString(sec->ldappws[i].password));
182
183                 mprAddArray(&es, i, e);
184         }
185
186         mprSetVar(&mpv, "ldappws", es);
187
188         for (i = 0; i < sec->domain_count; i++) {
189                 char *tmp;
190                 struct MprVar v;
191                 e = mprObject("domainsecrets");
192
193                 mprSetVar(&e, "name", mprString(sec->domains[i].name));
194                 
195                 tmp = dom_sid_string(NULL, &sec->domains[i].sid);
196                 mprSetVar(&e, "sid", mprString(tmp));
197                 talloc_free(tmp);
198
199                 tmp = GUID_string(NULL, &sec->domains[i].guid);
200                 mprSetVar(&e, "guid", mprString(tmp));
201                 talloc_free(tmp);
202
203                 mprSetVar(&e, "plaintext_pw", mprString(sec->domains[i].plaintext_pw));
204
205                 mprSetVar(&e, "last_change_time", mprCreateIntegerVar(sec->domains[i].last_change_time));
206                 mprSetVar(&e, "sec_channel_type", mprCreateIntegerVar(sec->domains[i].sec_channel_type));
207
208                 v = mprObject("hash_pw");
209
210                 mprSetVar(&v, "hash", mprData(sec->domains[i].hash_pw.hash, 16));
211
212                 mprSetVar(&v, "mod_time", mprCreateIntegerVar(sec->domains[i].hash_pw.mod_time));
213
214                 mprSetVar(&e, "hash_pw", v);
215
216                 mprAddArray(&es, i, e);
217         }
218
219         mprSetVar(&mpv, "domains", es);
220
221         es = mprObject("trusted_domains");
222
223         for (i = 0; i < sec->trusted_domain_count; i++) {
224                 struct MprVar ns;
225                 char *tmp;
226                 int j;
227                 e = mprObject("trusted_domain");
228
229                 ns = mprObject("array");
230
231                 for (j = 0; j < sec->trusted_domains[i].uni_name_len; j++) {
232                         mprAddArray(&ns, j, mprString(sec->trusted_domains[i].uni_name[j]));
233                 }
234
235                 mprSetVar(&e, "uni_name", ns);
236
237                 mprSetVar(&e, "pass", mprString(sec->trusted_domains[i].pass));
238                 mprSetVar(&e, "mod_time", mprCreateIntegerVar(sec->trusted_domains[i].mod_time));
239
240                 tmp = dom_sid_string(NULL, &sec->trusted_domains[i].domain_sid);
241                 mprSetVar(&e, "domains_sid", mprString(tmp));
242                 talloc_free(tmp);
243
244                 mprAddArray(&es, i, e);
245         }
246
247         mprSetVar(&mpv, "trusted_domains", es);
248         
249         es = mprObject("array");
250
251         for (i = 0; i < sec->afs_keyfile_count; i++) {
252                 struct MprVar ks;
253                 int j;
254                 e = mprObject("afs_keyfile");
255
256                 mprSetVar(&e, "cell", mprString(sec->afs_keyfiles[i].cell));
257
258                 ks = mprObject("array");
259                 
260                 for (j = 0; j < 8; j++) {
261                         struct MprVar k = mprObject("entry");
262                         
263                         mprSetVar(&k, "kvno", mprCreateIntegerVar(sec->afs_keyfiles[i].entry[j].kvno));
264                         mprSetVar(&k, "key", mprData((uint8_t*)sec->afs_keyfiles[i].entry[j].key, 8));
265
266                         mprAddArray(&ks, j, k);
267                 }
268
269                 mprSetVar(&e, "entry", ks);
270
271                 mprSetVar(&e, "nkeys", mprCreateIntegerVar(sec->afs_keyfiles[i].nkeys));
272
273                 mprAddArray(&es, i, e);
274         }
275
276         mprSetVar(&mpv, "afs_keyfiles", es);
277
278         mprSetVar(&mpv, "ipc_cred", mprCredentials(sec->ipc_cred));
279
280         return mpv;
281 }
282
283 static struct MprVar mprShares(struct samba3 *samba3)
284 {
285         struct MprVar mpv = mprObject("array"), s, ps, p;
286         int i, j;
287
288         for (i = 0; i < samba3->share_count; i++) {
289                 s = mprObject("share");
290
291                 mprSetVar(&s, "name", mprString(samba3->shares[i].name));
292
293                 /* FIXME: secdesc */
294
295                 ps = mprObject("array");
296
297                 for (j = 0; j < samba3->shares[i].parameter_count; j++) {
298                         p = mprObject("parameter");
299
300                         mprSetVar(&p, "name", mprString(samba3->shares[i].parameters[j].name));
301                         mprSetVar(&p, "value", mprString(samba3->shares[i].parameters[j].value));
302
303                         mprAddArray(&ps, j, p);
304                 }
305
306                 mprSetVar(&s, "parameters", ps);
307         }
308
309         return mpv;
310 }
311
312 static struct MprVar mprSamAccounts(struct samba3 *samba3)
313 {
314         struct MprVar mpv = mprObject("array"), m;
315         int i;
316
317         for (i = 0; i < samba3->samaccount_count; i++) {
318                 struct samba3_samaccount *a = &samba3->samaccounts[i];
319
320                 m = mprObject("samba3_samaccount");
321
322                 mprSetVar(&m, "logon_time", mprCreateIntegerVar(a->logon_time));
323                 mprSetVar(&m, "logoff_time", mprCreateIntegerVar(a->logoff_time));
324                 mprSetVar(&m, "kickoff_time", mprCreateIntegerVar(a->kickoff_time));
325                 mprSetVar(&m, "bad_password_time", mprCreateIntegerVar(a->bad_password_time));
326                 mprSetVar(&m, "pass_last_set_time", mprCreateIntegerVar(a->pass_last_set_time));
327                 mprSetVar(&m, "pass_can_change_time", mprCreateIntegerVar(a->pass_can_change_time));
328                 mprSetVar(&m, "pass_must_change_time", mprCreateIntegerVar(a->pass_must_change_time));
329                 mprSetVar(&m, "user_rid", mprCreateIntegerVar(a->user_rid));
330                 mprSetVar(&m, "group_rid", mprCreateIntegerVar(a->group_rid));
331                 mprSetVar(&m, "acct_ctrl", mprCreateIntegerVar(a->acct_ctrl));
332                 mprSetVar(&m, "logon_divs", mprCreateIntegerVar(a->logon_divs));
333                 mprSetVar(&m, "bad_password_count", mprCreateIntegerVar(a->bad_password_count));
334                 mprSetVar(&m, "logon_count", mprCreateIntegerVar(a->logon_count));
335                 mprSetVar(&m, "username", mprString(a->username));
336                 mprSetVar(&m, "domain", mprString(a->domain));
337                 mprSetVar(&m, "nt_username", mprString(a->nt_username));
338                 mprSetVar(&m, "dir_drive", mprString(a->dir_drive));
339                 mprSetVar(&m, "munged_dial", mprString(a->munged_dial));
340                 mprSetVar(&m, "fullname", mprString(a->fullname));
341                 mprSetVar(&m, "homedir", mprString(a->homedir));
342                 mprSetVar(&m, "logon_script", mprString(a->logon_script));
343                 mprSetVar(&m, "profile_path", mprString(a->profile_path));
344                 mprSetVar(&m, "acct_desc", mprString(a->acct_desc));
345                 mprSetVar(&m, "workstations", mprString(a->workstations));
346
347                 /* FIXME: lm_pw_ptr, nt_pw_ptr */
348
349                 mprAddArray(&mpv, i, m);
350         }
351
352         return mpv;
353 }
354
355 static struct MprVar mprWinsEntries(struct samba3 *samba3)
356 {
357         struct MprVar mpv = mprObject("array");
358         int i, j;
359
360         for (i = 0; i < samba3->winsdb_count; i++) {
361                 struct MprVar w = mprObject("wins_entry"), ips;
362
363                 mprSetVar(&w, "name", mprString(samba3->winsdb_entries[i].name));
364                 mprSetVar(&w, "nb_flags", mprCreateIntegerVar(samba3->winsdb_entries[i].nb_flags));
365                 mprSetVar(&w, "type", mprCreateIntegerVar(samba3->winsdb_entries[i].type));
366                 mprSetVar(&w, "ttl", mprCreateIntegerVar(samba3->winsdb_entries[i].ttl));
367
368                 ips = mprObject("array");
369
370                 for (j = 0; j < samba3->winsdb_entries[i].ip_count; j++) {
371                         mprAddArray(&ips, j, mprString(iface_n_ip(i)));
372                 }
373
374                 mprSetVar(&w, "ips", ips);
375                 
376                 mprAddArray(&mpv, i, w);
377         }
378
379         return mpv;
380 }
381
382 /*
383   initialise samba3 ejs subsystem
384 */
385 static int ejs_samba3_read(MprVarHandle eid, int argc, struct MprVar **argv)
386 {
387         struct MprVar mpv = mprObject("samba3");
388         struct samba3 *samba3;
389         NTSTATUS status;
390
391         if (argc < 2) {
392                 ejsSetErrorMsg(eid, "samba3_read invalid arguments");
393                 return -1;
394         }
395
396         status = samba3_read(mprToString(argv[0]), mprToString(argv[0]), mprMemCtx(), &samba3);
397
398         if (NT_STATUS_IS_ERR(status)) {
399                 ejsSetErrorMsg(eid, "samba3_read: error");
400                 return -1;
401         }
402
403         mprSetVar(&mpv, "winsentries", mprWinsEntries(samba3));
404         mprSetVar(&mpv, "samaccounts", mprSamAccounts(samba3));
405         mprSetVar(&mpv, "shares", mprShares(samba3));
406         mprSetVar(&mpv, "secrets", mprSecrets(&samba3->secrets));
407         mprSetVar(&mpv, "groupmappings", mprGroupMappings(&samba3->group));
408         mprSetVar(&mpv, "aliases", mprAliases(&samba3->group));
409         mprSetVar(&mpv, "idmapdb", mprIdmapDb(&samba3->idmap));
410         mprSetVar(&mpv, "policy", mprPolicy(&samba3->policy));
411         mprSetVar(&mpv, "registry", mprRegistry(&samba3->registry));
412
413         mpr_Return(eid, mpv);
414         
415         return 0;
416 }
417
418
419 /*
420   setup C functions that be called from ejs
421 */
422 void smb_setup_ejs_samba3(void)
423 {
424         ejsDefineCFunction(-1, "samba3_read", ejs_samba3_read, NULL, MPR_VAR_SCRIPT_HANDLE);
425 }