0
0
mirror of https://github.com/Doodle3D/doodle3d-firmware.git synced 2024-12-31 23:13:48 +01:00

Documentation.

This commit is contained in:
Wouter R 2013-11-05 01:46:32 +01:00
parent 97564de8fc
commit 0e5726ee04
4 changed files with 98 additions and 42 deletions

View File

@ -1,13 +1,16 @@
--- This file wraps handle_request(env) in main.lua for command-line or CGI usage. ---
-- This file wraps @{main.handle_request} in main.lua for command-line or CGI usage.
-- It emulates the env table usually constructed by uhttpd-mod-lua. -- It emulates the env table usually constructed by uhttpd-mod-lua.
local main = require('main') local main = require('main')
--- Create an environment table mimicking the table uhttpd-mod-lua passes into handle_request(). --- Create an environment table mimicking the table uhttpd-mod-lua passes into @{main.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). -- The table is created using shell environment variables leaving out only 'DOCUMENT\_ROOT',
-- Fields present in the 'real' env table but not in this one are: 'HTTP_VERSION' -- 'SCRIPT\_PATH' and the regular shell variables (e.g., IFS, HOME and PS1).
-- 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'). -- 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. -- @treturn table An environment table created from shell environment variables.
local function createEnvTableFromShellEnvironment() local function createEnvTableFromShellEnvironment()
local environ = {} local environ = {}

View File

@ -1,3 +1,5 @@
---
-- Entry code of the REST API. This sets up the environment, processes a REST request and responds appropiately.
package.path = package.path .. ';/usr/share/lua/wifibox/?.lua' package.path = package.path .. ';/usr/share/lua/wifibox/?.lua'
local confDefaults = require('conf_defaults') local confDefaults = require('conf_defaults')
@ -208,11 +210,11 @@ local function main(environment)
end end
--- Main firmware entry point. --- Firmware entry point.
-- This is either used by uhttp-mod-lua directly, or by the d3dapi cgi-bin wrapper -- This is either used by [uhttp-mod-lua](http://wiki.openwrt.org/doc/uci/uhttpd#embedded.lua)
-- script which builds the env table from the shell environment. The wrapper script -- directly, or by the d3dapi cgi-bin wrapper script which builds the env table
-- also handles command-line invocation. -- from the shell environment. The wrapper script also handles command-line invocation.
-- @tparam table The CGI environment table. -- @tparam table env 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. -- @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) function handle_request(env)
local s, msg = init(env) local s, msg = init(env)

View File

@ -97,12 +97,13 @@ end
--- Adds a data item to the response, this will be included under the `data` item of the json text. --- Adds a data item to the response, this will be included under the `data` item of the json text.
-- --
-- NOTE: To add nested data with this method, it is necessary to precreate the table -- NOTE: To add nested data with this method, it is necessary to precreate the table
-- and then add that with its root key. (e.g., `response:addData('f_values', {f1=3, f2='x'})`) -- and then add that with its root key (see usage).
-- --
-- After calling this, any binary data set by @{M:setBinaryFileData} will not be sent anymore. -- After calling this, any binary data set by @{M:setBinaryFileData} will not be sent anymore.
-- --
-- @string k The key of the item to set. -- @string k The key of the item to set.
-- @param v The value to set. -- @param v The value to set.
-- @usage response:addData('f_values', {f1=3, f2='x'})
function M:addData(k, v) function M:addData(k, v)
self.body.data[k] = v self.body.data[k] = v
self.binaryData = nil self.binaryData = nil

View File

