]]--
local uci = require "luci.model.uci".cursor()
-local tools = require "luci.tools.ffwizard"
-local util = require "luci.util"
-
-local io = require "io"
-
-------------------- View --------------------
f = SimpleForm("siitwizward", "4over6-Assistent",
mode:value("client", "Client")
dev = f:field(ListValue, "device", "WLAN-Gerät")
-uci:foreach("network", "interface",
+uci:foreach("wireless", "wifi-device",
function(section)
- if section[".name"] ~= "siit0" then
- dev:value(section[".name"])
- end
+ dev:value(section[".name"])
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 --------------------
-LL_PREFIX = luci.ip.IPv6("fe80::/16")
+LL_PREFIX = luci.ip.IPv6("fe80::/64")
--
-- find link-local address
--
-function find_ll(dev)
+function find_ll()
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)
end
end
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
--
- local ula_prefix = uci:get("siit", "defaults", "ula_prefix") or "fd00::"
- local ula_global = uci:get("siit", "defaults", "ula_global") or "00ca:ffee:babe::" -- = Freifunk
- local ula_subnet = uci:get("siit", "defaults", "ula_subnet") or "0000:0000:0000:4223::" -- = Berlin
- local siit_prefix = uci:get("siit", "defaults", "siit_prefix") or "::ffff:ffff:0000:0000"
- local siit_route = luci.ip.IPv6(siit_prefix .. "/96")
+ local ula_prefix = uci:get("siit", "ipv6", "ula_prefix") or "fd00::"
+ local ula_global = uci:get("siit", "ipv6", "ula_global") or "00ca:ffee:babe::" -- = Freifunk
+ local ula_subnet = uci:get("siit", "ipv6", "ula_subnet") or "0000:0000:0000:4223::" -- = Berlin
+ local siit_prefix = uci:get("siit", "ipv6", "siit_prefix") or "::ffff:0000:0000"
-- Find wifi interface
local device = dev:formvalue(section)
--
-- Generate ULA
--
- local ula = luci.ip.IPv6("::")
+ local ula = luci.ip.IPv6("::/64")
for _, prefix in ipairs({ ula_prefix, ula_global, ula_subnet }) do
ula = ula:add(luci.ip.IPv6(prefix))
end
- ula = ula:add(find_ll(uci:get("network", device, "ifname") or device))
+ ula = ula:add(find_ll())
--
uci:set("network", "wan", "mtu", 1400)
+ -- use full siit subnet
+ siit_route = luci.ip.IPv6(siit_prefix .. "/96")
--
-- Client mode
-- * Also, MTU on LAN reduced to 1400.
else
- local lan_ip = luci.ip.IPv4(
- uci:get("network", "lan", "ipaddr"),
- uci:get("network", "lan", "netmask")
+ -- lan interface
+ local lan_net = luci.ip.IPv4(
+ 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_prefix .. "/" .. (96 + lan_ip:prefix())
- ):add(lan_ip[2])
+ siit_prefix .. "/" .. (96 + lan_net:prefix())
+ ):add(lan_net[2])
end
function(s) return siit_route:contains(luci.ip.IPv6(s.target)) end)
uci:section("network", "route6", nil, {
- interface = device,
+ interface = "siit0",
target = siit_route:string()
})
- -- interface
- uci:set("network", device, "ip6addr", ula:string())
- uci:set("network", "lan", "mtu", 1400)
+ -- create wifi network interface
+ uci:section("network", "interface", wifi_device, {
+ proto = "static",
+ mtu = 1400,
+ ip6addr = ula:string()
+ })
+
+ -- nuke old olsrd interfaces
+ uci:delete_all("olsrd", "Interface",
+ function(s) return s.interface == wifi_device end)
- uci:set("olsrd", "general", "IpVersion", 6)
- uci:foreach("olsrd", "Interface",
- function(s)
- if s.interface == device then
- uci:set("olsrd", s[".name"], "Ip6AddrType", "global")
- end
- uci:delete("olsrd", s[".name"], "Ip4Broadcast")
- end)
+ -- configure olsrd interface
+ uci:foreach("olsrd", "olsrd",
+ function(s) uci:set("olsrd", s['.name'], "IpVersion", 6) end)
+
+ uci:section("olsrd", "Interface", nil, {
+ ignore = 0,
+ interface = wifi_device,
+ Ip6AddrType = "global"
+ })
-- hna6
uci:delete_all("olsrd", "Hna6",
prefix = siit_route:prefix()
})
+ uci:save("wireless")
uci:save("network")
uci:save("olsrd")
end