mirror of
https://github.com/samba-team/samba.git
synced 2025-08-04 08:22:08 +03:00
r8484: switched the sys_*() calls to the OO interface
tim, do you want to do the cli_*() calls now?
(This used to be commit 9991e924e9
)
This commit is contained in:
committed by
Gerald (Jerry) Carter
parent
a0bc4da1a3
commit
7913cbbe11
@ -170,17 +170,31 @@ static int ejs_sys_file_save(MprVarHandle eid, int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
initialise sys ejs subsystem
|
||||||
|
*/
|
||||||
|
static int ejs_sys_init(MprVarHandle eid, int argc, struct MprVar **argv)
|
||||||
|
{
|
||||||
|
struct MprVar obj = mprObject("sys");
|
||||||
|
|
||||||
|
mprSetCFunction(&obj, "interfaces", ejs_sys_interfaces);
|
||||||
|
mprSetCFunction(&obj, "hostname", ejs_sys_hostname);
|
||||||
|
mprSetCFunction(&obj, "nttime", ejs_sys_nttime);
|
||||||
|
mprSetCFunction(&obj, "gmtime", ejs_sys_gmtime);
|
||||||
|
mprSetCFunction(&obj, "ldaptime", ejs_sys_ldaptime);
|
||||||
|
mprSetStringCFunction(&obj, "unlink", ejs_sys_unlink);
|
||||||
|
mprSetStringCFunction(&obj, "file_load", ejs_sys_file_load);
|
||||||
|
mprSetStringCFunction(&obj, "file_save", ejs_sys_file_save);
|
||||||
|
|
||||||
|
mpr_Return(eid, obj);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
setup C functions that be called from ejs
|
setup C functions that be called from ejs
|
||||||
*/
|
*/
|
||||||
void smb_setup_ejs_system(void)
|
void smb_setup_ejs_system(void)
|
||||||
{
|
{
|
||||||
ejsDefineCFunction(-1, "sys_interfaces", ejs_sys_interfaces, NULL, MPR_VAR_SCRIPT_HANDLE);
|
ejsDefineCFunction(-1, "sys_init", ejs_sys_init, NULL, MPR_VAR_SCRIPT_HANDLE);
|
||||||
ejsDefineCFunction(-1, "sys_hostname", ejs_sys_hostname, NULL, MPR_VAR_SCRIPT_HANDLE);
|
|
||||||
ejsDefineCFunction(-1, "sys_nttime", ejs_sys_nttime, NULL, MPR_VAR_SCRIPT_HANDLE);
|
|
||||||
ejsDefineCFunction(-1, "sys_gmtime", ejs_sys_gmtime, NULL, MPR_VAR_SCRIPT_HANDLE);
|
|
||||||
ejsDefineCFunction(-1, "sys_ldaptime", ejs_sys_ldaptime, NULL, MPR_VAR_SCRIPT_HANDLE);
|
|
||||||
ejsDefineStringCFunction(-1, "sys_unlink", ejs_sys_unlink, NULL, MPR_VAR_SCRIPT_HANDLE);
|
|
||||||
ejsDefineStringCFunction(-1, "sys_file_load", ejs_sys_file_load, NULL, MPR_VAR_SCRIPT_HANDLE);
|
|
||||||
ejsDefineStringCFunction(-1, "sys_file_save", ejs_sys_file_save, NULL, MPR_VAR_SCRIPT_HANDLE);
|
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,8 @@
|
|||||||
/* used to generate sequence numbers for records */
|
/* used to generate sequence numbers for records */
|
||||||
provision_next_usn = 1;
|
provision_next_usn = 1;
|
||||||
|
|
||||||
|
sys = sys_init();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
find a user or group from a list of possibilities
|
find a user or group from a list of possibilities
|
||||||
*/
|
*/
|
||||||
@ -59,7 +61,7 @@ unixName: ${UNIXNAME}
|
|||||||
*/
|
*/
|
||||||
function nttime()
|
function nttime()
|
||||||
{
|
{
|
||||||
return "" + sys_nttime();
|
return "" + sys.nttime();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -67,7 +69,7 @@ function nttime()
|
|||||||
*/
|
*/
|
||||||
function ldaptime()
|
function ldaptime()
|
||||||
{
|
{
|
||||||
return sys_ldaptime(sys_nttime());
|
return sys.ldaptime(sys.nttime());
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -75,7 +77,7 @@ function ldaptime()
|
|||||||
*/
|
*/
|
||||||
function datestring()
|
function datestring()
|
||||||
{
|
{
|
||||||
var t = sys_gmtime(sys_nttime());
|
var t = sys.gmtime(sys.nttime());
|
||||||
return sprintf("%04u%02u%02u%02u",
|
return sprintf("%04u%02u%02u%02u",
|
||||||
t.tm_year+1900, t.tm_mon+1, t.tm_mday, t.tm_hour);
|
t.tm_year+1900, t.tm_mon+1, t.tm_mday, t.tm_hour);
|
||||||
}
|
}
|
||||||
@ -85,7 +87,7 @@ function datestring()
|
|||||||
*/
|
*/
|
||||||
function hostip()
|
function hostip()
|
||||||
{
|
{
|
||||||
var list = sys_interfaces();
|
var list = sys.interfaces();
|
||||||
return list[0];
|
return list[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -103,7 +105,7 @@ function nextusn()
|
|||||||
*/
|
*/
|
||||||
function hostname()
|
function hostname()
|
||||||
{
|
{
|
||||||
var s = split(".", sys_hostname());
|
var s = split(".", sys.hostname());
|
||||||
return s[0];
|
return s[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -123,9 +125,9 @@ function setup_ldb(ldif, dbname, subobj)
|
|||||||
var db = lpGet("private dir") + "/" + dbname;
|
var db = lpGet("private dir") + "/" + dbname;
|
||||||
var src = lpGet("setup directory") + "/" + ldif;
|
var src = lpGet("setup directory") + "/" + ldif;
|
||||||
|
|
||||||
sys_unlink(db);
|
sys.unlink(db);
|
||||||
|
|
||||||
var data = sys_file_load(src);
|
var data = sys.file_load(src);
|
||||||
data = data + extra;
|
data = data + extra;
|
||||||
data = substitute_var(data, subobj);
|
data = substitute_var(data, subobj);
|
||||||
|
|
||||||
@ -141,12 +143,12 @@ function setup_file(template, fname, subobj)
|
|||||||
var f = lpGet("private dir") + "/" + fname;
|
var f = lpGet("private dir") + "/" + fname;
|
||||||
var src = lpGet("setup directory") + "/" + template;
|
var src = lpGet("setup directory") + "/" + template;
|
||||||
|
|
||||||
sys_unlink(f);
|
sys.unlink(f);
|
||||||
|
|
||||||
var data = sys_file_load(src);
|
var data = sys.file_load(src);
|
||||||
data = substitute_var(data, subobj);
|
data = substitute_var(data, subobj);
|
||||||
|
|
||||||
ok = sys_file_save(f, data);
|
ok = sys.file_save(f, data);
|
||||||
assert(ok);
|
assert(ok);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user