diff options
author | John Crispin <blogic@openwrt.org> | 2008-08-27 18:31:34 +0000 |
---|---|---|
committer | John Crispin <blogic@openwrt.org> | 2008-08-27 18:31:34 +0000 |
commit | 44382e0f8b45c0da3fca8108f93bb2bcdf17d3d1 (patch) | |
tree | 38916b62f4dc4fad022dc902f8fe61eacdb7204b /package/firewall/files | |
parent | 1392ad82ec9309169306da05b84caa072bb4414a (diff) | |
download | upstream-44382e0f8b45c0da3fca8108f93bb2bcdf17d3d1.tar.gz upstream-44382e0f8b45c0da3fca8108f93bb2bcdf17d3d1.tar.bz2 upstream-44382e0f8b45c0da3fca8108f93bb2bcdf17d3d1.zip |
fix device duplication in firewall if the balancing of ifup and ifdown is broken
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@12404 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/firewall/files')
-rwxr-xr-x | package/firewall/files/uci_firewall.sh | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/package/firewall/files/uci_firewall.sh b/package/firewall/files/uci_firewall.sh index 5063d9e088..925ab4eb4b 100755 --- a/package/firewall/files/uci_firewall.sh +++ b/package/firewall/files/uci_firewall.sh @@ -53,6 +53,10 @@ create_zone() { } addif() { + local dev + config_get dev core $2 + [ -n "$dev" -a "$dev" != "$1" ] && delif "$dev" "$2" + [ -n "$dev" -a "$dev" == "$1" ] && return logger "adding $1 to firewall zone $2" $IPTABLES -A INPUT -i $1 -j zone_$2 $IPTABLES -I zone_$2_ACCEPT 1 -o $1 -j ACCEPT @@ -64,6 +68,7 @@ addif() { $IPTABLES -I zone_$2_nat 1 -t nat -o $1 -j MASQUERADE $IPTABLES -I PREROUTING 1 -t nat -i $1 -j zone_$2_prerouting $IPTABLES -A FORWARD -i $1 -j zone_$2_forward + uci_set_state firewall core "$2" "$1" } delif() { @@ -78,6 +83,7 @@ delif() { $IPTABLES -D zone_$2_nat -t nat -o $1 -j MASQUERADE $IPTABLES -D PREROUTING -t nat -i $1 -j zone_$2_prerouting $IPTABLES -D FORWARD -i $1 -j zone_$2_forward + uci_revert_state firewall core "$2" } load_synflood() { @@ -106,6 +112,9 @@ fw_defaults() { do echo 0 > $f done + + uci_revert_state firewall core + uci_set_state firewall core "" firewall_state $IPTABLES -F $IPTABLES -t nat -F @@ -306,8 +315,6 @@ fw_init() { fw_custom_chains echo "Loading includes" config_foreach fw_include include - - uci_set_state firewall core "" firewall_state uci_set_state firewall core loaded 1 unset CONFIG_APPEND config_load network |