diff options
Diffstat (limited to 'applications/luci-ffwizard/luasrc')
-rw-r--r-- | applications/luci-ffwizard/luasrc/model/cbi/freifunk/ffwizard.lua | 460 |
1 files changed, 194 insertions, 266 deletions
diff --git a/applications/luci-ffwizard/luasrc/model/cbi/freifunk/ffwizard.lua b/applications/luci-ffwizard/luasrc/model/cbi/freifunk/ffwizard.lua index 297834f990..8a6e078369 100644 --- a/applications/luci-ffwizard/luasrc/model/cbi/freifunk/ffwizard.lua +++ b/applications/luci-ffwizard/luasrc/model/cbi/freifunk/ffwizard.lua @@ -90,6 +90,78 @@ function gen_dhcp_range(n) return "?" end +function cbi_meship(dev) + meship = f:field(Value, "meship_" .. dev, dev:upper() .. " " .. translate("Mesh IP address"), + translate("This is a unique address in the mesh (e.g. 10.1.1.1) and has to be registered at your local community.")) + meship:depends("device_" .. dev, "1") + meship.rmempty = true + function meship.cfgvalue(self, section) + return uci:get("freifunk", "wizard", "meship_" .. dev) + end + function meship.validate(self, value) + local x = ip.IPv4(value) + return ( x and x:prefix() == 32 ) and x:string() or "" + end + function meship.write(self, sec, value) + uci:set("freifunk", "wizard", "meship_" .. dev, value) + end +end + +function cbi_meship6(dev) + local meship6 = f:field(Value, "meship6_" .. dev, dev:upper() .. " " .. translate("Mesh IPv6 Address"), translate("The ipv6 address is calculated auomatically.")) + meship6:depends("device_" .. dev, "1") + meship6.rmempty = true + function meship6.cfgvalue(self, section) + return get_ula(get_mac(dev)) + end +end + +function cbi_netconf(dev) + local d = f:field(Flag, "device_" .. dev , " <b>" .. dev:upper() .. "</b>", "Configure this interface.") + d:depends("netconfig", "1") + d.rmempty = false + function d.cfgvalue(self, section) + return uci:get("freifunk", "wizard", "device_" .. dev) + end + function d.write(self, sec, value) + if value then + uci:set("freifunk", "wizard", "device_" .. dev, value) + uci:save("freifunk") + end + end +end + +function cbi_meshdhcp(dev) + local dhcpmesh = f:field(Value, "dhcpmesh_" .. dev, dev:upper() .. " " .. translate("DHCP IP range"), + translate("The IP range from which clients are assigned ip addresses (e.g. 10.1.2.1/28). If this is a range inside your mesh network range, then it will be announced as HNA. Any other range will use NAT. If left empty then the defaults from the community profile will be used.")) + dhcpmesh:depends("client_" .. dev, "1") + dhcpmesh.rmempty = true + function dhcpmesh.cfgvalue(self, section) + return uci:get("freifunk", "wizard", "dhcpmesh_" .. dev) + end + function dhcpmesh.validate(self, value) + local x = ip.IPv4(value) + return ( x and x:prefix() <= 30 and x:minhost()) and x:string() or "" + end + function dhcpmesh.write(self, sec, value) + uci:set("freifunk", "wizard", "dhcpmesh_" .. dev, value) + uci:save("freifunk") + end +end + +function cbi_dhcp(dev) + local client = f:field(Flag, "client_" .. dev, dev:upper() .. " " .. translate("Enable DHCP"), translate("DHCP will automatically assign ip addresses to clients")) + client:depends("device_" .. dev, "1") + client.rmempty = true + function client.cfgvalue(self, section) + return uci:get("freifunk", "wizard", "client_" .. dev) + end + function client.write(self, sec, value) + uci:set("freifunk", "wizard", "client_" .. dev, value) + uci:save("freifunk") + end +end + function hbconf(dev) if has_hb then local ifacelist = uci:get_list("manager", "heartbeat", "interface") or {} @@ -99,9 +171,36 @@ function hbconf(dev) end end +function uci_radvd(n) + uci:section("radvd", "interface", nil, { + interface =n, + AdvSendAdvert =1, + AdvManagedFlag =0, + AdvOtherConfigFlag =0, + ignore =0 + }) + uci:section("radvd", "prefix", nil, { + interface =n, + AdvOnLink =1, + AdvAutonomous =1, + AdvRouterAddr =0, + ignore =0, + }) + uci:save("radvd") +end + +function uci_clean_radvd (n) + uci:delete_all("radvd", "interface", {interface=n.."dhcp"}) + uci:delete_all("radvd", "interface", {interface=n}) + uci:delete_all("radvd", "prefix", {interface=n.."dhcp"}) + uci:delete_all("radvd", "prefix", {interface=n}) +end + + -------------------- View -------------------- -f = SimpleForm("ffwizward", "Freifunkassistent", - translate("This wizard will assist you in setting up your router for your local Freifunk network or another similar wireless community network.")) +f = SimpleForm("ffwizward", translate("Wizard"), + translate("This wizard will assist you in setting up your router for Freifunk " .. + "or another similar wireless community network.")) -- if password is not set or default then force the user to set a new one if sys.exec("diff /rom/etc/passwd /etc/passwd") == "" then @@ -109,7 +208,7 @@ if sys.exec("diff /rom/etc/passwd /etc/passwd") == "" then pw1.password = true pw1.rmempty = false - pw2 = f:field(Value, "pw2", translate("Confirmation")) + pw2 = f:field(Value, "pw2", translate("Password confirmation")) pw2.password = true pw2.rmempty = false @@ -123,184 +222,82 @@ end local cc = uci:get(community, "wifi_device", "country") or "DE" main = f:field(Flag, "netconfig", translate("Configure network"), translate("Select this checkbox to configure your network interfaces.")) -uci:foreach("wireless", "wifi-device", - function(section) - local device = section[".name"] - local hwtype = section.type - local syscc = section.country - - if not syscc then - if hwtype == "atheros" then - cc = sys.exec("grep -i '" .. cc .. "' /lib/wifi/cc_translate.txt |cut -d ' ' -f 2") or 0 - sys.exec("echo " .. cc .. " > /proc/sys/dev/" .. device .. "/countrycode") - elseif hwtype == "mac80211" then - sys.exec("iw reg set " .. cc) - elseif hwtype == "broadcom" then - sys.exec ("wlc country " .. cc) - end - else - cc = syscc - end - local dev = f:field(Flag, "device_" .. device , "<b>Drahtloses Netzwerk \"" .. device:upper() .. "\"</b> ", "Konfigurieren Sie Ihre drahtlose " .. device:upper() .. "Schnittstelle (WLAN).") - dev:depends("netconfig", "1") - dev.rmempty = false - function dev.cfgvalue(self, section) - return uci:get("freifunk", "wizard", "device_" .. device) - end - function dev.write(self, sec, value) - if value then - uci:set("freifunk", "wizard", "device_" .. device, value) - uci:save("freifunk") - end - end - local chan = f:field(ListValue, "chan_" .. device, device:upper() .. " Freifunk Kanal einrichten", "Ihr Gerät und benachbarte Freifunk Knoten müssen auf demselben Kanal senden. Je nach Gerätetyp können Sie zwischen verschiedenen 2,4Ghz und 5Ghz Kanälen auswählen.") - chan:depends("device_" .. device, "1") - chan.rmempty = true - function chan.cfgvalue(self, section) - return uci:get("freifunk", "wizard", "chan_" .. device) - end - - chan:value('default') - for _, f in ipairs(sys.wifi.channels(device)) do - if not f.restricted then - chan:value(f.channel) - end - end +uci:foreach("wireless", "wifi-device", function(section) + local device = section[".name"] + local hwtype = section.type + local syscc = section.country - function chan.write(self, sec, value) - if value then - uci:set("freifunk", "wizard", "chan_" .. device, value) - uci:save("freifunk") - end - end + if not syscc then + if hwtype == "atheros" then + cc = sys.exec("grep -i '" .. cc .. "' /lib/wifi/cc_translate.txt |cut -d ' ' -f 2") or 0 + sys.exec("echo " .. cc .. " > /proc/sys/dev/" .. device .. "/countrycode") + elseif hwtype == "mac80211" then + sys.exec("iw reg set " .. cc) + elseif hwtype == "broadcom" then + sys.exec ("wlc country " .. cc) + end + else + cc = syscc + end - local meship = f:field(Value, "meship_" .. device, device:upper() .. " Mesh IP Adresse einrichten", "Ihre Mesh IP Adresse erhalten Sie von der Freifunk Gemeinschaft in Ihrer Nachbarschaft. Es ist eine netzweit eindeutige Identifikation, z.B. 104.1.1.1.") - meship:depends("device_" .. device, "1") - meship.rmempty = true - function meship.cfgvalue(self, section) - return uci:get("freifunk", "wizard", "meship_" .. device) - end - function meship.validate(self, value) - local x = ip.IPv4(value) - return ( x and x:prefix() == 32 ) and x:string() or "" - end - function meship.write(self, sec, value) - uci:set("freifunk", "wizard", "meship_" .. device, value) - end - if has_ipv6 then - local meship6 = f:field(Value, "meship6_" .. device, device:upper() .. " Mesh IPv6 Adresse einrichten", "Ihre Mesh IP Adresse wird automatisch berechnet") - meship6:depends("device_" .. device, "1") - meship6.rmempty = true - function meship6.cfgvalue(self, section) - return get_ula(get_mac(device)) - end + cbi_netconf(device) + local chan = f:field(ListValue, "chan_" .. device, device:upper() .. " " .. translate("Channel"), translate("Your device and neighbouring nodes have to use the same channel.")) + chan:depends("device_" .. device, "1") + chan.rmempty = true + function chan.cfgvalue(self, section) + return uci:get("freifunk", "wizard", "chan_" .. device) + end + chan:value('default') + for _, f in ipairs(sys.wifi.channels(device)) do + if not f.restricted then + chan:value(f.channel) end - - local client = f:field(Flag, "client_" .. device, device:upper() .. " DHCP anbieten", "DHCP weist verbundenen Benutzern automatisch eine Adresse zu. Diese Option sollten Sie unbedingt aktivieren, wenn Sie Nutzer an der drahtlosen Schnittstelle erwarten.") - client:depends("device_" .. device, "1") - client.rmempty = true - function client.cfgvalue(self, section) - return uci:get("freifunk", "wizard", "client_" .. device) - end - function client.write(self, sec, value) - uci:set("freifunk", "wizard", "client_" .. device, value) - uci:save("freifunk") - end - local dhcpmesh = f:field(Value, "dhcpmesh_" .. device, device:upper() .. " Mesh DHCP anbieten", "Bestimmen Sie den Adressbereich aus dem Ihre Nutzer IP Adressen erhalten. Es wird empfohlen einen Adressbereich aus Ihrer lokalen Freifunk Gemeinschaft zu nutzen. Der Adressbereich ist ein netzweit eindeutiger Netzbereich. z.B. 104.1.2.1/28") - dhcpmesh:depends("client_" .. device, "1") - dhcpmesh.rmempty = true - function dhcpmesh.cfgvalue(self, section) - return uci:get("freifunk", "wizard", "dhcpmesh_" .. device) - end - function dhcpmesh.validate(self, value) - local x = ip.IPv4(value) - return ( x and x:minhost()) and x:string() or "" - end - function dhcpmesh.write(self, sec, value) - uci:set("freifunk", "wizard", "dhcpmesh_" .. device, value) - uci:save("freifunk") - end - local hwtype = section.type - if hwtype == "atheros" then - local vap = f:field(Flag, "vap_" .. device , "Virtueller Drahtloser Zugangspunkt", "Konfigurieren Sie Ihren Virtuellen AP") - vap:depends("client_" .. device, "1") - vap.rmempty = false - function vap.cfgvalue(self, section) - return uci:get("freifunk", "wizard", "vap_" .. device) - end - function vap.write(self, sec, value) - uci:set("freifunk", "wizard", "vap_" .. device, value) - uci:save("freifunk") - end + end + + function chan.write(self, sec, value) + if value then + uci:set("freifunk", "wizard", "chan_" .. device, value) + uci:save("freifunk") end - end) + end -uci:foreach("network", "interface", - function(section) - local device = section[".name"] - local ifname = uci_state:get("network",device,"ifname") - if device ~= "loopback" and not string.find(device, "gvpn") and not string.find(device, "wifi") and not string.find(device, "wl") and not string.find(device, "wlan") and not string.find(device, "wireless") and not string.find(device, "radio") then - dev = f:field(Flag, "device_" .. device , "<b>Drahtgebundenes Netzwerk \"" .. device:upper() .. "\"</b>", "Konfigurieren Sie Ihre drahtgebunde " .. device:upper() .. " Schnittstelle (LAN).") - dev:depends("netconfig", "1") - dev.rmempty = false - function dev.cfgvalue(self, section) - return uci:get("freifunk", "wizard", "device_" .. device) - end - function dev.write(self, sec, value) - uci:set("freifunk", "wizard", "device_" .. device, value) - uci:save("freifunk") - end - meship = f:field(Value, "meship_" .. device, device:upper() .. " Mesh IP Adresse einrichten", "Ihre Mesh IP Adresse erhalten Sie von der Freifunk Gemeinschaft in Ihrer Nachbarschaft. Es ist eine netzweit eindeutige Identifikation, z.B. 104.1.1.1.") - meship:depends("device_" .. device, "1") - meship.rmempty = true - function meship.cfgvalue(self, section) - return uci:get("freifunk", "wizard", "meship_" .. device) - end - function meship.validate(self, value) - local x = ip.IPv4(value) - return ( x and x:prefix() == 32 ) and x:string() or "" - end - function meship.write(self, sec, value) - uci:set("freifunk", "wizard", "meship_" .. device, value) - end - if has_ipv6 then - meship6 = f:field(Value, "meship6_" .. device, device:upper() .. " Mesh IPv6 Adresse einrichten", "Ihre Mesh IP Adresse wird automatisch berechnet") - meship6:depends("device_" .. device, "1") - meship6.rmempty = true - function meship6.cfgvalue(self, section) - return get_ula(get_mac(ifname)) - end - end + cbi_meship(device) + if has_ipv6 then + cbi_meship6(device) + end + cbi_dhcp(device) + cbi_meshdhcp(device) + local hwtype = section.type + if hwtype == "atheros" then + local vap = f:field(Flag, "vap_" .. device , " " .. translate("Virtual Access Point (VAP)"), translate("This will setup a new virtual wireless interface in Access Point mode.")) + vap:depends("client_" .. device, "1") + vap.rmempty = false + function vap.cfgvalue(self, section) + return uci:get("freifunk", "wizard", "vap_" .. device) + end + function vap.write(self, sec, value) + uci:set("freifunk", "wizard", "vap_" .. device, value) + uci:save("freifunk") + end + end +end) - client = f:field(Flag, "client_" .. device, device:upper() .. " DHCP anbieten","DHCP weist verbundenen Benutzern automatisch eine Adresse zu. Diese Option sollten Sie unbedingt aktivieren, wenn Sie Nutzer an der drahtlosen Schnittstelle erwarten.") - client:depends("device_" .. device, "1") - client.rmempty = false - function client.cfgvalue(self, section) - return uci:get("freifunk", "wizard", "client_" .. device) - end - function client.write(self, sec, value) - uci:set("freifunk", "wizard", "client_" .. device, value) - uci:save("freifunk") - end - dhcpmesh = f:field(Value, "dhcpmesh_" .. device, device:upper() .. " Mesh DHCP anbieten ", "Bestimmen Sie den Adressbereich aus dem Ihre Nutzer IP Adressen erhalten. Es wird empfohlen einen Adressbereich aus Ihrer lokalen Freifunk Gemeinschaft zu nutzen. Der Adressbereich ist ein netzweit eindeutiger Netzbereich. z.B. 104.1.2.1/28") - dhcpmesh:depends("client_" .. device, "1") - dhcpmesh.rmempty = true - function dhcpmesh.cfgvalue(self, section) - return uci:get("freifunk", "wizard", "dhcpmesh_" .. device) - end - function dhcpmesh.validate(self, value) - local x = ip.IPv4(value) - return ( x and x:prefix() <= 30 and x:minhost()) and x:string() or "" - end - function dhcpmesh.write(self, sec, value) - uci:set("freifunk", "wizard", "dhcpmesh_" .. device, value) - uci:save("freifunk") - end +uci:foreach("network", "interface", function(section) + local device = section[".name"] + local ifname = uci_state:get("network",device,"ifname") + if device ~= "loopback" and not string.find(device, "gvpn") and not string.find(device, "wifi") and not string.find(device, "wl") and not string.find(device, "wlan") and not string.find(device, "wireless") and not string.find(device, "radio") then + cbi_netconf(device) + cbi_meship(device) + if has_ipv6 then + cbi_meship6(device) end - end) + cbi_dhcp(device) + cbi_meshdhcp(device) + end +end) -share = f:field(Flag, "sharenet", "Eigenen Internetzugang freigeben", "Geben Sie Ihren Internetzugang im Freifunknetz frei.") +share = f:field(Flag, "sharenet", "<b>" .. translate("Share your internet connection") .. "</b>", translate("Select this to allow others to use your connection to access the internet.")) share.rmempty = false share:depends("netconfig", "1") function share.cfgvalue(self, section) @@ -311,7 +308,7 @@ function share.write(self, section, value) uci:save("freifunk") end -wanproto = f:field(ListValue, "wanproto", "Protokoll des Internetzugangs", "Geben Sie das Protokol an ueber das eine Internet verbindung hergestellt werden kann.") +wanproto = f:field(ListValue, "wanproto", translate("Protocol"), translate ("The protocol to use for internet connectivity.")) wanproto:depends("sharenet", "1") wanproto:value("static", translate("static", "static")) wanproto:value("dhcp", translate("dhcp", "dhcp")) @@ -324,7 +321,7 @@ function wanproto.write(self, section, value) uci:set("network", "wan", "proto", value) uci:save("network") end -wanip = f:field(Value, "wanipaddr", translate("ipaddress")) +wanip = f:field(Value, "wanipaddr", translate("Ip address")) wanip:depends("wanproto", "static") function wanip.cfgvalue(self, section) return uci:get("network", "wan", "ipaddr") @@ -333,7 +330,7 @@ function wanip.write(self, section, value) uci:set("network", "wan", "ipaddr", value) uci:save("network") end -wannm = f:field(Value, "wannetmask", translate("netmask")) +wannm = f:field(Value, "wannetmask", translate("Netmask")) wannm:depends("wanproto", "static") function wannm.cfgvalue(self, section) return uci:get("network", "wan", "netmask") @@ -342,7 +339,7 @@ function wannm.write(self, section, value) uci:set("network", "wan", "netmask", value) uci:save("network") end -wangw = f:field(Value, "wangateway", translate("gateway")) +wangw = f:field(Value, "wangateway", translate("Gateway")) wangw:depends("wanproto", "static") wangw.rmempty = true function wangw.cfgvalue(self, section) @@ -352,7 +349,7 @@ function wangw.write(self, section, value) uci:set("network", "wan", "gateway", value) uci:save("network") end -wandns = f:field(Value, "wandns", translate("dnsserver")) +wandns = f:field(Value, "wandns", translate("DNS Server")) wandns:depends("wanproto", "static") wandns.rmempty = true function wandns.cfgvalue(self, section) @@ -362,7 +359,7 @@ function wandns.write(self, section, value) uci:set("network", "wan", "dns", value) uci:save("network") end -wanusr = f:field(Value, "wanusername", translate("username")) +wanusr = f:field(Value, "wanusername", translate("Username")) wanusr:depends("wanproto", "pppoe") wanusr:depends("wanproto", "pptp") function wanusr.cfgvalue(self, section) @@ -372,7 +369,7 @@ function wanusr.write(self, section, value) uci:set("network", "wan", "username", value) uci:save("network") end -wanpwd = f:field(Value, "wanpassword", translate("password")) +wanpwd = f:field(Value, "wanpassword", translate("Password")) wanpwd.password = true wanpwd:depends("wanproto", "pppoe") wanpwd:depends("wanproto", "pptp") @@ -384,7 +381,8 @@ function wanpwd.write(self, section, value) uci:save("network") end -wansec = f:field(Flag, "wansec", "WAN-Zugriff auf Gateway beschränken", "Verbieten Sie Zugriffe auf Ihr lokales Netzwerk aus dem Freifunknetz.") +wansec = f:field(Flag, "wansec", translate("Protect LAN"), translate("Check this to protect your LAN from other nodes or clients" .. " (" .. translate("recommended") .. ").")) +wansec.default = "1" wansec.rmempty = false wansec:depends("wanproto", "static") wansec:depends("wanproto", "dhcp") @@ -396,7 +394,7 @@ function wansec.write(self, section, value) uci:save("freifunk") end if has_qos then - wanqosdown = f:field(Value, "wanqosdown", "Download Bandbreite begrenzen", "kb/s") + wanqosdown = f:field(Value, "wanqosdown", translate("Limit download bandwidth"), translate("kbit/s")) wanqosdown:depends("sharenet", "1") function wanqosdown.cfgvalue(self, section) return uci:get("qos", "wan", "download") @@ -405,7 +403,7 @@ if has_qos then uci:set("qos", "wan", "download", value) uci:save("qos") end - wanqosup = f:field(Value, "wanqosup", "Upload Bandbreite begrenzen", "kb/s") + wanqosup = f:field(Value, "wanqosup", translate("Limit upload bandwidth"), translate("kbit/s")) wanqosup:depends("sharenet", "1") function wanqosup.cfgvalue(self, section) return uci:get("qos", "wan", "upload") @@ -417,7 +415,7 @@ if has_qos then end if has_l2gvpn then - gvpn = f:field(Flag, "gvpn", "Freifunk Internet Tunnel", "Verbinden Sie ihren Router ueber das Internet mit anderen Freifunknetzen.") + gvpn = f:field(Flag, "gvpn", translate("L2gvpn tunnel"), translate("Connect your node with other nodes with a tunnel via the internet.")) gvpn.rmempty = false gvpn:depends("sharenet", "1") function gvpn.cfgvalue(self, section) @@ -427,7 +425,7 @@ if has_l2gvpn then uci:set("freifunk", "wizard", "gvpn", value) uci:save("freifunk") end - gvpnip = f:field(Value, "gvpnipaddr", translate("ipaddress")) + gvpnip = f:field(Value, "gvpnipaddr", translate("IP address")) gvpnip:depends("gvpn", "1") function gvpnip.cfgvalue(self, section) return uci:get("l2gvpn", "bbb", "ip") or uci:get("network", "gvpn", "ipaddr") @@ -439,7 +437,7 @@ if has_l2gvpn then end if has_hb then - hb = f:field(Flag, "hb", "Heartbeat aktivieren","Dem Gerät erlauben anonyme Statistiken zu übertragen. (empfohlen)") + hb = f:field(Flag, "hb", translate("Heartbeat"), translate("Allow to transfer anonymous statistics about this node" .. " (" .. translate("recommended") .. ").")) hb.rmempty = false hb:depends("netconfig", "1") function hb.cfgvalue(self, section) @@ -538,11 +536,6 @@ function main.write(self, section, value) local network network = ip.IPv4(uci:get_first(community, "community", "mesh_network") or "104.0.0.0/8") - -- Tune community settings --- if community and uci:get("freifunk", community) then --- uci:get_all(community) --- end - -- Cleanup uci:delete_all("firewall","zone", {name="freifunk"}) uci:delete_all("firewall","forwarding", {dest="freifunk"}) @@ -551,7 +544,7 @@ function main.write(self, section, value) uci:delete_all("firewall","rule", {src="freifunk"}) uci:save("firewall") -- Create firewall zone and add default rules (first time) - -- firewall_create_zone("name" , "input" , "output", "forward ", Masqurade) + -- firewall_create_zone("name" , "input" , "output", "forward ", Masqurade) local newzone = tools.firewall_create_zone("freifunk", "ACCEPT", "ACCEPT", "REJECT" , true) if newzone then uci:foreach("freifunk", "fw_forwarding", function(section) @@ -647,10 +640,7 @@ function main.write(self, section, value) uci:delete_all("luci_splash", "iface", {network=nif.."dhcp", zone="freifunk"}) -- Delete old radvd if has_radvd then - uci:delete_all("radvd", "interface", {interface=nif.."dhcp"}) - uci:delete_all("radvd", "interface", {interface=nif}) - uci:delete_all("radvd", "prefix", {interface=nif.."dhcp"}) - uci:delete_all("radvd", "prefix", {interface=nif}) + uci_clean_radvd(nif) end -- New Config -- Tune wifi device @@ -665,9 +655,9 @@ function main.write(self, section, value) if sec.txantenna then devconfig.txantenna = sec.txantenna end - if sec.rxantenna then - devconfig.rxantenna = sec.rxantenna - end + if sec.rxantenna then + devconfig.rxantenna = sec.rxantenna + end -- set bssid, see https://kifuse02.pberg.freifunk.net/moin/channel-bssid-essid for schema if channel and channel ~= "default" then @@ -713,21 +703,7 @@ function main.write(self, section, value) end uci:section("network", "interface", nif, netconfig) if has_radvd then - uci:section("radvd", "interface", nil, { - interface =nif, - AdvSendAdvert =1, - AdvManagedFlag =0, - AdvOtherConfigFlag =0, - ignore =0 - }) - uci:section("radvd", "prefix", nil, { - interface =nif, - AdvOnLink =1, - AdvAutonomous =1, - AdvRouterAddr =0, - ignore =0, - }) - uci:save("radvd") + uci_radvd(nif) end tools.firewall_zone_add_interface("freifunk", nif) uci:save("firewall") @@ -742,14 +718,6 @@ function main.write(self, section, value) if client then local dhcpmeshnet = luci.http.formvalue("cbid.ffwizward.1.dhcpmesh_" .. device) and ip.IPv4(luci.http.formvalue("cbid.ffwizward.1.dhcpmesh_" .. device)) hbconf(nif) - --[[ - if has_hb then - local ifacelist = uci:get_list("manager", "heartbeat", "interface") or {} - table.insert(ifacelist,nif .. "dhcp") - uci:set_list("manager", "heartbeat", "interface", ifacelist) - uci:save("manager") - end - ]] if dhcpmeshnet then if not dhcpmeshnet:minhost() or not dhcpmeshnet:mask() then dhcpmesh.tag_missing[section] = true @@ -798,21 +766,7 @@ function main.write(self, section, value) ssid ="AP-" .. ssid }) if has_radvd then - uci:section("radvd", "interface", nil, { - interface =nif .. "dhcp", - AdvSendAdvert =1, - AdvManagedFlag =0, - AdvOtherConfigFlag =0, - ignore =0 - }) - uci:section("radvd", "prefix", nil, { - interface =nif .. "dhcp", - AdvOnLink =1, - AdvAutonomous =1, - AdvRouterAddr =0, - ignore =0 - }) - uci:save("radvd") + uci_radvd(nif .. "dhcp") end tools.firewall_zone_add_interface("freifunk", nif .. "dhcp") uci:save("wireless") @@ -892,7 +846,7 @@ function main.write(self, section, value) end if device ~= "loopback" and not string.find(device, "wifi") and not string.find(device, "wl") and not string.find(device, "wlan") and not string.find(device, "wireless") and not string.find(device, "radio") then local node_ip - node_ip = luci.http.formvalue("cbid.ffwizward.1.meship_" .. device) --and ip.IPv4(luci.http.formvalue("cbid.ffwizward.1.meship_" .. device)) + node_ip = luci.http.formvalue("cbid.ffwizward.1.meship_" .. device) and ip.IPv4(luci.http.formvalue("cbid.ffwizward.1.meship_" .. device)) if has_ipv6 then node_ip6 = luci.http.formvalue("cbid.ffwizward.1.meship6_" .. device) --and ip.IPv6(luci.http.formvalue("cbid.ffwizward.1.meship6_" .. device)) end @@ -913,10 +867,7 @@ function main.write(self, section, value) -- Delete old splash uci:delete_all("luci_splash", "iface", {network=device.."dhcp", zone="freifunk"}) if has_radvd then - uci:delete_all("radvd", "interface", {interface=device.."dhcp"}) - uci:delete_all("radvd", "interface", {interface=device}) - uci:delete_all("radvd", "prefix", {interface=device.."dhcp"}) - uci:delete_all("radvd", "prefix", {interface=device}) + uci_clean_radvd(device) end -- New Config local netconfig = uci:get_all("freifunk", "interface") @@ -929,21 +880,7 @@ function main.write(self, section, value) uci:section("network", "interface", device, netconfig) uci:save("network") if has_radvd then - uci:section("radvd", "interface", nil, { - interface =device, - AdvSendAdvert =1, - AdvManagedFlag =0, - AdvOtherConfigFlag =0, - ignore =0 - }) - uci:section("radvd", "prefix", nil, { - interface =device, - AdvOnLink =1, - AdvAutonomous =1, - AdvRouterAddr =0, - ignore =0, - }) - uci:save("radvd") + uci_radvd(device) end tools.firewall_zone_add_interface("freifunk", device) uci:save("firewall") @@ -959,16 +896,7 @@ function main.write(self, section, value) if client then local dhcpmeshnet = luci.http.formvalue("cbid.ffwizward.1.dhcpmesh_" .. device) and ip.IPv4(luci.http.formvalue("cbid.ffwizward.1.dhcpmesh_" .. device)) hbconf(device) ---[[ - if has_hb then - hbconf(device) - local ifacelist = uci:get_list("manager", "heartbeat", "interface") or {} - table.insert(ifacelist,device .. "dhcp") - uci:set_list("manager", "heartbeat", "interface", ifacelist) - uci:save("manager") - - end -]] + if dhcpmeshnet then if not dhcpmeshnet:minhost() or not dhcpmeshnet:mask() then dhcpmesh.tag_missing[section] = true |