diff options
-rw-r--r-- | source4/scripting/ejs/smbcalls_rand.c | 19 | ||||
-rw-r--r-- | source4/scripting/libjs/provision.js | 2 | ||||
-rw-r--r-- | swat/install/newuser.esp | 3 |
3 files changed, 19 insertions, 5 deletions
diff --git a/source4/scripting/ejs/smbcalls_rand.c b/source4/scripting/ejs/smbcalls_rand.c index 81473ad737..043b9cca09 100644 --- a/source4/scripting/ejs/smbcalls_rand.c +++ b/source4/scripting/ejs/smbcalls_rand.c @@ -81,12 +81,23 @@ static int ejs_randsid(MprVarHandle eid, int argc, struct MprVar **argv) } /* + initialise random ejs subsystem +*/ +static int ejs_random_init(MprVarHandle eid, int argc, struct MprVar **argv) +{ + struct MprVar *obj = mprInitObject(eid, "random", argc, argv); + + mprSetCFunction(obj, "random", ejs_random); + mprSetCFunction(obj, "randpass", ejs_randpass); + mprSetCFunction(obj, "randguid", ejs_randguid); + mprSetCFunction(obj, "randsid", ejs_randsid); + return 0; +} + +/* setup C functions that be called from ejs */ void smb_setup_ejs_random(void) { - ejsDefineCFunction(-1, "random", ejs_random, NULL, MPR_VAR_SCRIPT_HANDLE); - ejsDefineCFunction(-1, "randpass", ejs_randpass, NULL, MPR_VAR_SCRIPT_HANDLE); - ejsDefineCFunction(-1, "randguid", ejs_randguid, NULL, MPR_VAR_SCRIPT_HANDLE); - ejsDefineCFunction(-1, "randsid", ejs_randsid, NULL, MPR_VAR_SCRIPT_HANDLE); + ejsDefineCFunction(-1, "random_init", ejs_random_init, NULL, MPR_VAR_SCRIPT_HANDLE); } diff --git a/source4/scripting/libjs/provision.js b/source4/scripting/libjs/provision.js index e9a8aad0cc..58f0e18240 100644 --- a/source4/scripting/libjs/provision.js +++ b/source4/scripting/libjs/provision.js @@ -224,6 +224,7 @@ function provision_guess() var subobj = new Object(); var nss = nss_init(); var lp = loadparm_init(); + random_init(local); subobj.REALM = lp.get("realm"); subobj.DOMAIN = lp.get("workgroup"); @@ -277,6 +278,7 @@ function newuser(username, unixname, password, message) var lp = loadparm_init(); var samdb = lp.get("sam database"); var ldb = ldb_init(); + random_init(local); /* connect to the sam */ var ok = ldb.connect(samdb); diff --git a/swat/install/newuser.esp b/swat/install/newuser.esp index 21a2cb361b..42c109df6b 100644 --- a/swat/install/newuser.esp +++ b/swat/install/newuser.esp @@ -9,6 +9,7 @@ <% var f = FormObj("newuser", 3, 2); var i; +var rand = random_init(); f.element[0].label = "User Name"; f.element[0].name = "USERNAME"; @@ -29,7 +30,7 @@ if (form['submit'] == "Add" && form.UNIXNAME = form.USERNAME; } if (form.PASSWORD == undefined) { - form.PASSWORD = randpass(); + form.PASSWORD = rand.randpass(); } newuser(form.USERNAME, form.UNIXNAME, form.PASSWORD, writefln); } else { |