gluon-web-wifi-config: make mesh VIF options depend on outdoor=false
Instead of relying on the existence of interface sections only (which is
still used for the case of interface types that are not configured at
all in the site config), add a proper dependency.
This fixes section visiblity with enabled outdoor mode after the following
fix, and gives the user immediate feedback (allowing to disable outdoor
mode and enable meshing in a single step).
(cherry picked from commit d012d7d32f
)
This commit is contained in:
parent
63ca8f8bfa
commit
3d091912af
@ -47,13 +47,18 @@ f:section(Section, nil, translate(
|
|||||||
))
|
))
|
||||||
|
|
||||||
|
|
||||||
|
local mesh_vifs_5ghz = {}
|
||||||
|
|
||||||
|
|
||||||
uci:foreach('wireless', 'wifi-device', function(config)
|
uci:foreach('wireless', 'wifi-device', function(config)
|
||||||
local radio = config['.name']
|
local radio = config['.name']
|
||||||
|
|
||||||
|
local is_5ghz = false
|
||||||
local title
|
local title
|
||||||
if config.hwmode == '11g' or config.hwmode == '11ng' then
|
if config.hwmode == '11g' or config.hwmode == '11ng' then
|
||||||
title = translate("2.4GHz WLAN")
|
title = translate("2.4GHz WLAN")
|
||||||
elseif config.hwmode == '11a' or config.hwmode == '11na' then
|
elseif config.hwmode == '11a' or config.hwmode == '11na' then
|
||||||
|
is_5ghz = true
|
||||||
title = translate("5GHz WLAN")
|
title = translate("5GHz WLAN")
|
||||||
else
|
else
|
||||||
return
|
return
|
||||||
@ -95,10 +100,16 @@ uci:foreach('wireless', 'wifi-device', function(config)
|
|||||||
uci:set('wireless', interface .. '_' .. radio, 'disabled', not data)
|
uci:set('wireless', interface .. '_' .. radio, 'disabled', not data)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
return o
|
||||||
end
|
end
|
||||||
|
|
||||||
vif_option('client', {'client', 'owe'}, translate('Enable client network (access point)'))
|
vif_option('client', {'client', 'owe'}, translate('Enable client network (access point)'))
|
||||||
vif_option('mesh', {'mesh'}, translate("Enable mesh network (802.11s)"))
|
|
||||||
|
local mesh_vif = vif_option('mesh', {'mesh'}, translate("Enable mesh network (802.11s)"))
|
||||||
|
if is_5ghz then
|
||||||
|
table.insert(mesh_vifs_5ghz, mesh_vif)
|
||||||
|
end
|
||||||
|
|
||||||
local phy = wireless.find_phy(config)
|
local phy = wireless.find_phy(config)
|
||||||
if not phy then
|
if not phy then
|
||||||
@ -142,6 +153,10 @@ if has_5ghz_radio() then
|
|||||||
local outdoor = r:option(Flag, 'outdoor', translate("Node will be installed outdoors"))
|
local outdoor = r:option(Flag, 'outdoor', translate("Node will be installed outdoors"))
|
||||||
outdoor.default = uci:get_bool('gluon', 'wireless', 'outdoor')
|
outdoor.default = uci:get_bool('gluon', 'wireless', 'outdoor')
|
||||||
|
|
||||||
|
for _, mesh_vif in ipairs(mesh_vifs_5ghz) do
|
||||||
|
mesh_vif:depends(outdoor, false)
|
||||||
|
end
|
||||||
|
|
||||||
function outdoor:write(data)
|
function outdoor:write(data)
|
||||||
uci:set('gluon', 'wireless', 'outdoor', data)
|
uci:set('gluon', 'wireless', 'outdoor', data)
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user