LuCI - Lua Configuration Interface
Copyright 2008 Steven Barth <steven@midlink.org>
+Copyright 2008 Jo-Philipp Wich <xm@leipzig.freifunk.net>
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
$Id$
]]--
+require("luci.tools.webadmin")
+arg[1] = arg[1] or ""
m = Map("network", translate("interfaces"), translate("a_n_ifaces1"))
-s = m:section(TypedSection, "interface", translate("interfaces"))
-function s.filter(self, section)
- return section ~= "loopback" and
- (not arg or not arg[1] or arg[1] == section)
-end
+s = m:section(NamedSection, arg[1], "interface")
+s.addremove = true
-if not arg or not arg[1] then
- s.addremove = true
-end
-s:depends("proto", "static")
-s:depends("proto", "dhcp")
+back = s:option(DummyValue, "_overview", translate("overview"))
+back.value = ""
+back.titleref = luci.dispatcher.build_url("admin", "network", "network")
p = s:option(ListValue, "proto", translate("protocol"))
p:value("static", translate("static"))
p:value("dhcp", "DHCP")
+p:value("pppoe", "PPPoE")
+p:value("ppp", "PPP")
+p:value("pptp", "PPTP")
p.default = "static"
br = s:option(Flag, "type", translate("a_n_i_bridge"), translate("a_n_i_bridge1"))
end
end
+local zones = luci.tools.webadmin.network_get_zones(arg[1])
+if zones then
+ if #zones == 0 then
+ m:chain("firewall")
+
+ fwzone = s:option(Value, "_fwzone",
+ translate("network_interface_fwzone"),
+ translate("network_interface_fwzone_desc"))
+ fwzone.rmempty = true
+ fwzone:value("", "- " .. translate("none") .. " -")
+ fwzone:value(arg[1])
+ m.uci:load("firewall")
+ m.uci:foreach("firewall", "zone",
+ function (section)
+ fwzone:value(section.name)
+ end
+ )
+
+ function fwzone.write(self, section, value)
+ local zone = luci.tools.webadmin.firewall_find_zone(value)
+ local stat
+
+ if not zone then
+ stat = m.uci:section("firewall", "zone", nil, {
+ name = value,
+ network = section
+ })
+ else
+ local net = m.uci:get("firewall", zone, "network")
+ net = (net or value) .. " " .. section
+ stat = m.uci:set("firewall", zone, "network", net)
+ end
+
+ if stat then
+ self.render = function() end
+ end
+ end
+ else
+ fwzone = s:option(DummyValue, "_fwzone", translate("zone"))
+ fwzone.value = table.concat(zones, ", ")
+ end
+ fwzone.titleref = luci.dispatcher.build_url("admin", "network", "firewall", "zones")
+ m.uci:unload("firewall")
+end
ipaddr = s:option(Value, "ipaddr", translate("ipaddress"))
ipaddr.rmempty = true
mac.optional = true
+srv = s:option(Value, "server", translate("network_interface_server"))
+srv:depends("proto", "pptp")
+srv.rmempty = true
+
+user = s:option(Value, "username", translate("username"))
+user.rmempty = true
+user:depends("proto", "pptp")
+user:depends("proto", "pppoe")
+user:depends("proto", "ppp")
+
+pass = s:option(Value, "password", translate("password"))
+pass.rmempty = true
+pass:depends("proto", "pptp")
+pass:depends("proto", "pppoe")
+pass:depends("proto", "ppp")
+
+ka = s:option(Value, "keepalive",
+ translate("network_interface_keepalive"),
+ translate("network_interface_keepalive_desc")
+)
+ka.rmempty = true
+ka:depends("proto", "pptp")
+ka:depends("proto", "pppoe")
+ka:depends("proto", "ppp")
+
+demand = s:option(Value, "demand",
+ translate("network_interface_demand"),
+ translate("network_interface_demand_desc")
+)
+demand.rmempty = true
+demand:depends("proto", "pptp")
+demand:depends("proto", "pppoe")
+demand:depends("proto", "ppp")
+
+device = s:option(Value, "device",
+ translate("network_interface_device"),
+ translate("network_interface_device_desc")
+)
+device.rmempty = true
+device:depends("proto", "ppp")
+
+defaultroute = s:option(Flag, "defaultroute",
+ translate("network_interface_defaultroute"),
+ translate("network_interface_defaultroute_desc")
+)
+defaultroute:depends("proto", "ppp")
+
+peerdns = s:option(Flag, "peerdns",
+ translate("network_interface_peerdns"),
+ translate("network_interface_peerdns_desc")
+)
+peerdns:depends("proto", "ppp")
+
+ipv6 = s:option(Flag, "ipv6", translate("network_interface_ipv6") )
+ipv6:depends("proto", "ppp")
+
+connect = s:option(Value, "connect",
+ translate("network_interface_connect"),
+ translate("network_interface_connect_desc")
+)
+connect.rmempty = true
+connect:depends("proto", "ppp")
+
+disconnect = s:option(Value, "disconnect",
+ translate("network_interface_disconnect"),
+ translate("network_interface_disconnect_desc")
+)
+disconnect.rmempty = true
+disconnect:depends("proto", "ppp")
+
+pppd_options = s:option(Value, "pppd_options",
+ translate("network_interface_pppd_options"),
+ translate("network_interface_pppd_options_desc")
+)
+pppd_options.rmempty = true
+pppd_options:depends("proto", "ppp")
s2 = m:section(TypedSection, "alias", translate("aliases"))
s2.addremove = true
-if arg and arg[1] and luci.model.uci.get("network", arg[1]) then
- s2:depends("interface", arg[1])
- s2.defaults.interface = arg[1]
-else
- parent = s2:option(ListValue, "interface", translate("interface"))
- luci.model.uci.foreach("network", "interface",
- function (section)
- if section[".name"] ~= "loopback" then
- parent:value(section[".name"])
- end
- end
- )
-end
+s2:depends("interface", arg[1])
+s2.defaults.interface = arg[1]
s2.defaults.proto = "static"