1 -- Copyright 2008 Steven Barth <steven@midlink.org>
2 -- Licensed to the public under the Apache License 2.0.
4 local ds = require "luci.dispatcher"
5 local fw = require "luci.model.firewall"
6 local fs = require "nixio.fs"
11 translate("Firewall - Zone Settings"),
12 translate("The firewall creates zones over your network interfaces to control network traffic flow."))
16 s = m:section(TypedSection, "defaults", translate("General Settings"))
20 s:option(Flag, "syn_flood", translate("Enable SYN-flood protection"))
22 o = s:option(Flag, "drop_invalid", translate("Drop invalid packets"))
25 s:option(ListValue, "input", translate("Input")),
26 s:option(ListValue, "output", translate("Output")),
27 s:option(ListValue, "forward", translate("Forward"))
30 for i, v in ipairs(p) do
31 v:value("REJECT", translate("reject"))
32 v:value("DROP", translate("drop"))
33 v:value("ACCEPT", translate("accept"))
36 -- Netfilter flow offload support
38 local offload = fs.access("/sys/module/xt_FLOWOFFLOAD/refcnt")
41 s:option(DummyValue, "offload_advice",
42 translate("Routing/NAT Offloading"),
43 translate("Experimental feature. Not fully compatible with QoS/SQM."))
45 o = s:option(Flag, "flow_offloading",
46 translate("Software flow offloading"),
47 translate("Software based offloading for routing/NAT"))
50 o = s:option(Flag, "flow_offloading_hw",
51 translate("Hardware flow offloading"),
52 translate("Requires hardware NAT support. Implemented at least for mt7621"))
54 o:depends( "flow_offloading", 1)
59 s = m:section(TypedSection, "zone", translate("Zones"))
60 s.template = "cbi/tblsection"
63 s.extedit = ds.build_url("admin", "network", "firewall", "zones", "%s")
65 function s.create(self)
66 local z = fw:new_zone()
69 ds.build_url("admin", "network", "firewall", "zones", z.sid)
74 function s.remove(self, section)
75 return fw:del_zone(section)
78 o = s:option(DummyValue, "_info", translate("Zone ⇒ Forwardings"))
79 o.template = "cbi/firewall_zoneforwards"
80 o.cfgvalue = function(self, section)
81 return self.map:get(section, "name")
85 s:option(ListValue, "input", translate("Input")),
86 s:option(ListValue, "output", translate("Output")),
87 s:option(ListValue, "forward", translate("Forward"))
90 for i, v in ipairs(p) do
91 v:value("REJECT", translate("reject"))
92 v:value("DROP", translate("drop"))
93 v:value("ACCEPT", translate("accept"))
96 s:option(Flag, "masq", translate("Masquerading"))
97 s:option(Flag, "mtu_fix", translate("MSS clamping"))