Merge pull request #2223 from freifunk-gluon/wizard-reconfigure
Simplify save/commit handling of config wizard sections
This commit is contained in:
commit
17dd5abd75
@ -21,7 +21,6 @@ return function(form, uci)
|
||||
o.optional = true
|
||||
function o:write(data)
|
||||
uci:set("gluon-node-info", owner, "contact", data)
|
||||
uci:save("gluon-node-info")
|
||||
end
|
||||
|
||||
return {'gluon-node-info'}
|
||||
end
|
||||
|
@ -1,15 +1,6 @@
|
||||
local util = require "gluon.util"
|
||||
local uci = require("simple-uci").cursor()
|
||||
|
||||
|
||||
local wizard = {}
|
||||
for _, entry in ipairs(util.glob('/lib/gluon/config-mode/wizard/*')) do
|
||||
local f = assert(loadfile(entry))
|
||||
setfenv(f, getfenv())
|
||||
local w = f()
|
||||
table.insert(wizard, w)
|
||||
end
|
||||
|
||||
local f = Form(translate("Welcome!"))
|
||||
f.submit = translate('Save & restart')
|
||||
f.reset = false
|
||||
@ -18,21 +9,10 @@ local s = f:section(Section)
|
||||
s.template = "wizard/welcome"
|
||||
s.package = "gluon-config-mode-core"
|
||||
|
||||
local commit = {'gluon-setup-mode'}
|
||||
local run = {}
|
||||
|
||||
for _, w in ipairs(wizard) do
|
||||
for _, c in ipairs(w(f, uci) or {}) do
|
||||
if type(c) == 'string' then
|
||||
if not util.contains(commit, c) then
|
||||
table.insert(commit, c)
|
||||
end
|
||||
elseif type(c) == 'function' then
|
||||
table.insert(run, c)
|
||||
else
|
||||
error('invalid wizard module return')
|
||||
end
|
||||
end
|
||||
for _, entry in ipairs(util.glob('/lib/gluon/config-mode/wizard/*')) do
|
||||
local section = assert(loadfile(entry))
|
||||
setfenv(section, getfenv())
|
||||
section()(f, uci)
|
||||
end
|
||||
|
||||
function f:write()
|
||||
@ -40,13 +20,9 @@ function f:write()
|
||||
local unistd = require 'posix.unistd'
|
||||
|
||||
uci:set("gluon-setup-mode", uci:get_first("gluon-setup-mode", "setup_mode"), "configured", true)
|
||||
uci:save("gluon-setup-mode")
|
||||
|
||||
for _, c in ipairs(commit) do
|
||||
uci:commit(c)
|
||||
end
|
||||
for _, r in ipairs(run) do
|
||||
r()
|
||||
end
|
||||
os.execute('gluon-reconfigure')
|
||||
|
||||
f.template = "wizard/reboot"
|
||||
f.package = "gluon-config-mode-core"
|
||||
|
@ -49,20 +49,8 @@ return function(form, uci)
|
||||
o:value(domain.domain_code, domain.domain_name)
|
||||
end
|
||||
|
||||
local domain_changed = false
|
||||
|
||||
function o:write(data)
|
||||
if data ~= selected_domain then
|
||||
domain_changed = true
|
||||
uci:set('gluon', 'core', 'domain', data)
|
||||
uci:save('gluon')
|
||||
end
|
||||
end
|
||||
|
||||
local function reconfigure()
|
||||
if domain_changed then
|
||||
os.execute('gluon-reconfigure')
|
||||
end
|
||||
end
|
||||
|
||||
return {'gluon', reconfigure}
|
||||
end
|
||||
|
@ -100,5 +100,7 @@ return function(form, uci)
|
||||
end
|
||||
end
|
||||
|
||||
return {'gluon-node-info'}
|
||||
function s:write()
|
||||
uci:save("gluon-node-info")
|
||||
end
|
||||
end
|
||||
|
@ -30,7 +30,6 @@ return function(form, uci)
|
||||
|
||||
function o:write(data)
|
||||
pretty_hostname.set(uci, data or default_hostname)
|
||||
uci:save('system')
|
||||
end
|
||||
|
||||
return {'system'}
|
||||
end
|
||||
|
@ -58,11 +58,7 @@ return function(form, uci)
|
||||
uci:set("gluon", "mesh_vpn", "limit_egress", data * 1000)
|
||||
end
|
||||
|
||||
function s:handle()
|
||||
Section.handle(s)
|
||||
function s:write()
|
||||
uci:save('gluon')
|
||||
os.execute('exec /lib/gluon/mesh-vpn/update-config')
|
||||
end
|
||||
|
||||
return {'gluon', 'fastd', 'tunneldigger', 'simple-tc'}
|
||||
end
|
||||
|
@ -44,10 +44,6 @@ return function(form, uci)
|
||||
end
|
||||
uci:save('wireless')
|
||||
end
|
||||
|
||||
os.execute('/lib/gluon/upgrade/200-wireless')
|
||||
end
|
||||
end
|
||||
|
||||
return {'gluon', 'network', 'wireless'}
|
||||
end
|
||||
|
@ -53,6 +53,7 @@ function Node:__init__(name, title, description)
|
||||
self.name = name
|
||||
self.index = nil
|
||||
self.parent = nil
|
||||
self.state = M.FORM_NODATA
|
||||
self.package = 'gluon-web-model'
|
||||
end
|
||||
|
||||
@ -73,17 +74,32 @@ function Node:id()
|
||||
end
|
||||
|
||||
function Node:reset_node()
|
||||
self.state = M.FORM_NODATA
|
||||
for _, child in ipairs(self.children) do
|
||||
child:reset_node()
|
||||
end
|
||||
end
|
||||
|
||||
function Node:parse(http)
|
||||
self.state = M.FORM_VALID
|
||||
for _, child in ipairs(self.children) do
|
||||
child:parse(http)
|
||||
end
|
||||
end
|
||||
|
||||
function Node:propagate_state()
|
||||
if self.state == M.FORM_NODATA then
|
||||
return
|
||||
end
|
||||
|
||||
for _, child in ipairs(self.children) do
|
||||
child:propagate_state()
|
||||
if child.state == M.FORM_INVALID then
|
||||
self.state = M.FORM_INVALID
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
function Node:render(renderer, scope)
|
||||
if self.template then
|
||||
local env = setmetatable({
|
||||
@ -158,10 +174,17 @@ function Node:resolve_node_depends()
|
||||
return true
|
||||
end
|
||||
|
||||
-- will be overridden: write(value)
|
||||
function Node:write()
|
||||
end
|
||||
|
||||
function Node:handle()
|
||||
if self.state == M.FORM_VALID then
|
||||
for _, node in ipairs(self.children) do
|
||||
node:handle()
|
||||
end
|
||||
self:write(self.data)
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
@ -187,7 +210,6 @@ function AbstractValue:__init__(...)
|
||||
self.template = "model/valuewrapper"
|
||||
|
||||
self.error = false
|
||||
self.state = M.FORM_NODATA
|
||||
end
|
||||
|
||||
function AbstractValue:defaultvalue()
|
||||
@ -250,16 +272,6 @@ function AbstractValue:validate()
|
||||
|
||||
end
|
||||
|
||||
function AbstractValue:handle()
|
||||
if self.state == M.FORM_VALID then
|
||||
self:write(self.data)
|
||||
end
|
||||
end
|
||||
|
||||
-- will be overridden: write(value)
|
||||
function AbstractValue:write()
|
||||
end
|
||||
|
||||
|
||||
local Value = class(AbstractValue)
|
||||
M.Value = Value
|
||||
@ -438,26 +450,7 @@ function Form:parse(http)
|
||||
|
||||
while self:resolve_depends() do end
|
||||
|
||||
for _, s in ipairs(self.children) do
|
||||
for _, v in ipairs(s.children) do
|
||||
if v.state == M.FORM_INVALID then
|
||||
self.state = M.FORM_INVALID
|
||||
return
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
self.state = M.FORM_VALID
|
||||
end
|
||||
|
||||
function Form:handle()
|
||||
if self.state == M.FORM_VALID then
|
||||
Node.handle(self)
|
||||
self:write()
|
||||
end
|
||||
end
|
||||
|
||||
function Form:write()
|
||||
self:propagate_state()
|
||||
end
|
||||
|
||||
function Form:section(t, ...)
|
||||
|
Loading…
Reference in New Issue
Block a user