X-Git-Url: http://git.ozo.com/?a=blobdiff_plain;ds=sidebyside;f=package%2Ffirewall%2Ffiles%2Fnew%2F20-firewall;fp=package%2Ffirewall%2Ffiles%2Fnew%2F20-firewall;h=a8ce17c97662ce87b6b263b2a0d64ee09ce381ed;hb=8e2cf077d0066a626bf3b90596acd941f430fe9e;hp=0000000000000000000000000000000000000000;hpb=d738ce55876f392957ef8fd186fb486b92298d4d;p=openwrt-working-2016%2F.git 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 +}