applications/siitwizard:
- refresh ipv6 config - perform wifi and lan configuration too
This commit is contained in:
parent
c836191f98
commit
bbcb69d46b
2 changed files with 95 additions and 39 deletions
|
@ -15,11 +15,6 @@ $Id$
|
||||||
]]--
|
]]--
|
||||||
|
|
||||||
local uci = require "luci.model.uci".cursor()
|
local uci = require "luci.model.uci".cursor()
|
||||||
local tools = require "luci.tools.ffwizard"
|
|
||||||
local util = require "luci.util"
|
|
||||||
|
|
||||||
local io = require "io"
|
|
||||||
|
|
||||||
|
|
||||||
-------------------- View --------------------
|
-------------------- View --------------------
|
||||||
f = SimpleForm("siitwizward", "4over6-Assistent",
|
f = SimpleForm("siitwizward", "4over6-Assistent",
|
||||||
|
@ -30,23 +25,27 @@ mode:value("gateway", "Gateway")
|
||||||
mode:value("client", "Client")
|
mode:value("client", "Client")
|
||||||
|
|
||||||
dev = f:field(ListValue, "device", "WLAN-Gerät")
|
dev = f:field(ListValue, "device", "WLAN-Gerät")
|
||||||
uci:foreach("network", "interface",
|
uci:foreach("wireless", "wifi-device",
|
||||||
function(section)
|
function(section)
|
||||||
if section[".name"] ~= "siit0" then
|
dev:value(section[".name"])
|
||||||
dev:value(section[".name"])
|
|
||||||
end
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
lanip = f:field(Value, "ipaddr", "LAN IP Adresse")
|
||||||
|
lanip.value = "127.23.1.1"
|
||||||
|
|
||||||
|
lanmsk = f:field(Value, "netmask", "LAN Netzmaske")
|
||||||
|
lanmsk.value = "255.255.0.0"
|
||||||
|
|
||||||
|
|
||||||
-------------------- Control --------------------
|
-------------------- Control --------------------
|
||||||
LL_PREFIX = luci.ip.IPv6("fe80::/16")
|
LL_PREFIX = luci.ip.IPv6("fe80::/64")
|
||||||
|
|
||||||
--
|
--
|
||||||
-- find link-local address
|
-- find link-local address
|
||||||
--
|
--
|
||||||
function find_ll(dev)
|
function find_ll()
|
||||||
for _, r in ipairs(luci.sys.net.routes6()) do
|
for _, r in ipairs(luci.sys.net.routes6()) do
|
||||||
if r.device == dev and LL_PREFIX:contains(r.dest) then
|
if LL_PREFIX:contains(r.dest) and r.dest:higher(LL_PREFIX) then
|
||||||
return r.dest:sub(LL_PREFIX)
|
return r.dest:sub(LL_PREFIX)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -67,14 +66,47 @@ end
|
||||||
|
|
||||||
function mode.write(self, section, value)
|
function mode.write(self, section, value)
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Configure wifi device
|
||||||
|
--
|
||||||
|
local wifi_device = dev:formvalue(section)
|
||||||
|
local wifi_essid = uci:get("siit", "wifi", "essid") or "6mesh.freifunk.net"
|
||||||
|
local wifi_bssid = uci:get("siit", "wifi", "bssid") or "02:ca:ff:ee:ba:be"
|
||||||
|
local wifi_channel = uci:get("siit", "wifi", "channel") or "1"
|
||||||
|
|
||||||
|
-- nuke old device definition
|
||||||
|
uci:delete_all("wireless", "wifi-iface",
|
||||||
|
function(s) return s.device == wifi_device end )
|
||||||
|
|
||||||
|
uci:delete_all("network", "interface",
|
||||||
|
function(s) return s['.name'] == wifi_device end )
|
||||||
|
|
||||||
|
-- create wifi device definition
|
||||||
|
uci:tset("wireless", wifi_device, {
|
||||||
|
disabled = 0,
|
||||||
|
channel = wifi_channel,
|
||||||
|
-- txantenna = 1,
|
||||||
|
-- rxantenna = 1,
|
||||||
|
-- diversity = 0
|
||||||
|
})
|
||||||
|
|
||||||
|
uci:section("wireless", "wifi-iface", nil, {
|
||||||
|
encryption = "none",
|
||||||
|
mode = "adhoc",
|
||||||
|
network = wifi_device,
|
||||||
|
device = wifi_device,
|
||||||
|
ssid = wifi_essid,
|
||||||
|
bssid = wifi_bssid,
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Determine defaults
|
-- Determine defaults
|
||||||
--
|
--
|
||||||
local ula_prefix = uci:get("siit", "defaults", "ula_prefix") or "fd00::"
|
local ula_prefix = uci:get("siit", "ipv6", "ula_prefix") or "fd00::"
|
||||||
local ula_global = uci:get("siit", "defaults", "ula_global") or "00ca:ffee:babe::" -- = Freifunk
|
local ula_global = uci:get("siit", "ipv6", "ula_global") or "00ca:ffee:babe::" -- = Freifunk
|
||||||
local ula_subnet = uci:get("siit", "defaults", "ula_subnet") or "0000:0000:0000:4223::" -- = Berlin
|
local ula_subnet = uci:get("siit", "ipv6", "ula_subnet") or "0000:0000:0000:4223::" -- = Berlin
|
||||||
local siit_prefix = uci:get("siit", "defaults", "siit_prefix") or "::ffff:ffff:0000:0000"
|
local siit_prefix = uci:get("siit", "ipv6", "siit_prefix") or "::ffff:0000:0000"
|
||||||
local siit_route = luci.ip.IPv6(siit_prefix .. "/96")
|
|
||||||
|
|
||||||
-- Find wifi interface
|
-- Find wifi interface
|
||||||
local device = dev:formvalue(section)
|
local device = dev:formvalue(section)
|
||||||
|
@ -82,13 +114,13 @@ function mode.write(self, section, value)
|
||||||
--
|
--
|
||||||
-- Generate ULA
|
-- Generate ULA
|
||||||
--
|
--
|
||||||
local ula = luci.ip.IPv6("::")
|
local ula = luci.ip.IPv6("::/64")
|
||||||
|
|
||||||
for _, prefix in ipairs({ ula_prefix, ula_global, ula_subnet }) do
|
for _, prefix in ipairs({ ula_prefix, ula_global, ula_subnet }) do
|
||||||
ula = ula:add(luci.ip.IPv6(prefix))
|
ula = ula:add(luci.ip.IPv6(prefix))
|
||||||
end
|
end
|
||||||
|
|
||||||
ula = ula:add(find_ll(uci:get("network", device, "ifname") or device))
|
ula = ula:add(find_ll())
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -105,6 +137,8 @@ function mode.write(self, section, value)
|
||||||
|
|
||||||
uci:set("network", "wan", "mtu", 1400)
|
uci:set("network", "wan", "mtu", 1400)
|
||||||
|
|
||||||
|
-- use full siit subnet
|
||||||
|
siit_route = luci.ip.IPv6(siit_prefix .. "/96")
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Client mode
|
-- Client mode
|
||||||
|
@ -115,14 +149,22 @@ function mode.write(self, section, value)
|
||||||
-- * Also, MTU on LAN reduced to 1400.
|
-- * Also, MTU on LAN reduced to 1400.
|
||||||
|
|
||||||
else
|
else
|
||||||
local lan_ip = luci.ip.IPv4(
|
-- lan interface
|
||||||
uci:get("network", "lan", "ipaddr"),
|
local lan_net = luci.ip.IPv4(
|
||||||
uci:get("network", "lan", "netmask")
|
lanip:formvalue(section) or "192.168.1.1",
|
||||||
|
lanmsk:formvalue(section) or "255.255.255.0"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
uci:tset("network", "lan", {
|
||||||
|
mtu = 1400,
|
||||||
|
ipaddr = lan_net:host():string(),
|
||||||
|
netmask = lan_net:mask():string()
|
||||||
|
})
|
||||||
|
|
||||||
|
-- derive siit subnet from lan config
|
||||||
siit_route = luci.ip.IPv6(
|
siit_route = luci.ip.IPv6(
|
||||||
siit_prefix .. "/" .. (96 + lan_ip:prefix())
|
siit_prefix .. "/" .. (96 + lan_net:prefix())
|
||||||
):add(lan_ip[2])
|
):add(lan_net[2])
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -142,22 +184,30 @@ function mode.write(self, section, value)
|
||||||
function(s) return siit_route:contains(luci.ip.IPv6(s.target)) end)
|
function(s) return siit_route:contains(luci.ip.IPv6(s.target)) end)
|
||||||
|
|
||||||
uci:section("network", "route6", nil, {
|
uci:section("network", "route6", nil, {
|
||||||
interface = device,
|
interface = "siit0",
|
||||||
target = siit_route:string()
|
target = siit_route:string()
|
||||||
})
|
})
|
||||||
|
|
||||||
-- interface
|
-- create wifi network interface
|
||||||
uci:set("network", device, "ip6addr", ula:string())
|
uci:section("network", "interface", wifi_device, {
|
||||||
uci:set("network", "lan", "mtu", 1400)
|
proto = "static",
|
||||||
|
mtu = 1400,
|
||||||
|
ip6addr = ula:string()
|
||||||
|
})
|
||||||
|
|
||||||
uci:set("olsrd", "general", "IpVersion", 6)
|
-- nuke old olsrd interfaces
|
||||||
uci:foreach("olsrd", "Interface",
|
uci:delete_all("olsrd", "Interface",
|
||||||
function(s)
|
function(s) return s.interface == wifi_device end)
|
||||||
if s.interface == device then
|
|
||||||
uci:set("olsrd", s[".name"], "Ip6AddrType", "global")
|
-- configure olsrd interface
|
||||||
end
|
uci:foreach("olsrd", "olsrd",
|
||||||
uci:delete("olsrd", s[".name"], "Ip4Broadcast")
|
function(s) uci:set("olsrd", s['.name'], "IpVersion", 6) end)
|
||||||
end)
|
|
||||||
|
uci:section("olsrd", "Interface", nil, {
|
||||||
|
ignore = 0,
|
||||||
|
interface = wifi_device,
|
||||||
|
Ip6AddrType = "global"
|
||||||
|
})
|
||||||
|
|
||||||
-- hna6
|
-- hna6
|
||||||
uci:delete_all("olsrd", "Hna6",
|
uci:delete_all("olsrd", "Hna6",
|
||||||
|
@ -172,6 +222,7 @@ function mode.write(self, section, value)
|
||||||
prefix = siit_route:prefix()
|
prefix = siit_route:prefix()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
uci:save("wireless")
|
||||||
uci:save("network")
|
uci:save("network")
|
||||||
uci:save("olsrd")
|
uci:save("olsrd")
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,5 +1,10 @@
|
||||||
config siit defaults
|
config siit ipv6
|
||||||
option ula_prefix "fd00::"
|
option ula_prefix "fd00::"
|
||||||
option ula_global "00ca:ffee:babe::"
|
option ula_global "00ca:ffee:babe::"
|
||||||
option ula_subnet "0000:0000:0000:4223::"
|
option ula_subnet "0000:0000:0000:dada::"
|
||||||
option siit_prefix "::ffff:ffff:0000:0000"
|
option siit_prefix "::ffff:0000:0000"
|
||||||
|
|
||||||
|
config siit wifi
|
||||||
|
option essid "6mesh.freifunk.net"
|
||||||
|
option bssid "02:ca:ff:ee:ba:be"
|
||||||
|
option channel "1"
|
||||||
|
|
Loading…
Reference in a new issue