mirror of
https://github.com/samba-team/samba.git
synced 2024-12-25 23:21:54 +03:00
r8297: add libinclude() function in ejs, which is like include() but searches a js library
path set in "js include" in smb.conf. This will allow us to start building up a library of common js code, while avoiding the problem of hard-coding include paths in scripts
This commit is contained in:
parent
6961fe2905
commit
ff60529ba2
@ -138,6 +138,7 @@ typedef struct
|
||||
char *szSPOOLSS_URL;
|
||||
char *szWINS_URL;
|
||||
char *szPrivateDir;
|
||||
char **jsInclude;
|
||||
char **szPreloadModules;
|
||||
char **szPasswordServers;
|
||||
char *szSocketOptions;
|
||||
@ -734,6 +735,7 @@ static struct parm_struct parm_table[] = {
|
||||
{"lock dir", P_STRING, P_GLOBAL, &Globals.szLockDir, NULL, NULL, FLAG_HIDE},
|
||||
{"lock directory", P_STRING, P_GLOBAL, &Globals.szLockDir, NULL, NULL, FLAG_ADVANCED | FLAG_DEVELOPER},
|
||||
{"pid directory", P_STRING, P_GLOBAL, &Globals.szPidDir, NULL, NULL, FLAG_ADVANCED | FLAG_DEVELOPER},
|
||||
{"js include", P_LIST, P_GLOBAL, &Globals.jsInclude, NULL, NULL, FLAG_ADVANCED | FLAG_DEVELOPER},
|
||||
|
||||
{"default service", P_STRING, P_GLOBAL, &Globals.szDefaultService, NULL, NULL, FLAG_ADVANCED | FLAG_DEVELOPER},
|
||||
{"default", P_STRING, P_GLOBAL, &Globals.szDefaultService, NULL, NULL, FLAG_DEVELOPER},
|
||||
@ -1062,6 +1064,7 @@ static void init_globals(void)
|
||||
do_parameter("tls keyfile", "tls/key.pem");
|
||||
do_parameter("tls certfile", "tls/cert.pem");
|
||||
do_parameter("tls cafile", "tls/ca.pem");
|
||||
do_parameter_var("js include", "%s/js", dyn_LIBDIR);
|
||||
}
|
||||
|
||||
static TALLOC_CTX *lp_talloc;
|
||||
@ -1284,6 +1287,9 @@ FN_GLOBAL_INTEGER(lp_lm_interval, &Globals.lm_interval)
|
||||
FN_GLOBAL_INTEGER(lp_machine_password_timeout, &Globals.machine_password_timeout)
|
||||
FN_GLOBAL_INTEGER(lp_lock_spin_count, &Globals.iLockSpinCount)
|
||||
FN_GLOBAL_INTEGER(lp_lock_sleep_time, &Globals.iLockSpinTime)
|
||||
FN_GLOBAL_LIST(lp_js_include, &Globals.jsInclude)
|
||||
|
||||
|
||||
FN_LOCAL_STRING(lp_servicename, szService)
|
||||
FN_LOCAL_CONST_STRING(lp_const_servicename, szService)
|
||||
FN_LOCAL_STRING(lp_pathname, szPath)
|
||||
|
@ -65,6 +65,52 @@ static int ejs_typeof(MprVarHandle eid, int argc, struct MprVar **argv)
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
libinclude() allows you to include js files using a search path specified
|
||||
in "js include =" in smb.conf.
|
||||
*/
|
||||
static int ejs_libinclude(int eid, int argc, char **argv)
|
||||
{
|
||||
int i, j;
|
||||
const char **js_include = lp_js_include();
|
||||
|
||||
if (js_include == NULL || js_include[0] == NULL) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
for (i = 0; i < argc; i++) {
|
||||
const char *script = argv[i];
|
||||
|
||||
for (j=0;js_include[j];j++) {
|
||||
char *path;
|
||||
path = talloc_asprintf(mprMemCtx(), "%s/%s", js_include[j], script);
|
||||
if (path == NULL) {
|
||||
return -1;
|
||||
}
|
||||
if (file_exist(path)) {
|
||||
int ret;
|
||||
struct MprVar result;
|
||||
char *emsg;
|
||||
|
||||
ret = ejsEvalFile(eid, path, &result, &emsg);
|
||||
talloc_free(path);
|
||||
if (ret < 0) {
|
||||
ejsSetErrorMsg(eid, "%s: %s", script, emsg);
|
||||
return -1;
|
||||
}
|
||||
break;
|
||||
}
|
||||
talloc_free(path);
|
||||
}
|
||||
if (js_include[j] == NULL) {
|
||||
ejsSetErrorMsg(eid, "unable to include '%s'", script);
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
setup C functions that be called from ejs
|
||||
*/
|
||||
@ -78,6 +124,7 @@ void smb_setup_ejs_functions(void)
|
||||
smb_setup_ejs_auth();
|
||||
|
||||
ejsDefineCFunction(-1, "typeof", ejs_typeof, NULL, MPR_VAR_SCRIPT_HANDLE);
|
||||
ejsDefineStringCFunction(-1, "libinclude", ejs_libinclude, NULL, MPR_VAR_SCRIPT_HANDLE);
|
||||
}
|
||||
|
||||
/*
|
||||
|
Loading…
Reference in New Issue
Block a user