diff options
| author | jow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2012-05-03 17:19:20 +0000 | 
|---|---|---|
| committer | jow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2012-05-03 17:19:20 +0000 | 
| commit | 37f687e09940b8aea678b166750b54cd90d34e55 (patch) | |
| tree | e0ae1e375441ad6bb5cf23d537bad535e3a58e34 /package/uhttpd | |
| parent | 8329c6da4fac952135d7f10d8ee008b5342ad87b (diff) | |
uhttpd: added uhttpd.docroot
Passes the document-root to the Lua handler by placing it in uhttpd.docroot.
It could alternatively be placed in env.DOCUMENT_ROOT which would more closely
resemble the CGI protocol; but would mean that it is not available at the time
when the handler-chunk is loaded but rather not until the handler is called,
without any code savings.
Signed-off-by: David Favro <openwrt@meta-dynamic.com>
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@31571 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/uhttpd')
| -rw-r--r-- | package/uhttpd/src/uhttpd-lua.c | 12 | ||||
| -rw-r--r-- | package/uhttpd/src/uhttpd-lua.h | 2 | ||||
| -rw-r--r-- | package/uhttpd/src/uhttpd.c | 2 | ||||
| -rw-r--r-- | package/uhttpd/src/uhttpd.h | 2 | 
4 files changed, 13 insertions, 5 deletions
| diff --git a/package/uhttpd/src/uhttpd-lua.c b/package/uhttpd/src/uhttpd-lua.c index a140dc2f2..83b0b0a26 100644 --- a/package/uhttpd/src/uhttpd-lua.c +++ b/package/uhttpd/src/uhttpd-lua.c @@ -137,7 +137,7 @@ static int uh_lua_urlencode(lua_State *L)  } -lua_State * uh_lua_init(const char *handler) +lua_State * uh_lua_init(const struct config *conf)  {  	lua_State *L = lua_open();  	const char *err_str = NULL; @@ -164,12 +164,20 @@ lua_State * uh_lua_init(const char *handler)  	lua_pushcfunction(L, uh_lua_urlencode);  	lua_setfield(L, -2, "urlencode"); +	/* Pass the document-root to the Lua handler by placing it in +	** uhttpd.docroot.  It could alternatively be placed in env.DOCUMENT_ROOT +	** which would more closely resemble the CGI protocol; but would mean that +	** it is not available at the time when the handler-chunk is loaded but +	** rather not until the handler is called, without any code savings. */ +	lua_pushstring(L, conf->docroot); +	lua_setfield(L, -2, "docroot"); +  	/* _G.uhttpd = { ... } */  	lua_setfield(L, LUA_GLOBALSINDEX, "uhttpd");  	/* load Lua handler */ -	switch( luaL_loadfile(L, handler) ) +	switch( luaL_loadfile(L, conf->lua_handler) )  	{  		case LUA_ERRSYNTAX:  			fprintf(stderr, diff --git a/package/uhttpd/src/uhttpd-lua.h b/package/uhttpd/src/uhttpd-lua.h index 730466500..2d2f73c1c 100644 --- a/package/uhttpd/src/uhttpd-lua.h +++ b/package/uhttpd/src/uhttpd-lua.h @@ -32,7 +32,7 @@  #define UH_LUA_ERR_PARAM   -3 -lua_State * uh_lua_init(); +lua_State * uh_lua_init(const struct config *conf);  void uh_lua_request(  	struct client *cl, struct http_request *req, lua_State *L diff --git a/package/uhttpd/src/uhttpd.c b/package/uhttpd/src/uhttpd.c index 5d66e23a5..78e0b5d95 100644 --- a/package/uhttpd/src/uhttpd.c +++ b/package/uhttpd/src/uhttpd.c @@ -1089,7 +1089,7 @@ int main (int argc, char **argv)  			if( ! conf.lua_prefix )  				conf.lua_prefix = "/lua"; -			conf.lua_state = conf.lua_init(conf.lua_handler); +			conf.lua_state = conf.lua_init(&conf);  		}  	}  #endif diff --git a/package/uhttpd/src/uhttpd.h b/package/uhttpd/src/uhttpd.h index 993bf93af..c03d1ae65 100644 --- a/package/uhttpd/src/uhttpd.h +++ b/package/uhttpd/src/uhttpd.h @@ -83,7 +83,7 @@ struct config {  	char *lua_prefix;  	char *lua_handler;  	lua_State *lua_state; -	lua_State * (*lua_init) (const char *handler); +	lua_State * (*lua_init) (const struct config *conf);  	void (*lua_close) (lua_State *L);  	void (*lua_request) (struct client *cl, struct http_request *req, lua_State *L);  #endif | 
