1
0
mirror of https://github.com/freifunk-gluon/packages.git synced 2024-06-23 16:17:30 +02:00

Configure unique MAC addresses for all WLAN interfaces

This commit is contained in:
Matthias Schiffer 2014-09-15 19:47:52 +02:00
parent afecfc43f6
commit 10ea4ecd55
2 changed files with 64 additions and 57 deletions

View File

@ -66,8 +66,8 @@ end
-- Functions and IDs defined so far: -- Functions and IDs defined so far:
-- (1, 0): WAN (for mesh-on-WAN) -- (1, 0): WAN (for mesh-on-WAN)
-- (1, 1): LAN (for mesh-on-LAN) -- (1, 1): LAN (for mesh-on-LAN)
-- (2, X): client interface for radioX -- (2, n): client interface for the n'th radio
-- (3, X): adhoc interface for radioX -- (3, n): adhoc interface for n'th radio
-- (4, 0): mesh VPN -- (4, 0): mesh VPN
function generate_mac(f, i) function generate_mac(f, i)
local m1, m2, m3, m4, m5, m6 = string.match(sysconfig.primary_mac, '(%x%x):(%x%x):(%x%x):(%x%x):(%x%x):(%x%x)') local m1, m2, m3, m4, m5, m6 = string.match(sysconfig.primary_mac, '(%x%x):(%x%x):(%x%x):(%x%x):(%x%x):(%x%x)')

View File

@ -1,44 +1,33 @@
#!/usr/bin/lua #!/usr/bin/lua
local site = require 'gluon.site_config' local site = require 'gluon.site_config'
local uci = require 'luci.model.uci' local util = require 'gluon.util'
local c = uci.cursor() local uci = require('luci.model.uci').cursor()
local function configure_radio(device) local function configure_radio(radio, index, config)
local radio = device['.name'] uci:delete('wireless', radio, 'disabled')
local hwmode = c:get('wireless', radio, 'hwmode')
local config uci:set('wireless', radio, 'channel', config.channel)
if hwmode == '11g' or hwmode == '11ng' then uci:set('wireless', radio, 'htmode', config.htmode)
config = site.wifi24 uci:set('wireless', radio, 'country', site.regdom)
elseif hwmode == '11a' or hwmode == '11na' then
config = site.wifi5
else
return true
end
c:delete('wireless', radio, 'disabled')
c:set('wireless', radio, 'channel', config.channel)
c:set('wireless', radio, 'htmode', config.htmode)
c:set('wireless', radio, 'country', site.regdom)
local client = 'client_' .. radio local client = 'client_' .. radio
c:delete('wireless', client) uci:delete('wireless', client)
c:section('wireless', 'wifi-iface', client, uci:section('wireless', 'wifi-iface', client,
{ {
device = radio, device = radio,
network = 'client', network = 'client',
mode = 'ap', mode = 'ap',
ssid = config.ssid, ssid = config.ssid,
macaddr = util.generate_mac(2, index),
} }
) )
local mesh = 'mesh_' .. radio local mesh = 'mesh_' .. radio
c:delete('network', mesh) uci:delete('network', mesh)
c:section('network', 'interface', mesh, uci:section('network', 'interface', mesh,
{ {
proto = 'batadv', proto = 'batadv',
mtu = '1528', mtu = '1528',
@ -46,24 +35,42 @@ local function configure_radio(device)
} }
) )
c:delete('wireless', mesh) uci:delete('wireless', mesh)
c:section('wireless', 'wifi-iface', mesh, uci:section('wireless', 'wifi-iface', mesh,
{ {
device = radio, device = radio,
network = mesh, network = mesh,
mode = 'adhoc', mode = 'adhoc',
ssid = config.mesh_ssid, ssid = config.mesh_ssid,
bssid = config.mesh_bssid, bssid = config.mesh_bssid,
macaddr = util.generate_mac(3, index),
mcast_rate = config.mesh_mcast_rate, mcast_rate = config.mesh_mcast_rate,
} }
) )
return true
end end
c:foreach('wireless', 'wifi-device', configure_radio)
c:save('wireless') local radios = {}
c:save('network')
c:commit('wireless') uci:foreach('wireless', 'wifi-device',
c:commit('network') function(s)
table.insert(radios, s['.name'])
end
)
for index, radio in ipairs(radios) do
local hwmode = uci:get('wireless', radio, 'hwmode')
local config
if hwmode == '11g' or hwmode == '11ng' then
configure_radio(radio, index, site.wifi24)
elseif hwmode == '11a' or hwmode == '11na' then
configure_radio(radio, index, site.wifi5)
end
end
uci:save('wireless')
uci:save('network')
uci:commit('wireless')
uci:commit('network')