summaryrefslogtreecommitdiffhomepage
path: root/libs/core/luasrc
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2010-11-01 01:51:26 +0000
committerJo-Philipp Wich <jow@openwrt.org>2010-11-01 01:51:26 +0000
commitaab6378bc31be9b50c34135d4d3bbca00fcd732d (patch)
treefdc6f77164ace45a061037d2a1e43f9b36fbc61b /libs/core/luasrc
parent5b63f544f520a6d441713940a017a312f1e5e32d (diff)
libs/core: several fixes for firewall model
Diffstat (limited to 'libs/core/luasrc')
-rw-r--r--libs/core/luasrc/model/firewall.lua21
1 files changed, 10 insertions, 11 deletions
diff --git a/libs/core/luasrc/model/firewall.lua b/libs/core/luasrc/model/firewall.lua
index 1251feaa91..160995c262 100644
--- a/libs/core/luasrc/model/firewall.lua
+++ b/libs/core/luasrc/model/firewall.lua
@@ -339,11 +339,8 @@ function zone.add_network(self, net)
nets[#nets+1] = net
- if #nets > 0 then
- self:set("network", table.concat(nets, " "))
- else
- self:set("network", " ")
- end
+ _M:del_network(net)
+ self:set("network", table.concat(nets, " "))
end
end
@@ -375,6 +372,10 @@ function zone.get_networks(self)
return nets
end
+function zone.clear_networks(self)
+ self:set("network", " ")
+end
+
function zone.get_forwardings_by(self, what)
local name = self:name()
local forwards = { }
@@ -399,7 +400,7 @@ function zone.add_forwarding_to(self, dest)
end
end
- if not exist and dest ~= self:name() then
+ if not exist and dest ~= self:name() and _valid_id(dest) then
local s = uci_r:section("firewall", "forwarding", nil, {
src = self:name(),
dest = dest
@@ -419,7 +420,7 @@ function zone.add_forwarding_from(self, src)
end
end
- if not exist and src ~= self:name() then
+ if not exist and src ~= self:name() and _valid_id(src) then
local s = uci_r:section("firewall", "forwarding", nil, {
src = src,
dest = self:name()
@@ -432,11 +433,9 @@ end
function zone.del_forwardings_by(self, what)
local name = self:name()
- uci_r:foreach("firewall", "forwarding",
+ uci_r:delete_all("firewall", "forwarding",
function(s)
- if s.src and s.dest and s[what] == name then
- uci_r:delete("firewall", s['.name'])
- end
+ return (s.src and s.dest and s[what] == name)
end)
end