mirror of
https://github.com/Doodle3D/doodle3d-firmware.git
synced 2025-01-03 08:13:49 +01:00
Better uci error handling
This commit is contained in:
parent
1668cd446a
commit
bd1409b6a6
@ -124,6 +124,12 @@ local function setupLogger()
|
|||||||
else logTargetError = msg
|
else logTargetError = msg
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
else
|
||||||
|
-- if uci config not available, fallback to /tmp/wifibox.log
|
||||||
|
local f,msg = io.open('/tmp/wifibox.log', 'a+')
|
||||||
|
if f then logStream = f
|
||||||
|
else logTargetError = msg
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if type(logLevelSetting) == 'string' and logLevelSetting:len() > 0 then
|
if type(logLevelSetting) == 'string' and logLevelSetting:len() > 0 then
|
||||||
|
@ -40,8 +40,12 @@ function M._global_GET(request, response)
|
|||||||
for k,v in pairs(request:getAll()) do
|
for k,v in pairs(request:getAll()) do
|
||||||
local r,m = settings.get(k)
|
local r,m = settings.get(k)
|
||||||
|
|
||||||
if r ~= nil then response:addData(k, r)
|
if r ~= nil then
|
||||||
else response:addData(k, "could not read key ('" .. m .. "')")
|
response:addData(k, r)
|
||||||
|
else
|
||||||
|
response:addData(k, "could not read key ('" .. m .. "')")
|
||||||
|
response:setError(m)
|
||||||
|
return false;
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -59,12 +63,13 @@ function M._global_POST(request, response)
|
|||||||
local r,m = settings.set(k, v)
|
local r,m = settings.set(k, v)
|
||||||
|
|
||||||
if r then
|
if r then
|
||||||
--response:addData(k, "ok")
|
|
||||||
validation[k] = "ok"
|
validation[k] = "ok"
|
||||||
else
|
elseif r == false then
|
||||||
--response:addData(k, "could not save setting ('" .. m .. "')")
|
|
||||||
validation[k] = "could not save setting ('" .. m .. "')"
|
validation[k] = "could not save setting ('" .. m .. "')"
|
||||||
log:info(" m: "..utils.dump(m))
|
log:info(" m: "..utils.dump(m))
|
||||||
|
elseif r == nil then
|
||||||
|
response:setError(m)
|
||||||
|
return false;
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
response:addData("validation",validation)
|
response:addData("validation",validation)
|
||||||
@ -82,9 +87,15 @@ function M._global_POST(request, response)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function M.all_GET(request, response)
|
function M.all_GET(request, response)
|
||||||
response:setSuccess()
|
local allSettings, msg = settings.getAll();
|
||||||
for k,v in pairs(settings.getAll()) do
|
if allSettings then
|
||||||
response:addData(k,v)
|
response:setSuccess()
|
||||||
|
for k,v in pairs(settings.getAll()) do
|
||||||
|
response:addData(k,v)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
response:setError(msg)
|
||||||
|
return false;
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -102,8 +113,13 @@ function M.reset_POST(request, response)
|
|||||||
for k,v in pairs(request:getAll()) do
|
for k,v in pairs(request:getAll()) do
|
||||||
--log:info(" "..k..": "..v);
|
--log:info(" "..k..": "..v);
|
||||||
local r,m = settings.reset(k);
|
local r,m = settings.reset(k);
|
||||||
if r ~= nil then response:addData(k, "ok")
|
if r ~= nil then
|
||||||
else response:addData(k, "could not reset key ('" .. m .. "')") end
|
response:addData(k, "ok")
|
||||||
|
else
|
||||||
|
response:addData(k, "could not reset key ('" .. m .. "')")
|
||||||
|
response:setError(m)
|
||||||
|
return false;
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -111,7 +127,13 @@ end
|
|||||||
function M.resetall_POST(request, response)
|
function M.resetall_POST(request, response)
|
||||||
if not operationsAccessOrFail(request, response) then return end
|
if not operationsAccessOrFail(request, response) then return end
|
||||||
response:setSuccess()
|
response:setSuccess()
|
||||||
settings.resetAll()
|
|
||||||
|
local rv, msg = settings.resetAll()
|
||||||
|
|
||||||
|
if(rv == nil) then
|
||||||
|
response:setError(msg)
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
for k,v in pairs(settings.getAll()) do
|
for k,v in pairs(settings.getAll()) do
|
||||||
response:addData(k,v)
|
response:addData(k,v)
|
||||||
|
@ -161,7 +161,14 @@ function M.get(key)
|
|||||||
section = M.get(base.subSection)
|
section = M.get(base.subSection)
|
||||||
end
|
end
|
||||||
|
|
||||||
local uciV = fromUciValue(uci:get(UCI_CONFIG_NAME, section, key), base.type)
|
local uciV,msg = uci:get(UCI_CONFIG_NAME, section, key)
|
||||||
|
if not uciV and msg ~= nil then
|
||||||
|
local errorMSG = "Issue reading setting '"..utils.dump(key).."': "..utils.dump(msg);
|
||||||
|
log:info(errorMSG)
|
||||||
|
return nil, errorMSG;
|
||||||
|
end
|
||||||
|
|
||||||
|
local uciV = fromUciValue(uciV, base.type)
|
||||||
if uciV ~= nil then
|
if uciV ~= nil then
|
||||||
-- returning value from uci
|
-- returning value from uci
|
||||||
return uciV
|
return uciV
|
||||||
@ -183,7 +190,12 @@ function M.getAll()
|
|||||||
for k,_ in pairs(baseconfig) do
|
for k,_ in pairs(baseconfig) do
|
||||||
if not k:match('^[A-Z_]*$') then --TEMP: skip 'constants', which should be moved anyway
|
if not k:match('^[A-Z_]*$') then --TEMP: skip 'constants', which should be moved anyway
|
||||||
local key = replaceUnderscores(k)
|
local key = replaceUnderscores(k)
|
||||||
result[key] = M.get(key)
|
local v, msg = M.get(key)
|
||||||
|
if not uciV and msg ~= nil then
|
||||||
|
return nil, msg
|
||||||
|
else
|
||||||
|
result[key] = v
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return result
|
return result
|
||||||
@ -213,17 +225,22 @@ end
|
|||||||
--- Sets a key to a new value or reverts it to the default value.
|
--- Sets a key to a new value or reverts it to the default value.
|
||||||
-- @string key The key to set.
|
-- @string key The key to set.
|
||||||
-- @p[opt=nil] value The value or set, or nil to revert key to its default value.
|
-- @p[opt=nil] value The value or set, or nil to revert key to its default value.
|
||||||
-- @treturn bool|nil True if everything went well, nil in case of error.
|
-- @treturn bool|nil True if everything went well, false if validation error, nil in case of error.
|
||||||
-- @treturn ?string Error message in case first return value is nil (invalid key).
|
-- @treturn ?string Error message in case first return value is nil (invalid key).
|
||||||
function M.set(key, value)
|
function M.set(key, value)
|
||||||
log:info("settings:set: "..utils.dump(key).." to: "..utils.dump(value))
|
log:info("settings:set: "..utils.dump(key).." to: "..utils.dump(value))
|
||||||
key = replaceDots(key)
|
key = replaceDots(key)
|
||||||
|
|
||||||
local r = utils.create(UCI_CONFIG_FILE)
|
local r = utils.create(UCI_CONFIG_FILE)
|
||||||
uci:set(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, UCI_CONFIG_TYPE)
|
local rv, msg = uci:set(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, UCI_CONFIG_TYPE)
|
||||||
|
if not rv and msg ~= nil then
|
||||||
|
local errorMSG = "Issue creating section '"..utils.dump(UCI_CONFIG_SECTION).."': "..utils.dump(msg);
|
||||||
|
log:info(errorMSG)
|
||||||
|
return nil, errorMSG;
|
||||||
|
end
|
||||||
|
|
||||||
local base = getBaseKeyTable(key)
|
local base = getBaseKeyTable(key)
|
||||||
if not base then return nil,ERR_NO_SUCH_KEY end
|
if not base then return false,ERR_NO_SUCH_KEY end
|
||||||
|
|
||||||
--log:info(" base.type: "..utils.dump(base.type))
|
--log:info(" base.type: "..utils.dump(base.type))
|
||||||
if base.type == 'bool' then
|
if base.type == 'bool' then
|
||||||
@ -235,26 +252,41 @@ function M.set(key, value)
|
|||||||
elseif base.type == 'int' or base.type == 'float' then
|
elseif base.type == 'int' or base.type == 'float' then
|
||||||
value = tonumber(value)
|
value = tonumber(value)
|
||||||
if(value == nil) then
|
if(value == nil) then
|
||||||
return nil,"Value isn't a valid int or float"
|
return false,"Value isn't a valid int or float"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
local valid,m = isValid(value, base)
|
local valid,m = isValid(value, base)
|
||||||
if not valid then
|
if not valid then
|
||||||
return nil,m
|
return false,m
|
||||||
end
|
end
|
||||||
|
|
||||||
local section = UCI_CONFIG_SECTION;
|
local section = UCI_CONFIG_SECTION;
|
||||||
if base.subSection ~= nil then
|
if base.subSection ~= nil then
|
||||||
section = M.get(base.subSection)
|
section = M.get(base.subSection)
|
||||||
uci:set(UCI_CONFIG_NAME, section, UCI_CONFIG_TYPE)
|
local rv, msg = uci:set(UCI_CONFIG_NAME, section, UCI_CONFIG_TYPE)
|
||||||
|
if not rv and msg ~= nil then
|
||||||
|
local errorMSG = "Issue creating subsection '"..utils.dump(section).."': "..utils.dump(msg);
|
||||||
|
log:info(errorMSG)
|
||||||
|
return nil, errorMSG;
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if value ~= nil then
|
if value ~= nil then
|
||||||
uci:set(UCI_CONFIG_NAME, section, key, toUciValue(value, base.type))
|
local rv, msg = uci:set(UCI_CONFIG_NAME, section, key, toUciValue(value, base.type))
|
||||||
|
if not rv and msg ~= nil then
|
||||||
|
local errorMSG = "Issue setting setting '"..utils.dump(key).."' in section '"..utils.dump(section).."': "..utils.dump(msg);
|
||||||
|
log:info(errorMSG)
|
||||||
|
return nil, errorMSG;
|
||||||
|
end
|
||||||
else
|
else
|
||||||
uci:delete(UCI_CONFIG_NAME, section, key)
|
local rv, msg = uci:delete(UCI_CONFIG_NAME, section, key)
|
||||||
|
if not rv and msg ~= nil then
|
||||||
|
local errorMSG = "Issue deleting setting '"..utils.dump(key).."' in section '"..utils.dump(section).."': "..utils.dump(msg);
|
||||||
|
log:info(errorMSG)
|
||||||
|
return nil, errorMSG;
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
uci:commit(UCI_CONFIG_NAME)
|
uci:commit(UCI_CONFIG_NAME)
|
||||||
@ -268,11 +300,21 @@ function M.resetAll()
|
|||||||
log:info("settings:resetAll")
|
log:info("settings:resetAll")
|
||||||
|
|
||||||
-- delete all uci sections but system
|
-- delete all uci sections but system
|
||||||
local allSections = uci:get_all(UCI_CONFIG_NAME)
|
local allSections, msg = uci:get_all(UCI_CONFIG_NAME)
|
||||||
|
if not allSections and msg ~= nil then
|
||||||
|
local errorMSG = "Issue reading all settings: "..utils.dump(msg);
|
||||||
|
log:info(errorMSG)
|
||||||
|
return nil, errorMSG;
|
||||||
|
end
|
||||||
|
|
||||||
for key,value in pairs(allSections) do
|
for key,value in pairs(allSections) do
|
||||||
if key ~= "system" and not key:match('^[A-Z_]*$') then --TEMP: skip 'constants', which should be moved anyway
|
if key ~= "system" and not key:match('^[A-Z_]*$') then --TEMP: skip 'constants', which should be moved anyway
|
||||||
|
local rv, msg = uci:delete(UCI_CONFIG_NAME,key)
|
||||||
uci:delete(UCI_CONFIG_NAME,key)
|
if not rv and msg ~= nil then
|
||||||
|
local errorMSG = "Issue deleting setting '"..utils.dump(key).."': "..utils.dump(msg);
|
||||||
|
log:info(errorMSG)
|
||||||
|
return nil, errorMSG;
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -302,7 +344,12 @@ function M.reset(key)
|
|||||||
if base.subSection ~= nil then
|
if base.subSection ~= nil then
|
||||||
section = M.get(base.subSection)
|
section = M.get(base.subSection)
|
||||||
end
|
end
|
||||||
uci:delete(UCI_CONFIG_NAME, section, key)
|
local rv, msg = uci:delete(UCI_CONFIG_NAME, section, key)
|
||||||
|
if not rv and msg ~= nil then
|
||||||
|
local errorMSG = "Issue deleting setting '"..utils.dump(key).."' in section '"..section.."': "..utils.dump(msg);
|
||||||
|
log:info(errorMSG)
|
||||||
|
return nil, errorMSG;
|
||||||
|
end
|
||||||
|
|
||||||
-- reuse get logic to retrieve default and set it.
|
-- reuse get logic to retrieve default and set it.
|
||||||
M.set(key,M.get(key))
|
M.set(key,M.get(key))
|
||||||
@ -317,7 +364,12 @@ end
|
|||||||
-- @return Requested value or false if it does not exist or nil on invalid key.
|
-- @return Requested value or false if it does not exist or nil on invalid key.
|
||||||
function M.getSystemKey(key)
|
function M.getSystemKey(key)
|
||||||
if type(key) ~= 'string' or key:len() == 0 then return nil end
|
if type(key) ~= 'string' or key:len() == 0 then return nil end
|
||||||
local v = uci:get(UCI_CONFIG_NAME, UCI_CONFIG_SYSTEM_SECTION, key)
|
local v,msg = uci:get(UCI_CONFIG_NAME, UCI_CONFIG_SYSTEM_SECTION, key)
|
||||||
|
if not v and msg ~= nil then
|
||||||
|
local errorMSG = "Issue getting system setting '"..utils.dump(key).."' in section '"..UCI_CONFIG_SYSTEM_SECTION.."': "..utils.dump(msg);
|
||||||
|
return nil, errorMSG;
|
||||||
|
end
|
||||||
|
|
||||||
return v or false
|
return v or false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user