mirror of
https://github.com/JamesonHuang/OpenWrt_Luci_Lua.git
synced 2024-11-24 06:10:11 +00:00
89 lines
2.2 KiB
Lua
89 lines
2.2 KiB
Lua
|
--[[
|
||
|
LuCI - Lua Configuration Interface
|
||
|
|
||
|
Copyright 2008 Steven Barth <steven@midlink.org>
|
||
|
|
||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
you may not use this file except in compliance with the License.
|
||
|
You may obtain a copy of the License at
|
||
|
|
||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||
|
|
||
|
$Id: zones.lua 8108 2011-12-19 21:16:31Z jow $
|
||
|
]]--
|
||
|
|
||
|
local ds = require "luci.dispatcher"
|
||
|
local fw = require "luci.model.firewall"
|
||
|
|
||
|
local m, s, o, p, i, v
|
||
|
|
||
|
m = Map("firewall",
|
||
|
translate("Firewall - Zone Settings"),
|
||
|
translate("The firewall creates zones over your network interfaces to control network traffic flow."))
|
||
|
|
||
|
fw.init(m.uci)
|
||
|
|
||
|
s = m:section(TypedSection, "defaults", translate("General Settings"))
|
||
|
s.anonymous = true
|
||
|
s.addremove = false
|
||
|
|
||
|
s:option(Flag, "syn_flood", translate("Enable SYN-flood protection"))
|
||
|
|
||
|
o = s:option(Flag, "drop_invalid", translate("Drop invalid packets"))
|
||
|
o.default = o.disabled
|
||
|
|
||
|
p = {
|
||
|
s:option(ListValue, "input", translate("Input")),
|
||
|
s:option(ListValue, "output", translate("Output")),
|
||
|
s:option(ListValue, "forward", translate("Forward"))
|
||
|
}
|
||
|
|
||
|
for i, v in ipairs(p) do
|
||
|
v:value("REJECT", translate("reject"))
|
||
|
v:value("DROP", translate("drop"))
|
||
|
v:value("ACCEPT", translate("accept"))
|
||
|
end
|
||
|
|
||
|
|
||
|
s = m:section(TypedSection, "zone", translate("Zones"))
|
||
|
s.template = "cbi/tblsection"
|
||
|
s.anonymous = true
|
||
|
s.addremove = true
|
||
|
s.extedit = ds.build_url("admin", "network", "firewall", "zones", "%s")
|
||
|
|
||
|
function s.create(self)
|
||
|
local z = fw:new_zone()
|
||
|
if z then
|
||
|
luci.http.redirect(
|
||
|
ds.build_url("admin", "network", "firewall", "zones", z.sid)
|
||
|
)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
function s.remove(self, section)
|
||
|
return fw:del_zone(section)
|
||
|
end
|
||
|
|
||
|
o = s:option(DummyValue, "_info", translate("Zone ⇒ Forwardings"))
|
||
|
o.template = "cbi/firewall_zoneforwards"
|
||
|
o.cfgvalue = function(self, section)
|
||
|
return self.map:get(section, "name")
|
||
|
end
|
||
|
|
||
|
p = {
|
||
|
s:option(ListValue, "input", translate("Input")),
|
||
|
s:option(ListValue, "output", translate("Output")),
|
||
|
s:option(ListValue, "forward", translate("Forward"))
|
||
|
}
|
||
|
|
||
|
for i, v in ipairs(p) do
|
||
|
v:value("REJECT", translate("reject"))
|
||
|
v:value("DROP", translate("drop"))
|
||
|
v:value("ACCEPT", translate("accept"))
|
||
|
end
|
||
|
|
||
|
s:option(Flag, "masq", translate("Masquerading"))
|
||
|
s:option(Flag, "mtu_fix", translate("MSS clamping"))
|
||
|
|
||
|
return m
|