- #!/bin/sh
-
- [ "$ACTION" == "ifup" -o "$ACTION" == "ifdown" ] || exit 1
- [ -n "$INTERFACE" ] || exit 2
-
- if [ "$ACTION" == "ifup" ]; then
- [ -n "$DEVICE" ] || exit 3
- fi
-
- [ -x /usr/bin/ip ] || exit 4
- [ -x /usr/sbin/ipset ] || exit 5
- [ -x /usr/sbin/iptables ] || exit 6
- [ -x /usr/sbin/ip6tables ] || exit 7
- [ -x /usr/bin/logger ] || exit 8
-
- . /lib/functions.sh
- . /lib/functions/network.sh
- . /lib/mwan3/mwan3.sh
-
- config_load mwan3
-
- config_get enabled $INTERFACE enabled 0
- [ "$enabled" == "1" ] || exit 0
-
- $LOG notice "$ACTION interface $INTERFACE (${DEVICE:-unknown})"
-
- mwan3_set_connected_iptables
-
- case "$ACTION" in
- ifup)
- mwan3_set_general_rules
- mwan3_set_general_iptables
- mwan3_create_iface_rules $INTERFACE $DEVICE
- mwan3_create_iface_iptables $INTERFACE $DEVICE
- mwan3_create_iface_route $INTERFACE $DEVICE
- mwan3_track $INTERFACE $DEVICE
- mwan3_set_user_rules
- ;;
- ifdown)
- mwan3_delete_iface_rules $INTERFACE
- mwan3_delete_iface_iptables $INTERFACE
- mwan3_delete_iface_route $INTERFACE
- mwan3_delete_iface_ipset_entries $INTERFACE
- ;;
- esac
-
- config_foreach mwan3_create_policies_iptables policy
-
- exit 0
|