X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/ac32f8a93b20dbb922568f7d8f3fc9195de708a6..ec40024c13729034674107632ca48de6771c8eaf:/package/firewall/files/lib/core.sh diff --git a/package/firewall/files/lib/core.sh b/package/firewall/files/lib/core.sh index 2178e0505..0297518a5 100644 --- a/package/firewall/files/lib/core.sh +++ b/package/firewall/files/lib/core.sh @@ -58,17 +58,21 @@ 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 + local z n i + config_get z core zones + for z in $z; do + config_get n core "${z}_networks" + for n in $n; do config_get i core "${n}_ifname" [ -n "$i" ] && env -i ACTION=remove ZONE="$z" \ - INTERFACE="$n" DEVICE="$i" \ - /sbin/hotplug-call firewall + INTERFACE="$n" DEVICE="$i" /sbin/hotplug-call firewall done + + config_get i core "${z}_tcpmss" + [ "$i" == 1 ] && { + fw del i m FORWARD zone_${z}_MSSFIX + fw del i m zone_${z}_MSSFIX + } done fw_clear ACCEPT @@ -109,10 +113,8 @@ fw_die() { fw_log() { local level="$1" - [ -n "$2" ] || { - shift - level=notice - } + [ -n "$2" ] && shift || level=notice + [ "$level" != error ] || echo "Error: $@" >&2 logger -t firewall -p user.$level "$@" }