modules/admin-full: introduce a new tab for firewall related stuff in iface config...
[project/luci.git] / modules / admin-full / luasrc / model / cbi / admin_network / ifaces.lua
1 --[[
2 LuCI - Lua Configuration Interface
3
4 Copyright 2008 Steven Barth <steven@midlink.org>
5 Copyright 2008 Jo-Philipp Wich <xm@subsignal.org>
6
7 Licensed under the Apache License, Version 2.0 (the "License");
8 you may not use this file except in compliance with the License.
9 You may obtain a copy of the License at
10
11 http://www.apache.org/licenses/LICENSE-2.0
12
13 $Id$
14 ]]--
15
16 local fs = require "nixio.fs"
17 local nw = require "luci.model.network"
18 local fw = require "luci.model.firewall"
19
20 arg[1] = arg[1] or ""
21
22 local has_3g = fs.access("/usr/bin/gcom")
23 local has_pptp = fs.access("/usr/sbin/pptp")
24 local has_pppd = fs.access("/usr/sbin/pppd")
25 local has_pppoe = fs.glob("/usr/lib/pppd/*/rp-pppoe.so")()
26 local has_pppoa = fs.glob("/usr/lib/pppd/*/pppoatm.so")()
27 local has_ipv6 = fs.access("/proc/net/ipv6_route")
28
29 m = Map("network", translate("interfaces"), translate("a_n_ifaces1"))
30 m:chain("firewall")
31 m:chain("wireless")
32
33 nw.init(m.uci)
34 fw.init(m.uci)
35
36 s = m:section(NamedSection, arg[1], "interface")
37 s.addremove = false
38
39 s:tab("general", translate("a_n_general", "General Setup"))
40 if has_ipv6 then s:tab("ipv6", translate("a_n_ipv6", "IPv6 Setup")) end
41 if has_pppd then s:tab("ppp", translate("a_n_ppp", "PPP Settings")) end
42 s:tab("physical", translate("a_n_physical", "Physical Settings"))
43 s:tab("firewall", translate("a_n_firewall", "Firewall Settings"))
44
45 --[[
46 back = s:taboption("general", DummyValue, "_overview", translate("overview"))
47 back.value = ""
48 back.titleref = luci.dispatcher.build_url("admin", "network", "network")
49 ]]
50
51 p = s:taboption("general", ListValue, "proto", translate("protocol"))
52 p.override_scheme = true
53 p.default = "static"
54 p:value("static", translate("static"))
55 p:value("dhcp", "DHCP")
56 if has_pppd then p:value("ppp", "PPP") end
57 if has_pppoe then p:value("pppoe", "PPPoE") end
58 if has_pppoa then p:value("pppoa", "PPPoA") end
59 if has_3g then p:value("3g", "UMTS/3G") end
60 if has_pptp then p:value("pptp", "PPTP") end
61 p:value("none", translate("none"))
62
63 if not ( has_pppd and has_pppoe and has_pppoa and has_3g and has_pptp ) then
64 p.description = translate("network_interface_prereq")
65 end
66
67 br = s:taboption("physical", Flag, "type", translate("a_n_i_bridge"), translate("a_n_i_bridge1"))
68 br.enabled = "bridge"
69 br.rmempty = true
70
71 stp = s:taboption("physical", Flag, "stp", translate("a_n_i_stp"),
72 translate("a_n_i_stp1", "Enables the Spanning Tree Protocol on this bridge"))
73 stp:depends("type", "1")
74 stp.rmempty = true
75
76 ifname_single = s:taboption("physical", Value, "ifname_single", translate("interface"))
77 ifname_single.template = "cbi/network_ifacelist"
78 ifname_single.widget = "radio"
79 ifname_single.nobridges = true
80 ifname_single.network = arg[1]
81 ifname_single.rmempty = true
82 ifname_single:depends("type", "")
83
84 function ifname_single.cfgvalue(self, s)
85 return self.map.uci:get("network", s, "ifname")
86 end
87
88 function ifname_single.write(self, s, val)
89 local n = nw:get_network(s)
90 if n then
91 local i
92 for _, i in ipairs(n:get_interfaces()) do
93 n:del_interface(i)
94 end
95 n:add_interface(val)
96 end
97 end
98
99
100 ifname_multi = s:taboption("physical", MultiValue, "ifname_multi", translate("interface"))
101 ifname_multi.template = "cbi/network_ifacelist"
102 ifname_multi.nobridges = true
103 ifname_multi.network = arg[1]
104 ifname_multi.widget = "checkbox"
105 ifname_multi:depends("type", "1")
106 ifname_multi.cfgvalue = ifname_single.cfgvalue
107 ifname_multi.write = ifname_single.write
108
109
110 for _, d in ipairs(nw:get_interfaces()) do
111 if not d:is_bridge() then
112 ifname_single:value(d:name())
113 ifname_multi:value(d:name())
114 end
115 end
116
117
118 local fwd_to, fwd_from
119
120 fwzone = s:taboption("firewall", Value, "_fwzone",
121 translate("network_interface_fwzone"),
122 translate("network_interface_fwzone_desc"))
123
124 fwzone.template = "cbi/firewall_zonelist"
125 fwzone.network = arg[1]
126 fwzone.rmempty = false
127
128 function fwzone.cfgvalue(self, section)
129 self.iface = section
130 local z = fw:get_zone_by_network(section)
131 return z and z:name()
132 end
133
134 function fwzone.write(self, section, value)
135 local zone = fw:get_zone(value)
136
137 if not zone and value == '-' then
138 value = m:formvalue(self:cbid(section) .. ".newzone")
139 if value and #value > 0 then
140 zone = fw:add_zone(value)
141 else
142 fw:del_network(section)
143 end
144 end
145
146 if zone then
147 fw:del_network(section)
148 zone:add_network(section)
149 end
150 end
151
152
153 ipaddr = s:taboption("general", Value, "ipaddr", translate("ipaddress"))
154 ipaddr.rmempty = true
155 ipaddr:depends("proto", "static")
156
157 nm = s:taboption("general", Value, "netmask", translate("netmask"))
158 nm.rmempty = true
159 nm:depends("proto", "static")
160 nm:value("255.255.255.0")
161 nm:value("255.255.0.0")
162 nm:value("255.0.0.0")
163
164 gw = s:taboption("general", Value, "gateway", translate("gateway"))
165 gw:depends("proto", "static")
166 gw.rmempty = true
167
168 bcast = s:taboption("general", Value, "bcast", translate("broadcast"))
169 bcast:depends("proto", "static")
170
171 if has_ipv6 then
172 ip6addr = s:taboption("ipv6", Value, "ip6addr", translate("ip6address"), translate("cidr6"))
173 ip6addr:depends("proto", "static")
174
175 ip6gw = s:taboption("ipv6", Value, "ip6gw", translate("gateway6"))
176 ip6gw:depends("proto", "static")
177 end
178
179 dns = s:taboption("general", Value, "dns", translate("dnsserver"))
180 dns:depends("peerdns", "")
181
182 mtu = s:taboption("physical", Value, "mtu", "MTU")
183 mtu.isinteger = true
184
185 mac = s:taboption("physical", Value, "macaddr", translate("macaddress"))
186
187
188 srv = s:taboption("general", Value, "server", translate("network_interface_server"))
189 srv:depends("proto", "pptp")
190 srv.rmempty = true
191
192 if has_3g then
193 service = s:taboption("general", ListValue, "service", translate("network_interface_service"))
194 service:value("", translate("cbi_select"))
195 service:value("umts", "UMTS/GPRS")
196 service:value("cdma", "CDMA")
197 service:value("evdo", "EV-DO")
198 service:depends("proto", "3g")
199 service.rmempty = true
200
201 apn = s:taboption("general", Value, "apn", translate("network_interface_apn"))
202 apn:depends("proto", "3g")
203
204 pincode = s:taboption("general", Value, "pincode",
205 translate("network_interface_pincode"),
206 translate("network_interface_pincode_desc")
207 )
208 pincode:depends("proto", "3g")
209 end
210
211 if has_pppd or has_pppoe or has_pppoa or has_3g or has_pptp then
212 user = s:taboption("general", Value, "username", translate("username"))
213 user.rmempty = true
214 user:depends("proto", "pptp")
215 user:depends("proto", "pppoe")
216 user:depends("proto", "pppoa")
217 user:depends("proto", "ppp")
218 user:depends("proto", "3g")
219
220 pass = s:taboption("general", Value, "password", translate("password"))
221 pass.rmempty = true
222 pass.password = true
223 pass:depends("proto", "pptp")
224 pass:depends("proto", "pppoe")
225 pass:depends("proto", "pppoa")
226 pass:depends("proto", "ppp")
227 pass:depends("proto", "3g")
228
229 ka = s:taboption("ppp", Value, "keepalive",
230 translate("network_interface_keepalive"),
231 translate("network_interface_keepalive_desc")
232 )
233 ka:depends("proto", "pptp")
234 ka:depends("proto", "pppoe")
235 ka:depends("proto", "pppoa")
236 ka:depends("proto", "ppp")
237 ka:depends("proto", "3g")
238
239 demand = s:taboption("ppp", Value, "demand",
240 translate("network_interface_demand"),
241 translate("network_interface_demand_desc")
242 )
243 demand:depends("proto", "pptp")
244 demand:depends("proto", "pppoe")
245 demand:depends("proto", "pppoa")
246 demand:depends("proto", "ppp")
247 demand:depends("proto", "3g")
248 end
249
250 if has_pppoa then
251 encaps = s:taboption("ppp", ListValue, "encaps", translate("network_interface_encaps"))
252 encaps:depends("proto", "pppoa")
253 encaps:value("", translate("cbi_select"))
254 encaps:value("vc", "VC")
255 encaps:value("llc", "LLC")
256
257 vpi = s:taboption("ppp", Value, "vpi", "VPI")
258 vpi:depends("proto", "pppoa")
259
260 vci = s:taboption("ppp", Value, "vci", "VCI")
261 vci:depends("proto", "pppoa")
262 end
263
264 if has_pptp or has_pppd or has_pppoe or has_pppoa or has_3g then
265 device = s:taboption("general", Value, "device",
266 translate("network_interface_device"),
267 translate("network_interface_device_desc")
268 )
269 device:depends("proto", "ppp")
270 device:depends("proto", "3g")
271
272 defaultroute = s:taboption("ppp", Flag, "defaultroute",
273 translate("network_interface_defaultroute"),
274 translate("network_interface_defaultroute_desc")
275 )
276 defaultroute:depends("proto", "ppp")
277 defaultroute:depends("proto", "pppoa")
278 defaultroute:depends("proto", "pppoe")
279 defaultroute:depends("proto", "pptp")
280 defaultroute:depends("proto", "3g")
281 defaultroute.rmempty = false
282 function defaultroute.cfgvalue(...)
283 return ( AbstractValue.cfgvalue(...) or '1' )
284 end
285
286 peerdns = s:taboption("ppp", Flag, "peerdns",
287 translate("network_interface_peerdns"),
288 translate("network_interface_peerdns_desc")
289 )
290 peerdns:depends("proto", "ppp")
291 peerdns:depends("proto", "pppoa")
292 peerdns:depends("proto", "pppoe")
293 peerdns:depends("proto", "pptp")
294 peerdns:depends("proto", "3g")
295 peerdns.rmempty = false
296 function peerdns.cfgvalue(...)
297 return ( AbstractValue.cfgvalue(...) or '1' )
298 end
299
300 if has_ipv6 then
301 ipv6 = s:taboption("ppp", Flag, "ipv6", translate("network_interface_ipv6") )
302 ipv6:depends("proto", "ppp")
303 ipv6:depends("proto", "pppoa")
304 ipv6:depends("proto", "pppoe")
305 ipv6:depends("proto", "pptp")
306 ipv6:depends("proto", "3g")
307 end
308
309 connect = s:taboption("ppp", Value, "connect",
310 translate("network_interface_connect"),
311 translate("network_interface_connect_desc")
312 )
313 connect:depends("proto", "ppp")
314 connect:depends("proto", "pppoe")
315 connect:depends("proto", "pppoa")
316 connect:depends("proto", "pptp")
317 connect:depends("proto", "3g")
318
319 disconnect = s:taboption("ppp", Value, "disconnect",
320 translate("network_interface_disconnect"),
321 translate("network_interface_disconnect_desc")
322 )
323 disconnect:depends("proto", "ppp")
324 disconnect:depends("proto", "pppoe")
325 disconnect:depends("proto", "pppoa")
326 disconnect:depends("proto", "pptp")
327 disconnect:depends("proto", "3g")
328
329 pppd_options = s:taboption("ppp", Value, "pppd_options",
330 translate("network_interface_pppd_options"),
331 translate("network_interface_pppd_options_desc")
332 )
333 pppd_options:depends("proto", "ppp")
334 pppd_options:depends("proto", "pppoa")
335 pppd_options:depends("proto", "pppoe")
336 pppd_options:depends("proto", "pptp")
337 pppd_options:depends("proto", "3g")
338
339 maxwait = s:taboption("ppp", Value, "maxwait",
340 translate("network_interface_maxwait"),
341 translate("network_interface_maxwait_desc")
342 )
343 maxwait:depends("proto", "3g")
344 end
345
346 s2 = m:section(TypedSection, "alias", translate("aliases"))
347 s2.addremove = true
348
349 s2:depends("interface", arg[1])
350 s2.defaults.interface = arg[1]
351
352 s2:tab("general", translate("a_n_general", "General Setup"))
353
354 s2.defaults.proto = "static"
355
356 s2:taboption("general", Value, "ipaddr", translate("ipaddress")).rmempty = true
357
358 nm = s2:taboption("general", Value, "netmask", translate("netmask"))
359 nm.rmempty = true
360 nm:value("255.255.255.0")
361 nm:value("255.255.0.0")
362 nm:value("255.0.0.0")
363
364 s2:taboption("general", Value, "gateway", translate("gateway")).rmempty = true
365 s2:taboption("general", Value, "bcast", translate("broadcast"))
366 s2:taboption("general", Value, "dns", translate("dnsserver"))
367
368 if has_ipv6 then
369 s2:tab("ipv6", translate("a_n_ipv6", "IPv6 Setup"))
370 s2:taboption("ipv6", Value, "ip6addr", translate("ip6address"), translate("cidr6"))
371 s2:taboption("ipv6", Value, "ip6gw", translate("gateway6"))
372 end
373
374 return m