|
@@ -14,11 +14,74 @@ $Id$
|
|
|
|
|
|
local uci = luci.model.uci.cursor()
|
|
|
|
|
|
-f = SimpleForm("portconfig")
|
|
|
+local wan = uci:get_all("network", "wan")
|
|
|
+local wan6 = uci:get_all("network", "wan6")
|
|
|
+local dns = uci:get_first("gluon-wan-dnsmasq", "static")
|
|
|
+
|
|
|
+local f = SimpleForm("portconfig", "WAN-Verbindung")
|
|
|
f.template = "admin/expertmode"
|
|
|
f.submit = "Speichern"
|
|
|
f.reset = "Zurücksetzen"
|
|
|
|
|
|
+local s
|
|
|
+local o
|
|
|
+
|
|
|
+s = f:section(SimpleSection, nil, nil)
|
|
|
+
|
|
|
+o = s:option(ListValue, "ipv4", "IPv4")
|
|
|
+o:value("dhcp", "Automatisch (DHCP)")
|
|
|
+o:value("static", "Statisch")
|
|
|
+o:value("none", "Deaktiviert")
|
|
|
+o.default = wan.proto
|
|
|
+
|
|
|
+o = s:option(Value, "ipv4_addr", "IP-Adresse")
|
|
|
+o:depends("ipv4", "static")
|
|
|
+o.value = wan.ipaddr
|
|
|
+o.datatype = "ip4addr"
|
|
|
+o.rmempty = false
|
|
|
+
|
|
|
+o = s:option(Value, "ipv4_netmask", "Netzmaske")
|
|
|
+o:depends("ipv4", "static")
|
|
|
+o.value = wan.netmask or "255.255.255.0"
|
|
|
+o.datatype = "ip4addr"
|
|
|
+o.rmempty = false
|
|
|
+
|
|
|
+o = s:option(Value, "ipv4_gateway", "Gateway")
|
|
|
+o:depends("ipv4", "static")
|
|
|
+o.value = wan.gateway
|
|
|
+o.datatype = "ip4addr"
|
|
|
+o.rmempty = false
|
|
|
+
|
|
|
+
|
|
|
+s = f:section(SimpleSection, nil, nil)
|
|
|
+
|
|
|
+o = s:option(ListValue, "ipv6", "IPv6")
|
|
|
+o:value("dhcpv6", "Automatisch (RA/DHCPv6)")
|
|
|
+o:value("static", "Statisch")
|
|
|
+o:value("none", "Deaktiviert")
|
|
|
+o.default = wan6.proto
|
|
|
+
|
|
|
+o = s:option(Value, "ipv6_addr", "IP-Adresse")
|
|
|
+o:depends("ipv6", "static")
|
|
|
+o.value = wan6.ip6addr
|
|
|
+o.datatype = "ip6addr"
|
|
|
+o.rmempty = false
|
|
|
+
|
|
|
+o = s:option(Value, "ipv6_gateway", "Gateway")
|
|
|
+o:depends("ipv6", "static")
|
|
|
+o.value = wan6.ip6gw
|
|
|
+o.datatype = "ip6addr"
|
|
|
+o.rmempty = false
|
|
|
+
|
|
|
+
|
|
|
+if dns then
|
|
|
+ s = f:section(SimpleSection, nil, nil)
|
|
|
+
|
|
|
+ o = s:option(DynamicList, "dns", "Statische DNS-Server")
|
|
|
+ o:write(nil, uci:get("gluon-wan-dnsmasq", dns, "server"))
|
|
|
+ o.datatype = "ipaddr"
|
|
|
+end
|
|
|
+
|
|
|
s = f:section(SimpleSection, nil, nil)
|
|
|
|
|
|
o = s:option(Flag, "mesh_wan", "Mesh auf dem WAN-Port aktivieren")
|
|
@@ -27,9 +90,41 @@ o.rmempty = false
|
|
|
|
|
|
function f.handle(self, state, data)
|
|
|
if state == FORM_VALID then
|
|
|
+ uci:set("network", "wan", "proto", data.ipv4)
|
|
|
+ if data.ipv4 == "static" then
|
|
|
+ uci:set("network", "wan", "ipaddr", data.ipv4_addr)
|
|
|
+ uci:set("network", "wan", "netmask", data.ipv4_netmask)
|
|
|
+ uci:set("network", "wan", "gateway", data.ipv4_gateway)
|
|
|
+ else
|
|
|
+ uci:delete("network", "wan", "ipaddr")
|
|
|
+ uci:delete("network", "wan", "netmask")
|
|
|
+ uci:delete("network", "wan", "gateway")
|
|
|
+ end
|
|
|
+
|
|
|
+ uci:set("network", "wan6", "proto", data.ipv6)
|
|
|
+ if data.ipv6 == "static" then
|
|
|
+ uci:set("network", "wan6", "ip6addr", data.ipv6_addr)
|
|
|
+ uci:set("network", "wan6", "ip6gw", data.ipv6_gateway)
|
|
|
+ else
|
|
|
+ uci:delete("network", "wan6", "ip6addr")
|
|
|
+ uci:delete("network", "wan6", "ip6gw")
|
|
|
+ end
|
|
|
+
|
|
|
uci:set("network", "mesh_wan", "auto", data.mesh_wan)
|
|
|
+
|
|
|
uci:save("network")
|
|
|
uci:commit("network")
|
|
|
+
|
|
|
+ if dns then
|
|
|
+ if data.dns then
|
|
|
+ uci:set("gluon-wan-dnsmasq", dns, "server", data.dns)
|
|
|
+ else
|
|
|
+ uci:delete("gluon-wan-dnsmasq", dns, "server")
|
|
|
+ end
|
|
|
+
|
|
|
+ uci:save("gluon-wan-dnsmasq")
|
|
|
+ uci:commit("gluon-wan-dnsmasq")
|
|
|
+ end
|
|
|
end
|
|
|
|
|
|
return true
|