#!/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
