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

Added specific API:config/reset endpoint

This commit is contained in:
peteruithoven 2013-11-29 13:00:09 +01:00
parent b1bc8f5ded
commit c432325b89
2 changed files with 39 additions and 4 deletions

View File

@ -88,7 +88,21 @@ function M.all_GET(request, response)
end end
end end
function M.reset_POST(request, response)
--log:info("API:reset");
if not operationsAccessOrFail(request, response) then return end
response:setSuccess()
for k,v in pairs(request:getAll()) do
--log:info(" "..k..": "..v);
local r,m = settings.reset(k);
if r ~= nil then response:addData(k, "ok")
else response:addData(k, "could not reset key ('" .. m .. "')") end
end
end
function M.resetall_POST(request, response) function M.resetall_POST(request, response)
if not operationsAccessOrFail(request, response) then return end
response:setSuccess() response:setSuccess()
settings.resetAll() settings.resetAll()

View File

@ -4,6 +4,7 @@
-- if no value is stored in the UCI config. The UCI config file is `/etc/config/wifibox`. -- if no value is stored in the UCI config. The UCI config file is `/etc/config/wifibox`.
-- The default values guarantee there will always be a set of reasonable settings -- The default values guarantee there will always be a set of reasonable settings
-- to use and provide a clear overview of all existing configuration keys as well. -- to use and provide a clear overview of all existing configuration keys as well.
-- uci api: http://wiki.openwrt.org/doc/techref/uci, http://luci.subsignal.org/api/luci/modules/luci.model.uci.html
local uci = require('uci').cursor() local uci = require('uci').cursor()
local utils = require('util.utils') local utils = require('util.utils')
local baseconfig = require('conf_defaults') local baseconfig = require('conf_defaults')
@ -284,9 +285,9 @@ end
-- @treturn bool|nil True if everything went well, nil in case of error. -- @treturn bool|nil True if everything went well, nil in case of error.
function M.resetAll() function M.resetAll()
log:info("settings:resetAll") log:info("settings:resetAll")
end
local allSections = uci:get_all(UCI_CONFIG_NAME) local allSections = uci:get_all(UCI_CONFIG_NAME)
log:info(" allSections: "..utils.dump(allSections))
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
@ -306,10 +307,30 @@ end
-- @string key The key to reset. -- @string key The key to reset.
-- @treturn bool|nil True if everything went well, nil in case of error. -- @treturn bool|nil True if everything went well, nil in case of error.
function M.reset(key) function M.reset(key)
log:info("settings:reset") log:info("settings:reset: "..utils.dump(key))
--uci:foreach(UCI_CONFIG_NAME,UCI_CONFIG_TYPE)
--uci:delete(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, key)
key = replaceDots(key)
local base = getBaseKeyTable(key)
if not base then return nil,ERR_NO_SUCH_KEY end
local section = UCI_CONFIG_SECTION;
if base.subSection ~= nil then
log:info(" base.subSection: "..utils.dump(base.subSection))
section = M.get(base.subSection)
end
log:info(" section: "..utils.dump(section))
local uciV = fromUciValue(uci:get(UCI_CONFIG_NAME, section, key), base.type)
log:info(" uciV: "..utils.dump(uciV))
uci:delete(UCI_CONFIG_NAME, section, key)
local uciV = fromUciValue(uci:get(UCI_CONFIG_NAME, section, key), base.type)
log:info(" >uciV: "..utils.dump(uciV))
--log:info(" key: "..utils.dump(key))
uci:delete(UCI_CONFIG_NAME, UCI_CONFIG_SECTION, key)
uci:commit(UCI_CONFIG_NAME) uci:commit(UCI_CONFIG_NAME)
return true return true
end end