mirror of
https://github.com/Doodle3D/doodle3d-firmware.git
synced 2024-12-31 23:13:48 +01:00
Adapt Lua code so it can be run from uhttpd-mod-lua (log functionality still missing, uhttpd configuration not adapted yet).
This commit is contained in:
parent
dfb16a9b32
commit
dc327ea420
50
src/cmdmain.lua
Normal file
50
src/cmdmain.lua
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
--- This file wraps handle_request(env) in main.lua for command-line or CGI usage.
|
||||||
|
-- It emulates the env table usually constructed by uhttpd-mod-lua.
|
||||||
|
local main = require('main')
|
||||||
|
|
||||||
|
--- Create an environment table mimicking the table uhttpd-mod-lua passes into handle_request().
|
||||||
|
-- The table is created using shell environment variables leaving out only 'DOCUMENT_ROOT',
|
||||||
|
-- 'SCRIPT_PATH' and the regular shell variables (e.g. IFS, HOME and PS1).
|
||||||
|
-- Fields present in the 'real' env table but not in this one are: 'HTTP_VERSION'
|
||||||
|
-- and another table 'headers' which is mostly mirrored by the 'HTTP_*' fields.
|
||||||
|
-- Note that the 'headers' table may contain extra fields (e.g. 'cache-control').
|
||||||
|
-- @treturn table An environment table created from shell environment variables.
|
||||||
|
local function createEnvTableFromShellEnvironment()
|
||||||
|
local environ = {}
|
||||||
|
|
||||||
|
environ['CONTENT_LENGTH'] = os.getenv('CONTENT_LENGTH') or ''
|
||||||
|
environ['CONTENT_TYPE'] = os.getenv('CONTENT_TYPE') or ''
|
||||||
|
environ['GATEWAY_INTERFACE'] = os.getenv('GATEWAY_INTERFACE') or ''
|
||||||
|
environ['HTTP_ACCEPT'] = os.getenv('HTTP_ACCEPT') or ''
|
||||||
|
environ['HTTP_ACCEPT_CHARSET'] = os.getenv('HTTP_ACCEPT_CHARSET') or ''
|
||||||
|
environ['HTTP_ACCEPT_ENCODING'] = os.getenv('HTTP_ACCEPT_ENCODING') or ''
|
||||||
|
environ['HTTP_ACCEPT_LANGUAGE'] = os.getenv('HTTP_ACCEPT_LANGUAGE') or ''
|
||||||
|
environ['HTTP_AUTHORIZATION'] = os.getenv('HTTP_AUTHORIZATION') or ''
|
||||||
|
environ['HTTP_CONNECTION'] = os.getenv('HTTP_CONNECTION') or ''
|
||||||
|
environ['HTTP_COOKIE'] = os.getenv('HTTP_COOKIE') or ''
|
||||||
|
environ['HTTP_HOST'] = os.getenv('HTTP_HOST') or ''
|
||||||
|
environ['HTTP_REFERER'] = os.getenv('HTTP_REFERER') or ''
|
||||||
|
environ['HTTP_USER_AGENT'] = os.getenv('HTTP_USER_AGENT') or ''
|
||||||
|
environ['PATH_INFO'] = os.getenv('PATH_INFO') or ''
|
||||||
|
environ['QUERY_STRING'] = os.getenv('QUERY_STRING') or ''
|
||||||
|
environ['REDIRECT_STATUS'] = os.getenv('REDIRECT_STATUS') or ''
|
||||||
|
environ['REMOTE_ADDR'] = os.getenv('REMOTE_ADDR') or ''
|
||||||
|
environ['REMOTE_HOST'] = os.getenv('REMOTE_HOST') or ''
|
||||||
|
environ['REMOTE_PORT'] = os.getenv('REMOTE_PORT') or ''
|
||||||
|
environ['REQUEST_METHOD'] = os.getenv('REQUEST_METHOD') or ''
|
||||||
|
environ['REQUEST_URI'] = os.getenv('REQUEST_URI') or ''
|
||||||
|
environ['SCRIPT_FILENAME'] = os.getenv('SCRIPT_FILENAME') or ''
|
||||||
|
environ['SCRIPT_NAME'] = os.getenv('SCRIPT_NAME') or ''
|
||||||
|
environ['SERVER_ADDR'] = os.getenv('SERVER_ADDR') or ''
|
||||||
|
environ['SERVER_NAME'] = os.getenv('SERVER_NAME') or ''
|
||||||
|
environ['SERVER_PORT'] = os.getenv('SERVER_PORT') or ''
|
||||||
|
environ['SERVER_PROTOCOL'] = os.getenv('SERVER_PROTOCOL') or ''
|
||||||
|
environ['SERVER_SOFTWARE'] = os.getenv('SERVER_SOFTWARE') or ''
|
||||||
|
|
||||||
|
return environ
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--- Entry point for cgi-bin wrapper script. ---
|
||||||
|
local rv = handle_request(createEnvTableFromShellEnvironment())
|
||||||
|
os.exit(rv)
|
32
src/main.lua
32
src/main.lua
@ -74,7 +74,7 @@ local function setupAutoWifiMode()
|
|||||||
return nil, "autowifi: uh oh - bad situation in autowifi function"
|
return nil, "autowifi: uh oh - bad situation in autowifi function"
|
||||||
end
|
end
|
||||||
|
|
||||||
local function init()
|
local function init(environment)
|
||||||
log:init(log.LEVEL.debug)
|
log:init(log.LEVEL.debug)
|
||||||
log:setStream(io.stderr)
|
log:setStream(io.stderr)
|
||||||
|
|
||||||
@ -88,8 +88,8 @@ local function init()
|
|||||||
|
|
||||||
log:info("Wifibox CGI handler started" .. dbgText)
|
log:info("Wifibox CGI handler started" .. dbgText)
|
||||||
|
|
||||||
if (os.getenv('REQUEST_METHOD') == 'POST') then
|
if (environment['REQUEST_METHOD'] == 'POST') then
|
||||||
local n = tonumber(os.getenv('CONTENT_LENGTH'))
|
local n = tonumber(environment['CONTENT_LENGTH'])
|
||||||
postData = io.read(n)
|
postData = io.read(n)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -103,8 +103,8 @@ local function init()
|
|||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
local function main()
|
local function main(environment)
|
||||||
local rq = RequestClass.new(postData, confDefaults.DEBUG_API)
|
local rq = RequestClass.new(environment, postData, confDefaults.DEBUG_API)
|
||||||
|
|
||||||
-- log:info("received request of type " .. rq:getRequestMethod() .. " for " .. (rq:getRequestedApiModule() or "<unknown>")
|
-- log:info("received request of type " .. rq:getRequestMethod() .. " for " .. (rq:getRequestedApiModule() or "<unknown>")
|
||||||
-- .. "/" .. (rq:getRealApiFunctionName() or "<unknown>") .. " with arguments: " .. util.dump(rq:getAll()))
|
-- .. "/" .. (rq:getRealApiFunctionName() or "<unknown>") .. " with arguments: " .. util.dump(rq:getAll()))
|
||||||
@ -134,19 +134,27 @@ end
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
---'entry point'---
|
|
||||||
local s, msg = init()
|
--- Main firmware entry point.
|
||||||
|
-- This is either used by uhttp-mod-lua directly, or by the d3dapi cgi-bin wrapper
|
||||||
|
-- script which builds the env table from the shell environment. The wrapper script
|
||||||
|
-- also handles command-line invocation.
|
||||||
|
-- @tparam table The CGI environment table.
|
||||||
|
-- @treturn number A Z+ return value suitable to return from wrapper script. Note that this value is ignored by uhttpd-mod-lua.
|
||||||
|
function handle_request(env)
|
||||||
|
local s, msg = init(env)
|
||||||
|
|
||||||
if s == false then
|
if s == false then
|
||||||
local resp = ResponseClass.new()
|
local resp = ResponseClass.new()
|
||||||
local errSuffix = msg and " (" .. msg .. ")" or ""
|
local errSuffix = msg and " (" .. msg .. ")" or ""
|
||||||
|
|
||||||
resp:setError("initialization failed" .. errSuffix)
|
resp:setError("initialization failed" .. errSuffix)
|
||||||
io.write ("Content-type: text/plain\r\n\r\n")
|
|
||||||
resp:send()
|
resp:send()
|
||||||
log:error("initialization failed" .. errSuffix) --NOTE: this assumes the logger has been inited properly, despite init() having failed
|
log:error("initialization failed" .. errSuffix) --NOTE: this assumes the logger has been initialized properly, despite init() having failed
|
||||||
|
|
||||||
os.exit(1)
|
return 1
|
||||||
else
|
else
|
||||||
main()
|
main(env)
|
||||||
os.exit(0)
|
return 0
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
@ -156,23 +156,23 @@ setmetatable(M, {
|
|||||||
|
|
||||||
--This function initializes itself using various environment variables, the arg array and the given postData
|
--This function initializes itself using various environment variables, the arg array and the given postData
|
||||||
--NOTE: if debugging is enabled, commandline arguments 'm' and 'f' override requested module and function
|
--NOTE: if debugging is enabled, commandline arguments 'm' and 'f' override requested module and function
|
||||||
function M.new(postData, debugEnabled)
|
function M.new(environment, postData, debugEnabled)
|
||||||
local self = setmetatable({}, M)
|
local self = setmetatable({}, M)
|
||||||
|
|
||||||
--NOTE: is it correct to assume that absence of REQUEST_METHOD indicates command line invocation?
|
--NOTE: is it correct to assume that absence of REQUEST_METHOD indicates command line invocation?
|
||||||
self.requestMethod = os.getenv('REQUEST_METHOD')
|
self.requestMethod = environment['REQUEST_METHOD']
|
||||||
if self.requestMethod ~= nil then
|
if type(self.requestMethod) == 'string' and self.requestMethod:len() > 0 then
|
||||||
self.remoteHost = os.getenv('REMOTE_HOST')
|
self.remoteHost = environment['REMOTE_HOST']
|
||||||
self.remotePort = os.getenv('REMOTE_PORT')
|
self.remotePort = environment['REMOTE_PORT']
|
||||||
self.userAgent = os.getenv('HTTP_USER_AGENT')
|
self.userAgent = environment['HTTP_USER_AGENT']
|
||||||
else
|
else
|
||||||
self.requestMethod = 'CMDLINE'
|
self.requestMethod = 'CMDLINE'
|
||||||
end
|
end
|
||||||
|
|
||||||
self.cmdLineArgs = kvTableFromArray(arg)
|
self.cmdLineArgs = kvTableFromArray(arg)
|
||||||
self.getArgs = kvTableFromUrlEncodedString(os.getenv('QUERY_STRING'))
|
self.getArgs = kvTableFromUrlEncodedString(environment['QUERY_STRING'])
|
||||||
self.postArgs = kvTableFromUrlEncodedString(postData)
|
self.postArgs = kvTableFromUrlEncodedString(postData)
|
||||||
self.pathArgs = arrayFromPath(os.getenv('PATH_INFO'))
|
self.pathArgs = arrayFromPath(environment['PATH_INFO'])
|
||||||
|
|
||||||
-- override path arguments with command line parameter and allow to emulate GET/POST if debugging is enabled *and* if the autowifi special command wasn't mentioned
|
-- override path arguments with command line parameter and allow to emulate GET/POST if debugging is enabled *and* if the autowifi special command wasn't mentioned
|
||||||
if debugEnabled and self.requestMethod == 'CMDLINE' and self:get('autowifi') == nil then
|
if debugEnabled and self.requestMethod == 'CMDLINE' and self:get('autowifi') == nil then
|
||||||
|
@ -6,9 +6,9 @@ SCRIPT_PATH=/usr/share/lua/wifibox
|
|||||||
LOG_FILE=/tmp/wifibox.log
|
LOG_FILE=/tmp/wifibox.log
|
||||||
|
|
||||||
cd $SCRIPT_PATH
|
cd $SCRIPT_PATH
|
||||||
$LUA ./main.lua $@ 2>> $LOG_FILE
|
$LUA ./cmdmain.lua $@ 2>> $LOG_FILE
|
||||||
|
|
||||||
exit
|
exit $?
|
||||||
|
|
||||||
# Code below is for debugging incoming CGI data
|
# Code below is for debugging incoming CGI data
|
||||||
read -n $CONTENT_LENGTH POSTDATA
|
read -n $CONTENT_LENGTH POSTDATA
|
||||||
|
Loading…
Reference in New Issue
Block a user