mirror of
https://github.com/Doodle3D/doodle3d-firmware.git
synced 2024-12-22 11:03:48 +01:00
Replace URL decoder with a simpler implementation.
This commit is contained in:
parent
e1bdd9bcc7
commit
c5fd097b79
@ -14,12 +14,13 @@
|
|||||||
|
|
||||||
WIFIBOX_IP=192.168.5.1
|
WIFIBOX_IP=192.168.5.1
|
||||||
#WIFIBOX_IP=192.168.10.1
|
#WIFIBOX_IP=192.168.10.1
|
||||||
API_BASE=$WIFIBOX_IP/d3dapi
|
#API_BASE=$WIFIBOX_IP/d3dapi
|
||||||
|
API_BASE=$WIFIBOX_IP/cgi-bin/d3dapi
|
||||||
WGET=wget
|
WGET=wget
|
||||||
#REQUEST_PATH=network/status
|
#REQUEST_PATH=network/status
|
||||||
REQUEST_PATH=printer/print
|
REQUEST_PATH=printer/print
|
||||||
#POST_PARMS=--post-data=xyzzy
|
#POST_PARMS=--post-data=xyzzy
|
||||||
POST_PARMS=--post-file=lorem.txt
|
POST_PARMS=--post-file=200k.gcode
|
||||||
|
|
||||||
RETRIES=1
|
RETRIES=1
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@ M.resolutionError = nil --non-nil means function could not be resolved
|
|||||||
local function kvTableFromUrlEncodedString(encodedText)
|
local function kvTableFromUrlEncodedString(encodedText)
|
||||||
local args = {}
|
local args = {}
|
||||||
if (encodedText ~= nil) then
|
if (encodedText ~= nil) then
|
||||||
urlcode.parsequery(encodedText, args)
|
urlcode.parsequeryNoRegex(encodedText, args)
|
||||||
end
|
end
|
||||||
return args
|
return args
|
||||||
|
|
||||||
|
70
src/test/test_urlcode.lua
Normal file
70
src/test/test_urlcode.lua
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
-- TODO: also test malformed query strings
|
||||||
|
local urlcode = require("util.urlcode")
|
||||||
|
|
||||||
|
local M = {
|
||||||
|
_is_test = true,
|
||||||
|
_skip = {},
|
||||||
|
_wifibox_only = {}
|
||||||
|
}
|
||||||
|
|
||||||
|
-- NOTE: the previous approach using #t1 and #t2 was too naive and only worked for tables with contiguous ranges of numeric keys.
|
||||||
|
local function compareTables(t1, t2)
|
||||||
|
local len = 0
|
||||||
|
|
||||||
|
for k1,v1 in pairs(t1) do
|
||||||
|
len = len + 1
|
||||||
|
if t2[k1] ~= v1 then return false end
|
||||||
|
end
|
||||||
|
|
||||||
|
for _ in pairs(t2) do len = len - 1 end
|
||||||
|
|
||||||
|
return len == 0 and true or false
|
||||||
|
end
|
||||||
|
|
||||||
|
local queryTexts = {
|
||||||
|
[1] = "k1=v1&k2=v2x&k3yy=v3",
|
||||||
|
[2] = "k1=v1&k2=v2x&k3yy=v3&",
|
||||||
|
[3] = "k1=v1&k2=v2x&k3yy=v3&=",
|
||||||
|
[4] = "k1=v1&k2=v2x&k3yy=v3& =",
|
||||||
|
[5] = ""
|
||||||
|
}
|
||||||
|
|
||||||
|
local queryTables = {
|
||||||
|
[1] = { ["k1"] = "v1", ["k2"] = "v2x", ["k3yy"] = "v3" },
|
||||||
|
[2] = { ["k1"] = "v1", ["k2"] = "v2x", ["k3yy"] = "v3" },
|
||||||
|
[3] = { ["k1"] = "v1", ["k2"] = "v2x", ["k3yy"] = "v3" },
|
||||||
|
[4] = { ["k1"] = "v1", ["k2"] = "v2x", ["k3yy"] = "v3", [" "] = "" },
|
||||||
|
[5] = {}
|
||||||
|
}
|
||||||
|
|
||||||
|
function M:_setup()
|
||||||
|
local longValue = ""
|
||||||
|
for i=1,5000 do
|
||||||
|
longValue = longValue .. i .. ": abcdefghijklmnopqrstuvwxyz\n"
|
||||||
|
end
|
||||||
|
|
||||||
|
table.insert(queryTexts, "shortkey=&longkey=" .. longValue)
|
||||||
|
table.insert(queryTables, { ["shortkey"] = "", ["longkey"] = longValue })
|
||||||
|
end
|
||||||
|
|
||||||
|
function M:_teardown()
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function M:test_parsequery()
|
||||||
|
for i=1,#queryTexts do
|
||||||
|
local args = {}
|
||||||
|
urlcode.parsequery(queryTexts[i], args)
|
||||||
|
assert(compareTables(queryTables[i], args))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function M:test_parsequeryNoRegex()
|
||||||
|
for i=1,#queryTexts do
|
||||||
|
local args = {}
|
||||||
|
urlcode.parsequeryNoRegex(queryTexts[i], args)
|
||||||
|
assert(compareTables(queryTables[i], args))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return M
|
@ -87,6 +87,38 @@ end)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- Parse url-encoded request data without using regular expressions
|
||||||
|
-- (the query part of the script URL or url-encoded post data)
|
||||||
|
--
|
||||||
|
-- Each decoded (name=value) pair is inserted into table [[args]]
|
||||||
|
-- @param query String to be parsed.
|
||||||
|
-- @param args Table where to store the pairs.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
function _M.parsequeryNoRegex (query, args)
|
||||||
|
if type(query) == "string" then
|
||||||
|
local insertfield, unescape = _M.insertfield, _M.unescape
|
||||||
|
|
||||||
|
local k = 1
|
||||||
|
while true do
|
||||||
|
local v = query:find('=', k+1, true) -- look for '=', assuming a key of at least 1 character and do not perform pattern matching
|
||||||
|
if not v then break end -- no k/v pairs left
|
||||||
|
|
||||||
|
v = v + 1
|
||||||
|
local ampersand = query:find('&', v, true)
|
||||||
|
if not ampersand then ampersand = 0 end -- 0 will become -1 in the substring call below...meaning end of string
|
||||||
|
|
||||||
|
local key = query:sub(k, v-1)
|
||||||
|
local value = query:sub(v, ampersand - 1)
|
||||||
|
insertfield (args, unescape(key), unescape(value))
|
||||||
|
|
||||||
|
if ampersand == 0 then break end -- we couldn't find any ampersands anymore so this was the last k/v
|
||||||
|
|
||||||
|
k = ampersand + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
----------------------------------------------------------------------------
|
----------------------------------------------------------------------------
|
||||||
-- URL-encode the elements of a table creating a string to be used in a
|
-- URL-encode the elements of a table creating a string to be used in a
|
||||||
-- URL for passing data/parameters to another script
|
-- URL for passing data/parameters to another script
|
||||||
|
Loading…
Reference in New Issue
Block a user