diff options
author | John Crispin <john@openwrt.org> | 2008-08-04 11:51:58 +0000 |
---|---|---|
committer | John Crispin <john@openwrt.org> | 2008-08-04 11:51:58 +0000 |
commit | 21bbdc24c397671e68606e846837f28df89a5a23 (patch) | |
tree | 372396ee96fd78a83bbffd5e33c073f5c6b9fb25 /package/firewall/files/new/20-firewall | |
parent | e4a0bfec3c1c9aaa59f4bd41182d394ec0ceb91d (diff) | |
download | upstream-21bbdc24c397671e68606e846837f28df89a5a23.tar.gz upstream-21bbdc24c397671e68606e846837f28df89a5a23.tar.bz2 upstream-21bbdc24c397671e68606e846837f28df89a5a23.zip |
adds a new uci firewall - iptbales and netfilter packages need to be rewrapped when we switch to this firewall as default - there are some examples in the file /etc/config/firewall - iptables-save/restore are still missing - hotplug takes care of adding/removing netdevs during runtime - misisng features ? wishes ? let me know ...
SVN-Revision: 12089
Diffstat (limited to 'package/firewall/files/new/20-firewall')
-rw-r--r-- | package/firewall/files/new/20-firewall | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/package/firewall/files/new/20-firewall b/package/firewall/files/new/20-firewall new file mode 100644 index 0000000000..a8ce17c976 --- /dev/null +++ b/package/firewall/files/new/20-firewall @@ -0,0 +1,41 @@ +. /lib/firewall/uci_firewall.sh +unset ZONE +config_get ifname $INTERFACE ifname +INTERFACE=$ifname +[ "$INTERFACE" == "lo" ] && exit 0 +load_zones() { + local name + local network + config_get name $1 name + config_get network $1 network + [ -z "$network" ] && return + for n in $network; do + local ifname + config_get ifname $n ifname + list_contains ifname $INTERFACE && { + list_contains ZONE $name || ZONE="$ZONE $name" + } + done +} + +config_foreach load_zones zone + +IFACE=$(find_config $INTERFACE) +[ -n "$IFACE" ] && + list_contains ZONE $IFACE || ZONE="$ZONE $IFACE" + +[ ifup = "$ACTION" ] && { + for z in $ZONE; do + local loaded + config_get loaded core loaded + [ -n "$loaded" ] && addif $INTERFACE $z + done +} + +[ ifdown = "$ACTION" ] && { + for z in $ZONE; do + local up + config_get up $z up + [ "$up" == "1" ] && delif $INTERFACE $z + done +} |