summaryrefslogtreecommitdiffstats
path: root/package/firewall/files/lib/core.sh
diff options
context:
space:
mode:
authorjow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73>2010-09-14 23:11:12 +0000
committerjow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73>2010-09-14 23:11:12 +0000
commitac32f8a93b20dbb922568f7d8f3fc9195de708a6 (patch)
treeb135139dc32ba513810092a23b2400ec94ac98c6 /package/firewall/files/lib/core.sh
parente30b799cdce79c4fe33c8bd09d2f289baf788382 (diff)
[package] firewall: deliver remove hotplug events for all active zones/networks when restarting the firewall
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@23062 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/firewall/files/lib/core.sh')
-rw-r--r--package/firewall/files/lib/core.sh14
1 files changed, 14 insertions, 0 deletions
diff --git a/package/firewall/files/lib/core.sh b/package/firewall/files/lib/core.sh
index 03a80c6f6..2178e0505 100644
--- a/package/firewall/files/lib/core.sh
+++ b/package/firewall/files/lib/core.sh
@@ -49,6 +49,7 @@ fw_start() {
fw_callback post core
+ uci_set_state firewall core zones "$FW_ZONES"
uci_set_state firewall core loaded 1
}
@@ -57,6 +58,19 @@ fw_stop() {
fw_callback pre stop
+ local old_zones z
+ config_get old_zones core zones
+ for z in $old_zones; do
+ local old_networks n i
+ config_get old_networks core "${z}_networks"
+ for n in $old_networks; do
+ config_get i core "${n}_ifname"
+ [ -n "$i" ] && env -i ACTION=remove ZONE="$z" \
+ INTERFACE="$n" DEVICE="$i" \
+ /sbin/hotplug-call firewall
+ done
+ done
+
fw_clear ACCEPT
fw_callback post stop