mesh-ba-core: split wireless config (base, mesh, client)

This commit is contained in:
Nils Schneider 2015-03-10 15:59:31 +01:00
parent 0f08020d39
commit 8dfea9e485
3 changed files with 144 additions and 71 deletions

View File

@ -12,87 +12,25 @@ local function configure_radio(radio, index, config)
uci:set('wireless', radio, 'channel', config.channel)
uci:set('wireless', radio, 'htmode', config.htmode)
uci:set('wireless', radio, 'country', site.regdom)
local client = 'client_' .. radio
local mesh = 'mesh_' .. radio
local client_ifname
local mesh_ifname
local radio_suffix = radio:match('^radio(%d+)$')
if radio_suffix then
client_ifname = 'client' .. radio_suffix
mesh_ifname = 'mesh' .. radio_suffix
end
uci:delete('wireless', client)
uci:section('wireless', 'wifi-iface', client,
{
device = radio,
network = 'client',
mode = 'ap',
ssid = config.ssid,
macaddr = util.generate_mac(2, index),
ifname = client_ifname,
}
)
uci:delete('network', mesh)
uci:delete('network', mesh .. '_vlan')
if config.mesh_vlan then
uci:section('network', 'interface', mesh,
{
proto = 'none',
}
)
uci:section('network', 'interface', mesh .. '_vlan',
{
ifname = '@' .. mesh .. '.' .. config.mesh_vlan,
proto = 'batadv',
mesh = 'bat0',
}
)
else
uci:section('network', 'interface', mesh,
{
proto = 'batadv',
mesh = 'bat0',
}
)
end
uci:delete('wireless', mesh)
uci:section('wireless', 'wifi-iface', mesh,
{
device = radio,
network = mesh,
mode = 'adhoc',
ssid = config.mesh_ssid,
bssid = config.mesh_bssid,
macaddr = util.generate_mac(3, index),
mcast_rate = config.mesh_mcast_rate,
ifname = mesh_ifname,
}
)
end
local radios = {}
uci:foreach('wireless', 'wifi-device',
function(s)
table.insert(radios, s['.name'])
end
function(s)
table.insert(radios, s['.name'])
end
)
for index, radio in ipairs(radios) do
local hwmode = uci:get('wireless', radio, 'hwmode')
local hwmode = uci:get('wireless', radio, 'hwmode')
if hwmode == '11g' then
configure_radio(radio, index, site.wifi24)
elseif hwmode == '11a' then
configure_radio(radio, index, site.wifi5)
end
if hwmode == '11g' then
configure_radio(radio, index, site.wifi24)
elseif hwmode == '11a' then
configure_radio(radio, index, site.wifi5)
end
end

View File

@ -0,0 +1,54 @@
#!/usr/bin/lua
local site = require 'gluon.site_config'
local util = require 'gluon.util'
local uci = require('luci.model.uci').cursor()
local function configure_radio(radio, index, config)
local client = 'client_' .. radio
local client_ifname
local radio_suffix = radio:match('^radio(%d+)$')
if radio_suffix then
client_ifname = 'client' .. radio_suffix
end
uci:delete('wireless', client)
uci:section('wireless', 'wifi-iface', client,
{
device = radio,
network = 'client',
mode = 'ap',
ssid = config.ssid,
macaddr = util.generate_mac(2, index),
ifname = client_ifname,
}
)
end
local radios = {}
uci:foreach('wireless', 'wifi-device',
function(s)
table.insert(radios, s['.name'])
end
)
for index, radio in ipairs(radios) do
local hwmode = uci:get('wireless', radio, 'hwmode')
if hwmode == '11g' then
configure_radio(radio, index, site.wifi24)
elseif hwmode == '11a' then
configure_radio(radio, index, site.wifi5)
end
end
uci:save('wireless')
uci:save('network')
uci:commit('wireless')
uci:commit('network')

View File

@ -0,0 +1,81 @@
#!/usr/bin/lua
local site = require 'gluon.site_config'
local util = require 'gluon.util'
local uci = require('luci.model.uci').cursor()
local function configure_radio(radio, index, config)
local mesh = 'mesh_' .. radio
local mesh_ifname
local radio_suffix = radio:match('^radio(%d+)$')
if radio_suffix then
mesh_ifname = 'mesh' .. radio_suffix
end
uci:delete('network', mesh)
uci:delete('network', mesh .. '_vlan')
if config.mesh_vlan then
uci:section('network', 'interface', mesh,
{
proto = 'none',
}
)
uci:section('network', 'interface', mesh .. '_vlan',
{
ifname = '@' .. mesh .. '.' .. config.mesh_vlan,
proto = 'batadv',
mesh = 'bat0',
}
)
else
uci:section('network', 'interface', mesh,
{
proto = 'batadv',
mesh = 'bat0',
}
)
end
uci:delete('wireless', mesh)
uci:section('wireless', 'wifi-iface', mesh,
{
device = radio,
network = mesh,
mode = 'adhoc',
ssid = config.mesh_ssid,
bssid = config.mesh_bssid,
macaddr = util.generate_mac(3, index),
mcast_rate = config.mesh_mcast_rate,
ifname = mesh_ifname,
}
)
end
local radios = {}
uci:foreach('wireless', 'wifi-device',
function(s)
table.insert(radios, s['.name'])
end
)
for index, radio in ipairs(radios) do
local hwmode = uci:get('wireless', radio, 'hwmode')
if hwmode == '11g' then
configure_radio(radio, index, site.wifi24)
elseif hwmode == '11a' then
configure_radio(radio, index, site.wifi5)
end
end
uci:save('wireless')
uci:save('network')
uci:commit('wireless')
uci:commit('network')