@ -261,8 +261,8 @@ local function downloadFile(url, saveDir, filename)
end end
--- Parses command-line arguments and returns a table containing information distilled from them. --- Parses command-line arguments and returns a table containing information distilled from them.
-- @tab arglist A table in the same form as the [arg table](http://www.lua.org/pil/1.4.html) created by Lua. -- @tparam table arglist A table in the same form as the [arg table](http://www.lua.org/pil/1.4.html) created by Lua.
-- @treturn tabla|nil A table containing information on what to do, or nil if invalid arguments were specified. -- @treturn table|nil A table containing information on what to do, or nil if invalid arguments were specified.
-- @treturn ?string Descriptive message on error. -- @treturn ?string Descriptive message on error.
local function parseCommandlineArguments(arglist) local function parseCommandlineArguments(arglist)
local result = { verbosity = 0, baseUrl = M.DEFAULT_BASE_URL, action = nil } local result = { verbosity = 0, baseUrl = M.DEFAULT_BASE_URL, action = nil }
@ -304,6 +304,16 @@ local function parseCommandlineArguments(arglist)
return result return result
end end
--- Returns the [MD5](http://en.wikipedia.org/wiki/MD5) hash for a given file.
--
-- NOTE: this function is not implemented, and a better hash function should probably be chosen anyway.
-- @string filepath The path of which to calculate the MD5-sum.
-- @treturn nil
local function md5sum(filepath)
return nil
-- TODO [osx: md5 -q <file>], [linux: ?]
end
@ -368,9 +378,9 @@ function M.getStatus()
return true, result return true, result
end end
-- Turns a plain-text version into a table. --- Turns a plain-text version as returned by @{formatVersion} into a table.
-- tables as argument are ignored so you can safely pass in an already parsed -- @tparam string|table versionText The version string to parse, if it is already a table, it is returned as-is.
-- version and expect it back unmodified. -- @treturn table A parse version.
function M.parseVersion(versionText) function M.parseVersion(versionText)
if type(versionText) == 'table' then return versionText end if type(versionText) == 'table' then return versionText end
if not versionText or versionText:len() == 0 then return nil end if not versionText or versionText:len() == 0 then return nil end
@ -381,15 +391,18 @@ function M.parseVersion(versionText)
return { ['major'] = major, ['minor'] = minor, ['patch'] = patch } return { ['major'] = major, ['minor'] = minor, ['patch'] = patch }
end end
-- Formats a version as returned by parseVersion(). --- Formats a version as returned by @{parseVersion}.
-- Strings are returned unmodified, so an 'already formatted' version can be -- @tparam table|string version The version to format, if it is already a string, that will be returned unmodified.
-- passed in safely and expected back unmodified. -- @treturn string A formatted version.
function M.formatVersion(version) function M.formatVersion(version)
if type(version) == 'string' then return version end if type(version) == 'string' then return version end
return version.major .. "." .. version.minor .. "." .. version.patch return version.major .. "." .. version.minor .. "." .. version.patch
end end
-- expects two tables as created by M.parseVersion() --- Compares two versions.
-- @tparam table versionA A version as returned by @{parseVersion}.
-- @tparam table versionB A version as returned by @{parseVersion}.
-- @treturn number -1 if versionA is smaller than versionB, 0 if versions are equal or 1 if versionA is larger than versionB.
function M.compareVersions(versionA, versionB) function M.compareVersions(versionA, versionB)
if type(versionA) ~= 'table' or type(versionB) ~= 'table' then return nil end if type(versionA) ~= 'table' or type(versionB) ~= 'table' then return nil end
local diff = versionA.major - versionB.major local diff = versionA.major - versionB.major
@ -398,7 +411,11 @@ function M.compareVersions(versionA, versionB)
return diff > 0 and 1 or (diff < 0 and -1 or 0) return diff > 0 and 1 or (diff < 0 and -1 or 0)
end end
-- verTable is optional, getAvailableVersions will be used to obtain it if nil --- Returns information on a version if it can be found in a collection of versions as returned by @{getAvailableVersions}.
-- @tparam table version The version to look for.
-- @tparam table[opt] verTable A table containing a collection of versions, if not passed in, it will be obtained using @{getAvailableVersions}.
-- @treturn table|nil Version information table found in the collection, or nil on error or if not found.
-- @treturn string Descriptive message in case of error or if the version could not be found.
function M.findVersion(version, verTable) function M.findVersion(version, verTable)
local msg = nil local msg = nil
version = M.parseVersion(version) version = M.parseVersion(version)
@ -412,7 +429,12 @@ function M.findVersion(version, verTable)
return nil,"no such version" return nil,"no such version"
end end
-- version may be a table or a string, devtype and isFactory are optional --- Creates an image file name based on given properties.
-- The generated name has the following form: `doodle3d-wifibox-<version>-<deviceType>-<'factory'|'sysupgrade'>.bin`.
-- @tparam table|string version The version of the image.
-- @string[opt] devType Openwrt device identifier (defaults to 'tl-mr3020').
-- @bool[opt] isFactory Switches between factory or sysupgrade image name.
-- @treturn string The constructed file name.
function M.constructImageFilename(version, devType, isFactory) function M.constructImageFilename(version, devType, isFactory)
local sf = isFactory and 'factory' or 'sysupgrade' local sf = isFactory and 'factory' or 'sysupgrade'
local v = M.formatVersion(version) local v = M.formatVersion(version)
@ -420,11 +442,16 @@ function M.constructImageFilename(version, devType, isFactory)
return 'doodle3d-wifibox-' .. M.formatVersion(v) .. '-' .. dt .. '-' .. sf .. '.bin' return 'doodle3d-wifibox-' .. M.formatVersion(v) .. '-' .. dt .. '-' .. sf .. '.bin'
end end
--TODO: move up to locals --- Checks whether a valid image file is present in @{CACHE_PATH} for the given image properties.
local function md5sum(filepath) -- The versionEntry table will be augmented with an `isValid` key.
-- TODO [osx: md5 -q <file>], [linux: ?] --
end -- NOTE: currently, this function only checks the image exists and has the correct size.
-- Sysupgrade will perform integrity checks, so this is not a major issue.
--
-- @tparam table versionEntry A version information table.
-- @string[opt] devType Image device type, see @{constructImageFilename}.
-- @bool[opt] isFactory Image type, see @{constructImageFilename}.
-- @treturn bool True if a valid image is present, false otherwise.
function M.checkValidImage(versionEntry, devType, isFactory) function M.checkValidImage(versionEntry, devType, isFactory)
local filename = M.constructImageFilename(versionEntry.version, devType, isFactory) local filename = M.constructImageFilename(versionEntry.version, devType, isFactory)
--return versionEntry.md5 == md5sum(M.CACHE_PATH .. '/' .. filename) --return versionEntry.md5 == md5sum(M.CACHE_PATH .. '/' .. filename)
@ -433,19 +460,23 @@ function M.checkValidImage(versionEntry, devType, isFactory)
return versionEntry.isValid return versionEntry.isValid
end end
-- returns a plain text version --- Returns the current wifibox version text, extracted from `/etc/wifibox-version`.
-- @treturn string Current version as plain-text.
function M.getCurrentVersionText() function M.getCurrentVersionText()
local res,msg,nr = readFile('/etc/wifibox-version', true) local res,msg,nr = readFile('/etc/wifibox-version', true)
if res then return res else return nil,msg,nr end if res then return res else return nil,msg,nr end
end end
-- returns a table with major, minor and patch as keys --- Returns the current wifibox version as a table with major, minor and patch as keys.
-- @treturn table Current version as version table.
function M.getCurrentVersion() function M.getCurrentVersion()
local vt,msg = M.getCurrentVersionText() local vt,msg = M.getCurrentVersionText()
return vt and M.parseVersion(vt) or nil,msg return vt and M.parseVersion(vt) or nil,msg
end end
-- returns an indexed (and sorted) table containing version tables --- Returns an indexed and sorted table containing version information tables.
-- The information is obtained from the either cached or downloaded image index (@{IMAGE_INDEX_FILE}).
-- @treturn table A table with a collection of version information tables.
function M.getAvailableVersions() function M.getAvailableVersions()
if not baseUrl then baseUrl = M.DEFAULT_BASE_URL end if not baseUrl then baseUrl = M.DEFAULT_BASE_URL end
local indexFilename = M.CACHE_PATH .. '/' .. M.IMAGE_INDEX_FILE local indexFilename = M.CACHE_PATH .. '/' .. M.IMAGE_INDEX_FILE
@ -515,8 +546,12 @@ function M.getAvailableVersions()
return result return result
end end
-- devtype and isFactory are optional --- Attempts to download an image file with the requested properties.
-- returns true or nil+msg or nil + return value from wget -- @tparam table versionEntry A version information table.
-- @string[opt] devType Image device type, see @{constructImageFilename}.
-- @bool[opt] isFactory Image type, see @{constructImageFilename}.
-- @treturn bool|nil True if successful, or nil on error.
-- @treturn ?string|number (optional) Descriptive message on general error, or wget exit status.
function M.downloadImageFile(versionEntry, devType, isFactory) function M.downloadImageFile(versionEntry, devType, isFactory)
if not baseUrl then baseUrl = M.DEFAULT_BASE_URL end if not baseUrl then baseUrl = M.DEFAULT_BASE_URL end
local filename = M.constructImageFilename(versionEntry.version, devType, isFactory) local filename = M.constructImageFilename(versionEntry.version, devType, isFactory)
@ -556,9 +591,15 @@ function M.downloadImageFile(versionEntry, devType, isFactory)
end end
end end
-- this function will not return if everything goes to plan --- Issues a [sysupgrade](http://wiki.openwrt.org/doc/howto/generic.sysupgrade) command with a wifibox image file.
-- noRetain, devType and isFactory are optional --
-- returns true or nil + wget return value -- This function will not return if it does its job successfully, the device will flash and reboot instead.
-- @tparam table versionEntry A version information table.
-- @bool[opt] noRetain If true, do not keep files in overlay filesystem (i.e., the '-n' switch in sysupgrade).
-- @string[opt] devType Image device type, see @{constructImageFilename}.
-- @bool[opt] isFactory Image type, see @{constructImageFilename}.
-- @treturn bool|nil True on success (with the 'exception' as noted above) or nil on error.
-- @treturn ?string|number (optional) Descriptive message or sysupgrade exit status on error.
function M.flashImageVersion(versionEntry, noRetain, devType, isFactory) function M.flashImageVersion(versionEntry, noRetain, devType, isFactory)
log:info("flashImageVersion") log:info("flashImageVersion")
local imgName = M.constructImageFilename(versionEntry.version, devType, isFactory) local imgName = M.constructImageFilename(versionEntry.version, devType, isFactory)
@ -586,7 +627,9 @@ function M.flashImageVersion(versionEntry, noRetain, devType, isFactory)
return (rv == 0) and true or nil,rv return (rv == 0) and true or nil,rv
end end
--returns true on success, or nil+msg otherwise --- Clears '*.bin' in the @{CACHE_PATH} directory.
-- @treturn bool|nil True on success, or nil on error.
-- @treturn ?string Descriptive message on error.
function M.clear() function M.clear()
local ccRv,ccMsg = createCacheDirectory() local ccRv,ccMsg = createCacheDirectory()
if not ccRv then return nil,ccMsg end if not ccRv then return nil,ccMsg end
@ -597,8 +640,15 @@ function M.clear()
return (rv == 0) and true or nil,"could not remove image files" return (rv == 0) and true or nil,"could not remove image files"
end end
-- NOTE: make sure the cache directory exists before calling this function or it will fail. --- Set updater state.
-- NOTE: this function _can_ fail but we don't expect this to happen so the return value is ignored for now --
-- NOTE: make sure the cache directory @{CACHE_PATH} exists before calling this function or it will fail.
--
-- NOTE: this function _can_ fail but this is not expected to happen so the return value is mostly ignored for now.
--
-- @number code The @{STATE} code to set.
-- @string msg The accompanying state message to set.
-- @treturn bool True on success or false if the state file could not be opened for writing.
function M.setState(code, msg) function M.setState(code, msg)
local s = code .. '|' .. msg local s = code .. '|' .. msg
D("set update state: " .. M.STATE_NAMES[code] .. " ('" .. s .. "')") D("set update state: " .. M.STATE_NAMES[code] .. " ('" .. s .. "')")