r8297: add libinclude() function in ejs, which is like include() but searches a js...
authorAndrew Tridgell <tridge@samba.org>
Mon, 11 Jul 2005 00:13:11 +0000 (00:13 +0000)
committerGerald (Jerry) Carter <jerry@samba.org>
Wed, 10 Oct 2007 18:19:32 +0000 (13:19 -0500)
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 used to be commit ff60529ba2515df29a20b4a417327a3565ec8ee9)

source4/param/loadparm.c
source4/scripting/ejs/smbcalls.c

index 49dbd74a695baaaa2b46459cc6b2f1221f4ebb8e..d6184fd9ae4f7aed86e019878579acfbea9b4d13 100644 (file)
@@ -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)
index ff57eff1290a2cab83de2105442ae63c66f814dc..1abbb52819c79970c502f1652cde432bbdcc5b22 100644 (file)
@@ -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);
 }
 
 /*