2018-01-23 14:35:00 +00:00
# vim: set ft=sh noexpandtab tabstop=4 shiftwidth=4 softtabstop=4 :
SETROUTE=false
set_route() {
2020-05-14 19:14:42 +00:00
local multipath_config_route interface_gw interface_if
2018-01-23 14:35:00 +00:00
INTERFACE=$1
2018-02-20 12:48:12 +00:00
PREVINTERFACE=$2
2020-08-19 13:40:38 +00:00
SETDEFAULT=$3
[ -z "$SETDEFAULT" ] && SETDEFAULT="yes"
2020-05-14 19:14:42 +00:00
multipath_config_route=$(uci -q get openmptcprouter.$INTERFACE.multipath)
[ -z "$multipath_config_route" ] && multipath_config_route=$(uci -q get network.$INTERFACE.multipath || echo "off")
2019-03-28 20:35:05 +00:00
interface_if=$(ifstatus "$INTERFACE" 2>/dev/null | jsonfilter -q -e '@["l3_device"]')
2020-09-02 08:07:24 +00:00
interface_up=$(ifstatus "$INTERFACE" 2>/dev/null | jsonfilter -q -e '@["up"]')
2018-07-23 20:31:43 +00:00
[ -z "$interface_if" ] && interface_if=$(ifstatus "${INTERFACE}_4" 2>/dev/null | jsonfilter -q -e '@["l3_device"]')
2019-03-28 20:35:05 +00:00
[ -z "$interface_if" ] && interface_if=$(uci -q get network.$INTERFACE.ifname)
2019-11-13 18:22:08 +00:00
interface_current_config=$(uci -q get openmptcprouter.$INTERFACE.state || echo "up")
2020-09-02 08:07:24 +00:00
if [ "$multipath_config_route" != "off" ] && [ "$SETROUTE" != true ] && [ "$INTERFACE" != "$PREVINTERFACE" ] && [ "$interface_current_config" = "up" ] && [ "$interface_up" = "true" ]; then
2018-05-29 16:03:50 +00:00
interface_gw="$(uci -q get network.$INTERFACE.gateway)"
if [ -z "$interface_gw" ]; then
2019-01-11 17:10:22 +00:00
interface_gw=$(ubus call network.interface.$INTERFACE status 2>/dev/null | jsonfilter -q -l 1 -e '@.inactive.route[@.target="0.0.0.0"].nexthop' | tr -d "\n")
2018-03-06 07:20:59 +00:00
fi
2018-05-29 16:03:50 +00:00
if [ -z "$interface_gw" ]; then
2019-01-11 17:10:22 +00:00
interface_gw=$(ubus call network.interface.$INTERFACE status 2>/dev/null | jsonfilter -q -l 1 -e '@.route[@.target="0.0.0.0"].nexthop' | tr -d "\n")
2018-03-06 07:20:59 +00:00
fi
2018-07-23 15:37:37 +00:00
if [ -z "$interface_gw" ]; then
2019-01-11 17:10:22 +00:00
interface_gw=$(ubus call network.interface.${INTERFACE}_4 status 2>/dev/null | jsonfilter -q -l 1 -e '@.inactive.route[@.target="0.0.0.0"].nexthop' | tr -d "\n")
2018-07-23 15:37:37 +00:00
fi
2020-02-25 13:20:30 +00:00
if [ "$interface_gw" != "" ] && [ "$interface_if" != "" ]; then
2018-05-26 20:04:54 +00:00
_log "$PREVINTERFACE down. Replace default route by $interface_gw dev $interface_if"
2020-08-19 13:40:38 +00:00
[ "$SETDEFAULT" = "yes" ] && ip route replace default scope global nexthop via $interface_gw dev $interface_if
ip route replace default via $interface_gw dev $interface_if table 991337 && SETROUTE=true
2018-02-22 11:03:37 +00:00
fi
2018-01-23 14:35:00 +00:00
fi
}
2018-12-21 14:38:45 +00:00
set_server_default_route() {
local server=$1
2020-05-14 19:14:42 +00:00
local serverip multipath_config_route
2018-12-21 14:38:45 +00:00
config_get serverip $server ip
2020-09-04 20:05:58 +00:00
[ -n "$serverip" ] && serverip="$(resolveip -4 -t 5 $serverip | head -n 1 | tr -d '\n')"
2020-05-11 08:34:16 +00:00
config_get disabled $server disabled
[ "$disabled" = "1" ] && return
2020-05-14 19:14:42 +00:00
multipath_config_route=$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.multipath)
2019-08-27 20:24:45 +00:00
[ -z "$multipath_config_route" ] && multipath_config_route=$(uci -q get network.$OMR_TRACKER_INTERFACE.multipath || echo "off")
2018-12-27 16:48:45 +00:00
if [ "$serverip" != "" ] && [ "$OMR_TRACKER_DEVICE_GATEWAY" != "" ] && [ "$(ip route show dev $OMR_TRACKER_DEVICE metric 1 | grep $serverip | grep $OMR_TRACKER_DEVICE_GATEWAY)" = "" ] && [ "$multipath_config_route" != "off" ]; then
2018-12-21 14:38:45 +00:00
_log "Set server $server ($serverip) default route via $OMR_TRACKER_DEVICE_GATEWAY"
2020-07-03 17:10:22 +00:00
if [ "$(ip r show $serverip | grep nexthop)" != "" ]; then
ip r delete $serverip >/dev/null 2>&1
fi
2018-12-27 16:48:45 +00:00
ip route replace $serverip via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE metric 1
2018-03-19 15:19:24 +00:00
fi
}
2020-02-28 18:51:17 +00:00
delete_server_default_route() {
local server=$1
local serverip
config_get serverip $server ip
2020-09-04 20:05:58 +00:00
[ -n "$serverip" ] && serverip="$(resolveip -4 -t 5 $serverip | head -n 1 | tr -d '\n')"
2020-05-11 08:34:16 +00:00
config_get disabled $server disabled
[ "$disabled" = "1" ] && return
2020-02-29 20:02:23 +00:00
if [ "$serverip" != "" ] && [ "$(ip route show $serverip metric 1)" != "" ]; then
2020-02-28 18:51:17 +00:00
_log "Delete server ($serverip) default route"
2020-02-29 20:02:23 +00:00
ip route del $serverip metric 1 >/dev/null 2>&1
2020-02-28 18:51:17 +00:00
fi
}
2019-07-24 17:58:58 +00:00
set_routes_intf() {
2020-05-14 19:14:42 +00:00
local multipath_config_route
2019-07-24 17:58:58 +00:00
local INTERFACE=$1
2020-05-14 19:14:42 +00:00
multipath_config_route=$(uci -q get openmptcprouter.$INTERFACE.multipath)
[ -z "$multipath_config_route" ] && multipath_config_route=$(uci -q get network.$INTERFACE.multipath || echo "off")
2019-07-24 17:58:58 +00:00
interface_if=$(ifstatus "$INTERFACE" 2>/dev/null | jsonfilter -q -e '@["l3_device"]')
[ -z "$interface_if" ] && interface_if=$(ifstatus "${INTERFACE}_4" 2>/dev/null | jsonfilter -q -e '@["l3_device"]')
[ -z "$interface_if" ] && interface_if=$(uci -q get network.$INTERFACE.ifname)
2020-09-02 08:07:24 +00:00
interface_up=$(ifstatus "$INTERFACE" 2>/dev/null | jsonfilter -q -e '@["up"]')
2019-11-13 18:22:08 +00:00
#multipath_current_config=$(multipath $interface_if | grep 'deactivated')
2019-11-17 07:55:15 +00:00
interface_current_config=$(uci -q get openmptcprouter.$INTERFACE.state || echo "up")
2020-09-02 08:07:24 +00:00
if [ "$multipath_config_route" != "off" ] && [ "$interface_current_config" = "up" ] && [ "$interface_if" != "" ] && [ "$interface_up" = "true" ]; then
2019-07-24 17:58:58 +00:00
interface_gw="$(uci -q get network.$INTERFACE.gateway)"
if [ -z "$interface_gw" ]; then
interface_gw=$(ubus call network.interface.$INTERFACE status 2>/dev/null | jsonfilter -q -l 1 -e '@.inactive.route[@.target="0.0.0.0"].nexthop' | tr -d "\n")
fi
if [ -z "$interface_gw" ]; then
interface_gw=$(ubus call network.interface.$INTERFACE status 2>/dev/null | jsonfilter -q -l 1 -e '@.route[@.target="0.0.0.0"].nexthop' | tr -d "\n")
fi
if [ -z "$interface_gw" ]; then
interface_gw=$(ubus call network.interface.${INTERFACE}_4 status 2>/dev/null | jsonfilter -q -l 1 -e '@.inactive.route[@.target="0.0.0.0"].nexthop' | tr -d "\n")
fi
2020-03-28 19:50:53 +00:00
#if [ "$interface_gw" != "" ] && [ "$interface_if" != "" ] && [ "$(ip route show $serverip | grep $interface_if)" = "" ]; then
if [ "$interface_gw" != "" ] && [ "$interface_if" != "" ]; then
2020-05-29 20:01:29 +00:00
if [ "$multipath_config_route" = "master" ]; then
weight=10
else
weight=1
fi
if [ "$multipath_config_route" = "backup" ]; then
2020-06-10 13:53:52 +00:00
if [ -z "$routesintfbackup" ]; then
routesintfbackup="nexthop via $interface_gw dev $interface_if weight $weight"
else
routesintfbackup="$routesintfbackup nexthop via $interface_gw dev $interface_if weight $weight"
fi
2020-05-29 20:01:29 +00:00
else
2020-08-19 13:40:38 +00:00
nbintf=$((nbintf+1))
2020-06-10 13:53:52 +00:00
if [ -z "$routesintf" ]; then
routesintf="nexthop via $interface_gw dev $interface_if weight $weight"
else
routesintf="$routesintf nexthop via $interface_gw dev $interface_if weight $weight"
fi
2020-05-29 20:01:29 +00:00
fi
2019-07-24 17:58:58 +00:00
fi
fi
}
2020-03-27 09:23:56 +00:00
set_route_balancing() {
2020-05-14 19:14:42 +00:00
local multipath_config_route interface_gw interface_if
2020-03-27 09:23:56 +00:00
INTERFACE=$1
2020-05-14 19:14:42 +00:00
multipath_config_route=$(uci -q get openmptcprouter.$INTERFACE.multipath)
[ -z "$multipath_config_route" ] && multipath_config_route=$(uci -q get network.$INTERFACE.multipath || echo "off")
2020-03-27 09:23:56 +00:00
interface_if=$(ifstatus "$INTERFACE" 2>/dev/null | jsonfilter -q -e '@["l3_device"]')
[ -z "$interface_if" ] && interface_if=$(ifstatus "${INTERFACE}_4" 2>/dev/null | jsonfilter -q -e '@["l3_device"]')
[ -z "$interface_if" ] && interface_if=$(uci -q get network.$INTERFACE.ifname)
2020-09-02 08:07:24 +00:00
interface_up=$(ifstatus "$INTERFACE" 2>/dev/null | jsonfilter -q -e '@["up"]')
2020-03-27 09:23:56 +00:00
interface_current_config=$(uci -q get openmptcprouter.$INTERFACE.state || echo "up")
2020-09-02 08:07:24 +00:00
if [ "$multipath_config_route" != "off" ] && [ "$interface_current_config" = "up" ] && [ "$interface_up" = "true" ]; then
2020-03-27 09:23:56 +00:00
interface_gw="$(uci -q get network.$INTERFACE.gateway)"
if [ -z "$interface_gw" ]; then
interface_gw=$(ubus call network.interface.$INTERFACE status 2>/dev/null | jsonfilter -q -l 1 -e '@.inactive.route[@.target="0.0.0.0"].nexthop' | tr -d "\n")
fi
if [ -z "$interface_gw" ]; then
interface_gw=$(ubus call network.interface.$INTERFACE status 2>/dev/null | jsonfilter -q -l 1 -e '@.route[@.target="0.0.0.0"].nexthop' | tr -d "\n")
fi
if [ -z "$interface_gw" ]; then
interface_gw=$(ubus call network.interface.${INTERFACE}_4 status 2>/dev/null | jsonfilter -q -l 1 -e '@.inactive.route[@.target="0.0.0.0"].nexthop' | tr -d "\n")
fi
if [ "$interface_gw" != "" ] && [ "$interface_if" != "" ]; then
2020-06-02 15:19:40 +00:00
nbintf=$((nbintf+1))
2020-05-29 20:01:29 +00:00
if [ "$(uci -q get network.$INTERFACE.weight)" != "" ]; then
weight=$(uci -q get network.$INTERFACE.weight)
elif [ "$(uci -q get openmtpcprouter.$INTERFACE.weight)" != "" ]; then
weight=$(uci -q get openmtpcprouter.$INTERFACE.weight)
elif [ "$multipath_config_route" = "master" ]; then
weight=2
else
weight=1
fi
if [ "$multipath_config_route" = "backup" ]; then
routesbalancingbackup="$routesbalancingbackup nexthop via $interface_gw dev $interface_if weight $weight"
else
routesbalancing="$routesbalancing nexthop via $interface_gw dev $interface_if weight $weight"
fi
2020-03-27 09:23:56 +00:00
fi
fi
}
2019-07-24 17:58:58 +00:00
set_server_all_routes() {
local server=$1
2020-05-14 19:14:42 +00:00
local serverip multipath_config_route
2019-07-24 17:58:58 +00:00
config_get serverip $server ip
2020-09-04 20:05:58 +00:00
[ -n "$serverip" ] && serverip="$(resolveip -4 -t 5 $serverip | head -n 1 | tr -d '\n')"
2020-05-11 08:34:16 +00:00
config_get disabled $server disabled
[ "$disabled" = "1" ] && return
2019-07-24 17:58:58 +00:00
interface_if=$(uci -q get network.$OMR_TRACKER_INTERFACE.ifname)
[ -z "$interface_if" ] && interface_if=$(ifstatus "$OMR_TRACKER_INTERFACE" 2>/dev/null | jsonfilter -q -e '@["l3_device"]')
[ -z "$interface_if" ] && interface_if=$(ifstatus "${OMR_TRACKER_INTERFACE}_4" 2>/dev/null | jsonfilter -q -e '@["l3_device"]')
2020-09-02 08:07:24 +00:00
interface_up=$(ifstatus "$OMR_TRACKER_INTERFACE" 2>/dev/null | jsonfilter -q -e '@["up"]')
2020-05-14 19:14:42 +00:00
multipath_config_route=$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.multipath || echo "off")
2020-09-02 08:07:24 +00:00
if [ "$serverip" != "" ] && [ "$OMR_TRACKER_DEVICE_GATEWAY" != "" ] && [ "$multipath_config_route" != "off" ] && [ "$interface_up" = "true" ]; then
2019-07-24 17:58:58 +00:00
routesintf=""
2020-05-29 20:01:29 +00:00
routesintfbackup=""
nbintf=0
2019-07-24 17:58:58 +00:00
config_load network
config_foreach set_routes_intf interface
2020-06-02 15:19:40 +00:00
[ -n "$routesintf" ] && ([ "$nbintf" -gt "1" ] && [ "$(ip r show $serverip | tr -d '\t' | tr -d '\n')" != "$serverip $routesintf " ]) || ([ "$nbintf" = "1" ] && [ "$(ip r show $serverip | grep $OMR_TRACKER_DEVICE)" = "" ]) && {
2020-08-19 13:40:38 +00:00
while [ "$(ip r show $serverip | grep -v nexthop | sed 's/ //g' | tr -d '\n')" != "$serverip" ] && [ "$(ip r show $serverip | grep -v nexthop | sed 's/ //g' | tr -d '\n')" != "" ]; do
2020-07-03 17:10:22 +00:00
ip r del $serverip
done
2020-05-20 08:06:51 +00:00
_log "Set server $server ($serverip) default route $serverip $routesintf"
2019-07-24 17:58:58 +00:00
ip route replace $serverip scope global $routesintf
}
2020-06-02 15:19:40 +00:00
[ -n "$routesintfbackup" ] && ([ "$nbintf" -gt "1" ] && [ "$(ip r show $serverip | tr -d '\t' | tr -d '\n')" != "$serverip $routesintfbackup " ]) || ([ "$nbintf" = "1" ] && [ "$(ip r show $serverip | grep $OMR_TRACKER_DEVICE)" = "" ]) && {
2020-05-29 20:01:29 +00:00
_log "Set server $server ($serverip) default route $serverip $routesintf"
ip route replace $serverip scope global metric 999 $routesintf
}
2019-07-24 17:58:58 +00:00
fi
}
2018-12-21 14:38:45 +00:00
set_server_route() {
local server=$1
2020-05-14 19:14:42 +00:00
local serverip multipath_config_route
2018-12-21 14:38:45 +00:00
config_get serverip $server ip
2020-09-04 20:05:58 +00:00
[ -n "$serverip" ] && serverip="$(resolveip -4 -t 5 $serverip | head -n 1 | tr -d '\n')"
2020-05-11 08:34:16 +00:00
config_get disabled $server disabled
[ "$disabled" = "1" ] && return
2018-07-24 12:26:04 +00:00
local metric=$2
2018-12-21 14:38:45 +00:00
[ -z "$metric" ] && metric=$(uci -q get network.$OMR_TRACKER_INTERFACE.metric)
2020-05-14 19:14:42 +00:00
multipath_config_route=$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.multipath)
[ "$multipath_config_route" ] && multipath_config_route=$(uci -q get network.$OMR_TRACKER_INTERFACE.multipath || echo "off")
2018-12-27 16:48:45 +00:00
interface_if=$(uci -q get network.$OMR_TRACKER_INTERFACE.ifname)
[ -z "$interface_if" ] && interface_if=$(ifstatus "$OMR_TRACKER_INTERFACE" 2>/dev/null | jsonfilter -q -e '@["l3_device"]')
[ -z "$interface_if" ] && interface_if=$(ifstatus "${OMR_TRACKER_INTERFACE}_4" 2>/dev/null | jsonfilter -q -e '@["l3_device"]')
2020-09-02 08:07:24 +00:00
interface_up=$(ifstatus "$OMR_TRACKER_INTERFACE" 2>/dev/null | jsonfilter -q -e '@["up"]')
2019-11-13 18:22:08 +00:00
#multipath_current_config=$(multipath $interface_if | grep "deactivated")
2019-11-17 07:55:15 +00:00
interface_current_config=$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.state || echo "up")
2019-11-13 18:22:08 +00:00
#if [ "$serverip" != "" ] && [ "$OMR_TRACKER_DEVICE_GATEWAY" != "" ] && [ "$(ip route show dev $OMR_TRACKER_DEVICE metric $metric | grep $serverip | grep $OMR_TRACKER_DEVICE_GATEWAY)" = "" ] && [ "$multipath_config_route" != "off" ] && [ "$multipath_current_config" = "" ]; then
2020-09-02 08:07:24 +00:00
if [ "$serverip" != "" ] && [ "$OMR_TRACKER_DEVICE_GATEWAY" != "" ] && [ "$(ip route show dev $OMR_TRACKER_DEVICE metric $metric | grep $serverip | grep $OMR_TRACKER_DEVICE_GATEWAY)" = "" ] && [ "$multipath_config_route" != "off" ] && [ "$interface_current_config" = "up" ] && [ "$interface_up" = "true" ]; then
2018-12-21 14:38:45 +00:00
_log "Set server $server ($serverip) route via $OMR_TRACKER_DEVICE_GATEWAY metric $metric"
2020-02-29 20:02:23 +00:00
ip route replace $serverip via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE metric $metric
2020-02-29 22:23:29 +00:00
fi
if [ "$serverip" != "" ] && [ "$OMR_TRACKER_DEVICE_GATEWAY" != "" ] && [ "$(ip route show dev $OMR_TRACKER_DEVICE table $metric | grep $serverip | grep $OMR_TRACKER_DEVICE_GATEWAY)" = "" ] && [ "$multipath_config_route" != "off" ] && [ "$interface_current_config" = "up" ]; then
2020-02-28 18:51:17 +00:00
ip route replace $serverip via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE table $metric
2018-12-21 14:38:45 +00:00
fi
if [ "$OMR_TRACKER_DEVICE_GATEWAY" != "" ]; then
2018-12-23 13:13:11 +00:00
ip route replace default via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE metric $metric
2018-03-19 15:19:24 +00:00
fi
}
2018-12-27 16:48:45 +00:00
del_server_route() {
local server=$1
local serverip
config_get serverip $server ip
2020-09-04 20:05:58 +00:00
[ -n "$serverip" ] && serverip="$(resolveip -4 -t 5 $serverip | head -n 1 | tr -d '\n')"
2020-02-28 18:51:17 +00:00
[ -n "$serverip" ] && _log "Delete default route via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE"
2018-12-28 16:34:00 +00:00
local metric
metric=$(uci -q get network.$OMR_TRACKER_INTERFACE.metric)
ip route del $serverip dev $OMR_TRACKER_DEVICE metric $metric >/dev/null 2>&1
ip route del $serverip dev $OMR_TRACKER_DEVICE >/dev/null 2>&1
2020-02-24 12:33:59 +00:00
if [ -n "$OMR_TRACKER_DEVICE_GATEWAY" ]; then
ip route del default via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE >/dev/null 2>&1
else
ip route del default dev $OMR_TRACKER_DEVICE >/dev/null 2>&1
fi
2018-12-27 16:48:45 +00:00
}
2019-08-09 15:20:12 +00:00
disable_pihole() {
local server=$1
2020-07-20 08:23:30 +00:00
if [ "$(uci -q get openmptcprouter.${server}.pihole)" = "0" ] && [ -n "$(uci -q get dhcp.@dnsmasq[0].server | grep '#53' | grep '10.2')" ]; then
2019-09-05 06:29:49 +00:00
_log "Disable Pi-Hole..."
2020-07-20 08:23:30 +00:00
uci -q del_list dhcp.@dnsmasq[0].server="$(uci -q get dhcp.@dnsmasq[0].server | tr ' ' '\n' | grep '#53' | grep '10.2')"
2019-08-09 15:20:12 +00:00
uci -q batch <<-EOF >/dev/null
2019-09-06 20:02:30 +00:00
add_list dhcp.@dnsmasq[0].server='127.0.0.1#5353'
2019-08-09 15:20:12 +00:00
commit dhcp
EOF
2019-08-23 18:59:11 +00:00
/etc/init.d/dnsmasq restart
2019-08-09 15:20:12 +00:00
fi
}
enable_pihole() {
local server=$1
2019-11-13 18:22:08 +00:00
nbserver=$((nbserver+1))
2020-07-10 13:41:01 +00:00
if [ "$(uci -q get openmptcprouter.${server}.pihole)" = "1" ] && [ "$(uci -q get dhcp.@dnsmasq[0].server | grep '127.0.0.1#5353')" != "" ]; then
2019-11-13 18:22:08 +00:00
piholeenabled=$((piholeenabled+1))
2019-08-09 15:20:12 +00:00
fi
}
2018-12-17 16:00:48 +00:00
dns_flush() {
unbound-control flush-negative >/dev/null 2>&1
unbound-control flush-bogus >/dev/null 2>&1
}
2020-03-03 09:49:48 +00:00
#if [ -n "$RANDOM" ]; then
# sleep `expr $RANDOM % 10`
#else
# sleep `awk 'BEGIN{srand();print int(rand()*9)}'`
#fi
2018-01-23 14:35:00 +00:00
# Get the current multipath status
multipath_status="off"
2018-03-22 14:51:32 +00:00
if [ -d "/sys/class/net/$OMR_TRACKER_DEVICE" ]; then
case "$(multipath "$OMR_TRACKER_DEVICE")" in
*default*) multipath_status="on" ;;
*backup*) multipath_status="backup" ;;
*handover*) multipath_status="handover" ;;
esac
fi
2018-01-23 14:35:00 +00:00
2018-12-28 12:17:39 +00:00
default_gw=$(ip route show default | grep -v "metric" | awk '/default/ {print $3}')
2018-03-06 07:20:59 +00:00
#current_interface_gw=$(uci -q get "network.$OMR_TRACKER_INTERFACE.gateway")
2018-01-23 14:35:00 +00:00
2020-09-02 08:07:24 +00:00
interface_up=$(ifstatus "$OMR_TRACKER_INTERFACE" 2>/dev/null | jsonfilter -q -e '@["up"]')
2018-01-23 14:35:00 +00:00
# An interface in error will never be used in MPTCP
2020-09-02 08:07:24 +00:00
if [ "$OMR_TRACKER_STATUS" = "ERROR" ] || [ "$interface_up" != "true" ]; then
2020-04-24 14:00:25 +00:00
if [ "$(uci -q get network.$OMR_TRACKER_INTERFACE.proto)" = "modemmanager" ]; then
2020-04-24 14:44:51 +00:00
_log "No answer from $OMR_TRACKER_INTERFACE ($OMR_TRACKER_DEVICE), restart interface"
_log "Set $OMR_TRACKER_INTERFACE down"
ifdown $OMR_TRACKER_INTERFACE
sleep 5
_log "Set $OMR_TRACKER_INTERFACE up"
ifup $OMR_TRACKER_INTERFACE
sleep 10
2020-04-24 14:00:25 +00:00
fi
2018-08-21 15:44:49 +00:00
if [ "$OMR_TRACKER_PREV_STATUS" = "$OMR_TRACKER_STATUS" ]; then
exit 0
fi
2018-10-09 14:23:22 +00:00
[ "$multipath_status" = "off" ] || {
if [ "$OMR_TRACKER_STATUS_MSG" = "" ]; then
2020-05-14 19:14:42 +00:00
_log "$OMR_TRACKER_INTERFACE ($OMR_TRACKER_DEVICE) switched off"
2018-10-09 14:23:22 +00:00
else
2020-05-14 19:14:42 +00:00
_log "$OMR_TRACKER_INTERFACE ($OMR_TRACKER_DEVICE) switched off because $OMR_TRACKER_STATUS_MSG"
2018-10-09 14:23:22 +00:00
fi
2018-11-16 14:01:41 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.state='down'
2019-11-13 18:22:08 +00:00
#if [ "$(sysctl -n net.mptcp.mptcp_enabled | tr -d '\n')" = "1" ]; then
# multipath "$OMR_TRACKER_DEVICE" off > /dev/null 2>&1
#fi
2018-10-09 14:23:22 +00:00
if [ -n "$OMR_TRACKER_DEVICE_IP" ]; then
glorytun-udp path $OMR_TRACKER_DEVICE_IP dev tun0 down > /dev/null 2>&1
fi
2020-05-20 08:06:51 +00:00
if [ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.vpn)" = "1" ]; then
VPN_BASE_INTF="$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.baseintf)"
VPN_BASE_INTF_IP=$(ubus call network.interface.$VPN_BASE_INTF status | jsonfilter -e '@["ipv4-address"][0].address' | tr -d "\n")
uci -q batch <<-EOF >/dev/null
set openvpn.$VPN_BASE_INTF.local=$VPN_BASE_INTF_IP
commit openvpn
EOF
/etc/init.d/openvpn restart $VPN_BASE_INTF
fi
2018-12-27 16:48:45 +00:00
config_load openmptcprouter
config_foreach del_server_route server
2020-07-10 13:41:01 +00:00
#if [ "$(uci -q get openmptcprouter.settings.master)" = "balancing" ] && [ "$(uci -q get openmptcprouter.settings.vpn)" != "mlvpn" ]; then
2020-05-29 20:01:29 +00:00
if [ "$(uci -q get openmptcprouter.settings.master)" = "balancing" ]; then
config_foreach set_server_all_routes server
fi
2018-10-09 14:23:22 +00:00
}
2020-05-05 08:48:55 +00:00
if ([ "$default_gw" = "$OMR_TRACKER_DEVICE_GATEWAY" ] || [ "$default_gw" = "" ]) && [ "$(uci -q get openmptcprouter.settings.defaultgw)" != "0" ]; then
2018-01-23 14:35:00 +00:00
config_load network
2018-03-19 15:19:24 +00:00
config_foreach set_route interface $OMR_TRACKER_INTERFACE
2020-08-19 13:40:38 +00:00
elif [ "$(uci -q get network.$OMR_TRACKER_INTERFACE.multipath)" = "master" ]; then
config_load network
config_foreach set_route interface $OMR_TRACKER_INTERFACE "no"
2018-03-19 15:19:24 +00:00
fi
2019-01-27 07:39:51 +00:00
mail_alert="$(uci -q get omr-tracker.$OMR_TRACKER_INTERFACE.mail_alert)"
[ -z "$mail_alert" ] && mail_alert="$(uci -q get omr-tracker.defaults.mail_alert)"
[ "$mail_alert" = "1" ] && {
2019-07-16 19:57:43 +00:00
OMR_SYSNAME="$(uci -q get system.@system[0].hostname)"
2018-11-20 13:25:38 +00:00
if [ "$OMR_TRACKER_STATUS_MSG" = "" ]; then
2019-07-16 19:57:43 +00:00
echo -e "Subject: $OMR_SYSNAME: $OMR_TRACKER_INTERFACE ($OMR_TRACKER_DEVICE) is down\n\nConnection failure of $OMR_TRACKER_INTERFACE ($OMR_TRACKER_DEVICE) detected." | sendmail $(uci -q get mail.default.to)
2018-11-20 13:25:38 +00:00
else
2019-07-16 19:57:43 +00:00
echo -e "Subject: $OMR_SYSNAME: $OMR_TRACKER_INTERFACE ($OMR_TRACKER_DEVICE) is down\n\nConnection failure of $OMR_TRACKER_INTERFACE ($OMR_TRACKER_DEVICE) detected. The reason is \"$OMR_TRACKER_STATUS_MSG\"." | sendmail $(uci -q get mail.default.to)
2018-11-20 13:25:38 +00:00
fi
}
2020-05-26 05:57:36 +00:00
script_alert_down="$(uci -q get omr-tracker.$OMR_TRACKER_INTERFACE.script_alert_down)"
[ -n "$script_alert_down" ] && eval $script_alert_down
2018-11-20 13:25:38 +00:00
2018-06-06 15:55:33 +00:00
if [ "$OMR_TRACKER_INTERFACE" = "glorytun" ] || [ "$OMR_TRACKER_INTERFACE" = "omrvpn" ]; then
2018-08-14 14:24:29 +00:00
if [ "$OMR_TRACKER_STATUS_MSG" = "" ]; then
_log "$OMR_TRACKER_INTERFACE down"
else
_log "$OMR_TRACKER_INTERFACE down because $OMR_TRACKER_STATUS_MSG"
fi
2020-05-05 08:48:55 +00:00
if [ "$(uci -q get openmptcprouter.settings.defaultgw)" != "0" ]; then
config_load network
config_foreach set_route interface $OMR_TRACKER_INTERFACE
fi
2020-09-07 09:05:18 +00:00
if [ "$(uci -q get shadowsocks-libev.sss0.disabled)" != "1" ] && [ "$(uci -q get openmptcprouter.omr.shadowsocks)" = "up" ] && [ "$(uci -q get shadowsocks-libev.ss_rules.redir_udp)" = "" ] && [ "$(uci -q get shadowsocks-libev.hi2.mode)" = "tcp_and_udp" ] && [ "$(uci -q get shadowsocks-libev.sss0.obfs)" != "1" ]; then
2018-07-27 21:28:38 +00:00
_log "Tunnel down use ShadowSocks for UDP"
2018-05-29 16:03:50 +00:00
uci -q set shadowsocks-libev.ss_rules.redir_udp='hi2'
2018-10-13 19:40:15 +00:00
if /etc/init.d/shadowsocks-libev rules_exist ; then
2018-10-09 14:23:22 +00:00
/etc/init.d/shadowsocks-libev rules_down
/etc/init.d/shadowsocks-libev rules_up
fi
2018-05-29 16:03:50 +00:00
fi
2020-03-27 09:23:56 +00:00
if [ "$(uci -q get dsvpn.vpn.enable)" = "1" ]; then
/etc/init.d/dsvpn restart
fi
2019-08-09 15:20:12 +00:00
config_load openmptcprouter
config_foreach disable_pihole server
2020-07-10 13:41:01 +00:00
#if [ "$(uci -q get openmptcprouter.settings.master)" != "balancing" ] || [ "$(uci -q get openmptcprouter.settings.vpn)" = "mlvpn" ]; then
2020-03-27 09:23:56 +00:00
if [ "$(uci -q get openmptcprouter.settings.master)" != "balancing" ]; then
2020-03-03 09:49:48 +00:00
config_foreach set_server_default_route server
fi
2018-05-29 16:03:50 +00:00
fi
2018-12-17 16:00:48 +00:00
dns_flush
2019-01-17 19:44:29 +00:00
uci -q delete openmptcprouter.$OMR_TRACKER_INTERFACE.lc
uci -q commit openmptcprouter
2019-01-11 17:10:22 +00:00
#ubus call network reload
2020-03-03 09:49:48 +00:00
# Set a little sleep after an interface error
if [ -n "$RANDOM" ]; then
sleep `expr $RANDOM % 10`
else
sleep `awk 'BEGIN{srand();print int(rand()*9)}'`
fi
2018-03-19 15:19:24 +00:00
exit 0
fi
2018-06-06 15:55:33 +00:00
if [ "$OMR_TRACKER_INTERFACE" = "glorytun" ] || [ "$OMR_TRACKER_INTERFACE" = "omrvpn" ]; then
2020-03-05 16:30:04 +00:00
if ([ "$default_gw" != "$OMR_TRACKER_DEVICE_GATEWAY" ] || [ "$default_gw" = "" ]) && [ "$OMR_TRACKER_DEVICE_GATEWAY" != "" ]; then
2018-05-14 19:03:51 +00:00
_log "Tunnel up : Replace default route by $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE"
2018-12-23 13:13:11 +00:00
ip route replace default scope global nexthop via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE
2020-03-13 21:34:02 +00:00
/etc/init.d/openmptcprouter-vps restart >/dev/null 2>&1
2018-08-21 15:44:49 +00:00
fi
2018-09-19 13:28:50 +00:00
if [ "$(uci -q get shadowsocks-libev.sss0.disabled)" != "1" ] && [ "$(uci -q get shadowsocks-libev.ss_rules.redir_udp)" = "hi2" ]; then
2018-09-21 21:07:47 +00:00
_log "Tunnel up disable use of ShadowSocks for UDP"
2018-08-21 15:44:49 +00:00
uci -q delete shadowsocks-libev.ss_rules.redir_udp
2018-10-13 19:40:15 +00:00
if /etc/init.d/shadowsocks-libev rules_exist ; then
2019-05-25 19:38:52 +00:00
/etc/init.d/shadowsocks-libev rules_down >/dev/null 2>&1
/etc/init.d/shadowsocks-libev rules_up >/dev/null 2>&1
2018-10-09 14:23:22 +00:00
fi
2018-01-23 14:35:00 +00:00
fi
2018-09-05 21:06:57 +00:00
# Set VPN MTU
2019-01-27 19:33:21 +00:00
if [ -n "$OMR_TRACKER_LATENCY" ] && ([ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.lc)" = "" ] || [ $(($(date +"%s") - $(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.lc))) -gt 3600 ]); then
2018-09-05 21:06:57 +00:00
local serverip=$(uci -q get shadowsocks-libev.sss0.server)
2020-09-04 20:05:58 +00:00
[ -n "$serverip" ] && serverip="$(resolveip -4 -t 5 $serverip | head -n 1 | tr -d '\n')"
2020-04-08 12:19:59 +00:00
if [ "$serverip" = "192.168.1.3" ] || [ "$serverip" = "127.0.0.1" ]; then
serverip=""
fi
2019-12-03 19:20:40 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE="interface"
2018-09-05 21:06:57 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.latency="$OMR_TRACKER_LATENCY"
if [ -n "$(uci -q get network.$OMR_TRACKER_INTERFACE.mtu)" ]; then
mtu=$(uci -q get network.$OMR_TRACKER_INTERFACE.mtu)
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.mtu=$mtu
ip link set dev $OMR_TRACKER_DEVICE mtu $mtu > /dev/null 2>&1
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.lc=$(date +"%s")
2018-10-20 17:20:51 +00:00
elif [ -z "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.mtu)" ]; then
2020-02-19 17:10:42 +00:00
[ -n "$serverip" ] && [ "$serverip" != "127.0.0.1" ] && {
local mtu=$(omr-mtu $OMR_TRACKER_DEVICE_IP $serverip)
#local mtu=$(omr-mtu $OMR_TRACKER_DEVICE_IP 8.8.8.8)
[ -n "$mtu" ] && {
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.mtu=$mtu
ip link set dev $OMR_TRACKER_DEVICE mtu $mtu > /dev/null 2>&1
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.lc=$(date +"%s")
}
} || {
local mtu=$(omr-mtu $OMR_TRACKER_DEVICE_IP 8.8.8.8)
[ -n "$mtu" ] && {
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.mtu=$mtu
ip link set dev $OMR_TRACKER_DEVICE mtu $mtu > /dev/null 2>&1
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.lc=$(date +"%s")
}
2018-09-05 21:06:57 +00:00
}
else
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.lc=$(date +"%s")
fi
uci -q commit openmptcprouter
fi
2019-11-13 18:22:08 +00:00
nbserver=0
piholeenabled=0
2019-08-09 15:20:12 +00:00
config_load openmptcprouter
config_foreach enable_pihole server
2020-03-03 09:49:48 +00:00
#config_foreach delete_server_default_route server
2019-11-13 18:22:08 +00:00
[ "$nbserver" = "$piholeenabled" ] && /etc/init.d/openmptcprouter-vps set_pihole
2018-12-23 13:13:11 +00:00
#ubus call network reload
2018-01-23 14:35:00 +00:00
exit 0
fi
2018-11-05 18:14:23 +00:00
if [ "$OMR_TRACKER_PREV_STATUS" != "" ] && [ "$OMR_TRACKER_PREV_STATUS" != "$OMR_TRACKER_STATUS" ]; then
2020-05-14 19:14:42 +00:00
_log "$OMR_TRACKER_INTERFACE ($OMR_TRACKER_DEVICE) switched up"
2018-11-05 18:14:23 +00:00
mail_alert="$(uci -q get omr-tracker.$OMR_TRACKER_INTERFACE.mail_alert)"
[ -z "$mail_alert" ] && mail_alert="$(uci -q get omr-tracker.defaults.mail_alert)"
2019-07-16 19:57:43 +00:00
[ "$mail_alert" = "1" ] && {
OMR_SYSNAME="$(uci -q get system.@system[0].hostname)"
echo -e "Subject: $OMR_SYSNAME: $OMR_TRACKER_INTERFACE ($OMR_TRACKER_DEVICE) is up\n\nDetected that connection $OMR_TRACKER_INTERFACE ($OMR_TRACKER_DEVICE) is up again." | sendmail $(uci -q get mail.default.to)
}
2020-05-26 05:57:36 +00:00
script_alert_up="$(uci -q get omr-tracker.$OMR_TRACKER_INTERFACE.script_alert_up)"
[ -n "$script_alert_up" ] && eval $script_alert_up
2020-05-29 20:01:29 +00:00
fi
if [ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.state)" != "up" ]; then
2018-11-16 14:01:41 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.state='up'
uci -q commit openmptcprouter
2018-12-17 16:00:48 +00:00
dns_flush
2018-11-05 18:14:23 +00:00
fi
2020-05-14 19:14:42 +00:00
multipath_config=$(uci -q get "openmtpcprouter.$OMR_TRACKER_INTERFACE.multipath")
[ -z "$multipath_config" ] && multipath_config=$(uci -q get "network.$OMR_TRACKER_INTERFACE.multipath" || echo "off")
2018-02-15 08:49:47 +00:00
if [ "$multipath_config" = "master" ]; then
2020-07-10 13:41:01 +00:00
#if ([ "$default_gw" != "$OMR_TRACKER_DEVICE_GATEWAY" ] || [ "$default_gw" = "" ]) && [ "$OMR_TRACKER_DEVICE_GATEWAY" != "" ] && ([ "$(uci -q get openmptcprouter.settings.master)" != "balancing" ] || [ "$(uci -q get openmptcprouter.settings.vpn)" = "mlvpn" ]); then
2020-04-08 13:57:55 +00:00
if ([ "$default_gw" != "$OMR_TRACKER_DEVICE_GATEWAY" ] || [ "$default_gw" = "" ]) && [ "$OMR_TRACKER_DEVICE_GATEWAY" != "" ] && [ "$(uci -q get openmptcprouter.settings.master)" != "balancing" ]; then
2018-06-08 12:52:58 +00:00
omrvpn_intf=$(uci -q get "network.omrvpn.ifname" || echo "tun")
2020-05-05 08:48:55 +00:00
if [ -n "$omrvpn_intf" ] && [ "$(ip route show default | awk '/default/ {print $5}' | grep $omrvpn_intf)" = "" ] && [ "$(uci -q get openmptcprouter.settings.defaultgw)" != "0" ]; then
2018-08-03 13:00:10 +00:00
_log "Master up : Replace default route by $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE"
2018-12-23 13:13:11 +00:00
ip route replace default scope global nexthop via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE
2020-05-01 09:09:04 +00:00
fi
config_load openmptcprouter
2020-07-03 17:10:22 +00:00
#if [ "$(uci -q get openmptcprouter.settings.master)" = "balancing" ]; then
# config_foreach set_server_all_routes server
if [ "$(uci -q get openmptcprouter.settings.master)" != "failover" ]; then
2020-05-01 09:09:04 +00:00
config_foreach set_server_default_route server
2018-03-19 15:19:24 +00:00
fi
2018-12-23 13:13:11 +00:00
ip route replace default via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE table 991337
2018-02-15 08:49:47 +00:00
fi
2020-07-10 13:41:01 +00:00
#if [ "$(uci -q get openmptcprouter.settings.master)" = "balancing" ] && [ "$(ip route show default | grep weight)" = "" ] && [ "$(uci -q get openmptcprouter.settings.defaultgw)" != "0" ] && [ "$(uci -q get openmptcprouter.settings.vpn)" != "mlvpn" ]; then
2020-05-05 08:48:55 +00:00
if [ "$(uci -q get openmptcprouter.settings.master)" = "balancing" ] && [ "$(ip route show default | grep weight)" = "" ] && [ "$(uci -q get openmptcprouter.settings.defaultgw)" != "0" ]; then
2020-03-27 09:23:56 +00:00
omrvpn_intf=$(uci -q get "network.omrvpn.ifname" || echo "tun")
if [ -n "$omrvpn_intf" ] && [ "$(ip route show default | awk '/default/ {print $5}' | grep $omrvpn_intf)" = "" ]; then
ip route replace default via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE table 991337
routesbalancing=""
2020-05-29 20:01:29 +00:00
routesbalancingbackup=""
2020-06-02 15:19:40 +00:00
nbintf=0
2020-03-27 09:23:56 +00:00
config_load network
config_foreach set_route_balancing interface
2020-06-02 15:19:40 +00:00
[ -n "$routesbalancing" ] && {
([ "$nbintf" -gt "1" ] && [ "$(ip r show default metric 0 | tr -d '\t' | tr -d '\n')" != "default via $routesbalancing " ]) || ([ "$nbintf" = "1" ] && [ "$(ip r show default metric 0 | grep $OMR_TRACKER_DEVICE)" = "" ]) && {
_log "Set ip route replace default scope global $routesbalancing"
ip route replace default scope global $routesbalancing
}
2020-03-27 09:23:56 +00:00
}
2020-06-02 15:19:40 +00:00
[ -n "$routesbalancingbackup" ] && {
([ "$nbintf" -gt "1" ] && [ "$(ip r show default metric 999 | tr -d '\t' | tr -d '\n')" != "default via $routesbalancingbackup " ]) || ([ "$nbintf" = "1" ] && [ "$(ip r show default metric 999 | grep $OMR_TRACKER_DEVICE)" = "" ]) && {
_log "Set backup ip route replace default scope global $routesbalancingbackup"
ip route replace default scope global metric 999 $routesbalancingbackup
}
2020-05-29 20:01:29 +00:00
}
2020-03-27 09:23:56 +00:00
fi
fi
if [ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.lc)" = "" ] || [ $(($(date +"%s") + $((10 + RANDOM % 31)) - $(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.lc))) -gt 3600 ] || [ "$(uci -q show openmptcprouter | grep get_config=\'1\')" != "" ] || [ "$(uci -q show openmptcprouter | grep admin_error=\'1\')" != "" ]; then
/etc/init.d/openmptcprouter-vps restart >/dev/null 2>&1
fi
2018-02-15 08:49:47 +00:00
multipath_config="on"
2018-12-11 14:01:03 +00:00
fi
2020-03-27 09:23:56 +00:00
2018-12-11 14:01:03 +00:00
if [ -n "$OMR_TRACKER_DEVICE_IP" ] && [ -n "$OMR_TRACKER_DEVICE_GATEWAY" ]; then
2018-12-21 14:38:45 +00:00
config_load openmptcprouter
2020-07-10 13:41:01 +00:00
#if [ "$(uci -q get openmptcprouter.settings.master)" = "balancing" ] && [ "$(uci -q get openmptcprouter.settings.vpn)" != "mlvpn" ]; then
2020-03-27 09:23:56 +00:00
if [ "$(uci -q get openmptcprouter.settings.master)" = "balancing" ]; then
2019-08-30 11:10:07 +00:00
config_foreach set_server_all_routes server
2020-03-03 09:49:48 +00:00
elif [ "$(uci -q get openmptcprouter.settings.master)" != "failover" ]; then
2019-08-30 11:10:07 +00:00
config_foreach set_server_route server
fi
2018-02-15 08:49:47 +00:00
fi
2018-06-27 18:41:57 +00:00
2019-02-22 18:50:21 +00:00
[ "$multipath_config" = "on" ] && {
2019-03-22 19:27:36 +00:00
download="$(uci -q get network.$OMR_TRACKER_INTERFACE.downloadspeed)"
[ -z "$download" ] && download="$(uci -q get sqm.$OMR_TRACKER_INTERFACE.download)"
upload="$(uci -q get network.$OMR_TRACKER_INTERFACE.uploadspeed)"
[ -z "$upload" ] && upload="$(uci -q get sqm.$OMR_TRACKER_INTERFACE.upload)"
2020-03-16 08:39:16 +00:00
if [ "$(pgrep glorytun-udp)" != "" ] && ([ "$(glorytun-udp path | grep $OMR_TRACKER_DEVICE_IP)" = "" ] || [ "$(glorytun-udp path $OMR_TRACKER_DEVICE_IP | awk '{print $13}')" = "0" ] || [ "$(glorytun-udp path $OMR_TRACKER_DEVICE_IP | awk '{print $16}')" = "0" ]); then
2020-02-26 14:38:20 +00:00
if [ "$download" != "0" ] && [ "$download" != "" ] && [ "$upload" != "0" ] && [ "$upload" != "" ]; then
2020-02-28 08:03:00 +00:00
if [ "$(uci -q get glorytun.vpn.rateauto)" = "1" ]; then
glorytun-udp path $OMR_TRACKER_DEVICE_IP dev tun0 up rate auto tx ${upload}000 rx ${download}000 > /dev/null 2>&1
else
glorytun-udp path $OMR_TRACKER_DEVICE_IP dev tun0 up rate tx ${upload}000 rx ${download}000 > /dev/null 2>&1
fi
2020-02-26 14:38:20 +00:00
else
2020-02-28 08:03:00 +00:00
if [ "$(uci -q get glorytun.vpn.rateauto)" = "1" ]; then
glorytun-udp path $OMR_TRACKER_DEVICE_IP dev tun0 up rate auto tx 125000000 rx 125000000 > /dev/null 2>&1
else
glorytun-udp path $OMR_TRACKER_DEVICE_IP dev tun0 up rate tx 125000000 rx 125000000 > /dev/null 2>&1
fi
2020-02-26 14:38:20 +00:00
fi
2019-02-22 18:50:21 +00:00
fi
}
2020-08-19 13:40:38 +00:00
[ "$multipath_config" = "backup" ] && [ "$(pgrep glorytun-udp)" != "" ] && glorytun-udp path $OMR_TRACKER_DEVICE_IP dev tun0 backup rate auto rx 125000000 tx 125000000 > /dev/null 2>&1
2018-08-23 12:52:09 +00:00
[ "$multipath_status" = "$multipath_config" ] || {
if [ "$(sysctl -n net.mptcp.mptcp_enabled | tr -d '\n')" = "1" ]; then
_log "Multipath $OMR_TRACKER_DEVICE switched to $multipath_config"
multipath "$OMR_TRACKER_DEVICE" "$multipath_config"
fi
}
2018-12-23 13:13:11 +00:00
#ubus call network reload
2018-08-23 12:52:09 +00:00
# Save wan settings for status page
2020-03-27 09:23:56 +00:00
if [ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.lc)" = "" ] || [ $(($(date +"%s") + $((30 + RANDOM % 31)) - $(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.lc))) -gt 3600 ] || [ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.state)" = "down" ]; then
2020-07-10 13:41:01 +00:00
[ "$(uci -q get openmptcprouter.settings.debug)" = "true" ] && _log "Get status and settings for $OMR_TRACKER_INTERFACE..."
2019-11-17 19:48:13 +00:00
if [ "$(uci -q get openmptcprouter.settings.external_check)" != "0" ] && [ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.vpn)" != "1" ]; then
2019-02-25 19:06:54 +00:00
local ipaddr="$(omr-ip-intf $OMR_TRACKER_DEVICE)"
2019-06-26 22:09:10 +00:00
else
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.lc=$(date +"%s")
2020-02-25 13:20:30 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.state="up"
2019-02-25 19:06:54 +00:00
fi
2018-08-23 12:52:09 +00:00
[ -n "$ipaddr" ] && {
2018-10-05 13:26:43 +00:00
# Check if we can get a IPv6 address, if yes enable RA else disable
2020-05-20 08:06:51 +00:00
#local check_ipv6_website="$(uci -q get openmptcprouter.settings.check_ipv6_website)"
#[ -z "$check_ipv6_website" ] && check_ipv6_website="http://ipv6.openmptcprouter.com/"
#local ip6addr="$(curl -s -6 -m 2 $check_ipv6_website)"
#[ -z "$ip6addr" ] && {
# local ip6addr="$(curl -s -6 -m 2 http://ifconfig.co/)"
#}
#if [ "$(uci -q get openmptcprouter.settings.ipv6_disable)" = "0" ]; then
# if [ -n "$ip6addr" ] && [ "$(uci -q get dhcp.lan.ra_default)" != 1 ]; then
# _log "Enable IPv6 RA"
# uci -q set dhcp.lan.ra=server
# uci -q set dhcp.lan.ra_default=1
# uci -q set dhcp.lan.dhcpv6=server
# /etc/init.d/odhcpd start > /dev/null 2>&1
# /etc/init.d/odhcpd enable > /dev/null 2>&1
# elif [ -z "$ip6addr" ] && [ "$(uci -q set dhcp.lan.ra_default)" = 1 ]; then
# _log "Disable IPv6 RA"
# uci -q delete dhcp.lan.ra
# uci -q delete dhcp.lan.dhcpv6
# /etc/init.d/odhcpd start > /dev/null 2>&1
# /etc/init.d/odhcpd enable > /dev/null 2>&1
# fi
#fi
2019-02-25 19:06:54 +00:00
if [ "$(uci -q get openmptcprouter.settings.external_check)" != "0" ]; then
2019-08-05 14:57:21 +00:00
local asn="$(wget -4 -qO- -T 4 http://api.iptoasn.com/v1/as/ip/$ipaddr | jsonfilter -q -e '@.as_description')"
2019-02-25 19:06:54 +00:00
[ -z "$asn" ] && {
asn="$(whois $ipaddr 2>/dev/null | grep -m 1 -i 'netname' | awk '{print $2}')"
}
fi
2018-10-13 21:02:11 +00:00
[ -z "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE)" ] && {
2018-10-12 15:13:52 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE=interface
}
2018-10-31 11:38:56 +00:00
if [ "$(uci -q get openmptcprouter.latest_versions.lc)" = "" ] || [ $(($(date +"%s") - $(uci -q get openmptcprouter.latest_versions.lc))) -gt 3600 ]; then
2019-08-05 14:57:21 +00:00
local latestversions="$(wget -4 -qO- -T 3 http://www.openmptcprouter.com/version/version.json)"
2018-10-31 11:38:56 +00:00
[ -n "$latestversions" ] && {
uci -q set openmptcprouter.latest_versions=latest_versions
uci -q set openmptcprouter.latest_versions.omr=$(echo $latestversions | jsonfilter -q -e '@.omr')
uci -q set openmptcprouter.latest_versions.vps=$(echo $latestversions | jsonfilter -q -e '@.vps')
uci -q set openmptcprouter.latest_versions.lc=$(date +"%s")
}
fi
2018-08-23 12:52:09 +00:00
local serverip=$(uci -q get shadowsocks-libev.sss0.server)
2020-09-04 20:05:58 +00:00
[ -n "$serverip" ] && serverip="$(resolveip -4 -t 5 $serverip | head -n 1 | tr -d '\n')"
2020-08-19 13:40:38 +00:00
[ -n "$serverip" ] && [ "$serverip" != "127.0.0.1" ] && [ "$(pgrep tracebox)" = "" ] && [ "$(uci -q get openmptcprouter.settings.tracebox)" != "0" ] && {
2020-06-26 13:00:23 +00:00
omrtracebox="$(omr-tracebox-mptcp $serverip $OMR_TRACKER_DEVICE)"
[ -n "$omrtracebox" ] && uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.mptcp_status="$omrtracebox"
}
2019-01-27 13:56:55 +00:00
[ -n "$ipaddr" ] && uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.publicip="$ipaddr"
[ -n "$OMR_TRACKER_LATENCY" ] && uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.latency="$OMR_TRACKER_LATENCY"
2018-08-23 12:52:09 +00:00
[ -n "$asn" ] && {
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.asn="$asn"
}
2018-09-05 21:06:57 +00:00
if [ -n "$(uci -q get network.$OMR_TRACKER_INTERFACE.mtu)" ]; then
mtu=$(uci -q get network.$OMR_TRACKER_INTERFACE.mtu)
2019-01-27 13:56:55 +00:00
[ -n "$mtu" ] && {
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.mtu=$mtu
ip link set dev $OMR_TRACKER_DEVICE mtu $mtu > /dev/null 2>&1
}
2019-05-21 19:36:21 +00:00
else
2020-02-19 17:10:42 +00:00
[ -n "$serverip" ] && [ "$serverip" != "127.0.0.1" ] && {
local mtu=$(omr-mtu $OMR_TRACKER_DEVICE_IP $serverip)
[ -n "$mtu" ] && {
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.mtu=$mtu
ip link set dev $OMR_TRACKER_DEVICE mtu $mtu > /dev/null 2>&1
}
} || {
2019-11-03 18:23:48 +00:00
local mtu=$(omr-mtu $OMR_TRACKER_DEVICE_IP 8.8.8.8)
2018-09-19 13:28:50 +00:00
[ -n "$mtu" ] && {
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.mtu=$mtu
ip link set dev $OMR_TRACKER_DEVICE mtu $mtu > /dev/null 2>&1
}
2020-02-19 17:10:42 +00:00
}
2018-08-24 11:34:37 +00:00
fi
2020-02-21 10:28:09 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.state='up'
2019-05-21 19:36:21 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.lc=$(date +"%s")
2018-08-23 12:52:09 +00:00
}
2019-02-25 19:06:54 +00:00
if [ "$(uci -q get shadowsocks-libev.sss0.server)" != "" ] && [ "$(uci -q get openmptcprouter.settings.external_check)" = "0" ]; then
2020-08-19 13:40:38 +00:00
if ping -c 1 $(uci -q get shadowsocks-libev.sss0.server) 2>&1 >/dev/null; then
2019-02-25 19:06:54 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.lc=$(date +"%s")
fi
fi
2020-04-26 11:21:26 +00:00
proto="$(uci -q get network.$OMR_TRACKER_INTERFACE.proto)"
#if [ "$proto" = "qmi" ]; then
# intfdata="$(omr-qmi $OMR_TRACKER_DEVICE all | tr -d '\n')"
# uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.operator=$(echo $intfdata | awk -F";" '{print $2}')
# uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.number=$(echo $intfdata | awk -F";" '{print $3}')
# uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.state=$(echo $intfdata | awk -F";" '{print $4}')
#elif [ "$proto" = "modemmanager" ]; then
# intfdata="$(omr-modemmanager $OMR_TRACKER_DEVICE all)"
# uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.operator=$(echo $intfdata | awk -F";" '{print $2}')
# uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.number=$(echo $intfdata | awk -F";" '{print $3}')
# uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.state=$(echo $intfdata | awk -F";" '{print $4}')
#else
if [ "$proto" != "qmi" ] && [ "$proto" != "modemmanager" ]; then
2020-04-21 20:56:42 +00:00
if [ -n "$OMR_TRACKER_DEVICE_GATEWAY" ] && [ -n "$(curl -s -m 1 -X GET http://$OMR_TRACKER_DEVICE_GATEWAY/api/webserver/SesTokInfo)" ]; then
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.manufacturer='huawei'
else
uci -q delete openmptcprouter.$OMR_TRACKER_INTERFACE.manufacturer
fi
2020-02-21 10:28:09 +00:00
fi
2018-10-12 15:13:52 +00:00
if [ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.lc)" = "" ] || [ $(($(date +"%s") - $(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.lc))) -gt 3600 ]; then
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.lc=$(( $(date +"%s") - 3400 ))
2020-07-10 13:41:01 +00:00
[ "$(uci -q get openmptcprouter.settings.debug)" = "true" ] && _log "Get status and settings for $OMR_TRACKER_INTERFACE... Failed"
2019-04-27 13:20:19 +00:00
uci -q commit openmptcprouter
2018-10-12 15:13:52 +00:00
else
2020-07-10 13:41:01 +00:00
[ "$(uci -q get openmptcprouter.settings.debug)" = "true" ] && _log "Get status and settings for $OMR_TRACKER_INTERFACE... Done"
2019-04-27 13:20:19 +00:00
uci -q commit openmptcprouter
2020-03-27 09:23:56 +00:00
#/etc/init.d/openmptcprouter-vps restart >/dev/null 2>&1
2018-10-12 15:13:52 +00:00
fi
2018-12-17 16:00:48 +00:00
dns_flush
2018-07-17 20:41:43 +00:00
fi
2018-10-31 11:38:56 +00:00
[ -n "$OMR_TRACKER_LATENCY" ] && {
2019-01-27 19:33:21 +00:00
[ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.latency)" != "" ] && uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.latency_previous="$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.latency)"
2018-10-31 11:38:56 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.latency="$OMR_TRACKER_LATENCY"
2019-07-29 08:36:22 +00:00
#[ -z "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.latency_max)" ] && uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.latency_max="$OMR_TRACKER_LATENCY"
#[ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.latency_max)" -lt "$OMR_TRACKER_LATENCY" ] && uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.latency_max="$OMR_TRACKER_LATENCY"
2020-05-14 19:14:42 +00:00
if [ "$multipath_config" = "on" ] && [ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.multipath)" != "master" ] && ([ "$(uci -q get openmptcprouter.settings.master)" = "dynamic" ] || (([ "$(uci -q get openmptcprouter.settings.master)" = "change" ] || [ "$(uci -q get openmptcprouter.settings.master)" = "" ]) && [ "$(uci -q get openmptcprouter.settings.master_lcintf | grep $OMR_TRACKER_INTERFACE)" = "" ])); then
2020-05-25 12:02:59 +00:00
masterintf="$(uci -q show openmptcprouter | grep -m 1 multipath=\'master\' | cut -d'.' -f2)"
[ -z "$masterintf" ] && masterintf="$(uci -q show network | grep -m 1 multipath=\'master\' | cut -d'.' -f2)"
2018-12-04 15:55:11 +00:00
masterlatency="$(uci -q get openmptcprouter.$masterintf.latency | tr -d '\n')"
2019-01-19 16:17:42 +00:00
if [ -z "$masterlatency" ] || [ "$(uci -q get openmptcprouter.$masterintf.state)" = "down" ]; then
masterlatency=1000
fi
if [ -n "$masterintf" ] && ([ "$masterlatency" != "" ] || [ "$(uci -q get openmptcprouter.$masterintf.state)" = "down" ]); then
2019-11-07 21:39:44 +00:00
if (([ "$(uci -q get openmptcprouter.settings.master)" = "change" ] || [ "$(uci -q get openmptcprouter.settings.master)" = "" ]) && [ "$OMR_TRACKER_LATENCY" -lt $(awk "BEGIN {printf \"%i\",${masterlatency}/1.5}") ]) || ([ "$(uci -q get openmptcprouter.settings.master)" = "dynamic" ] && [ "$OMR_TRACKER_LATENCY" -lt "$((masterlatency/2))" ] && [ "$(uci -q get openmptcprouter.$OMR_TRACKER_INTERFACE.latency_previous)" -lt "$((masterlatency/2))" ]); then
2018-12-25 08:49:36 +00:00
uci -q set network.$masterintf.multipath='on'
2019-08-27 20:24:45 +00:00
uci -q set openmptcprouter.$masterintf.multipath='on'
2018-12-25 08:49:36 +00:00
uci -q set network.$OMR_TRACKER_INTERFACE.multipath='master'
2019-08-27 20:24:45 +00:00
uci -q set openmptcprouter.$OMR_TRACKER_INTERFACE.multipath='master'
2019-06-11 17:12:47 +00:00
if [ "$(uci -q get openmptcprouter.settings.master_lcintf | grep $OMR_TRACKER_INTERFACE)" = "" ]; then
uci -q add_list openmptcprouter.settings.master_lcintf="$OMR_TRACKER_INTERFACE"
fi
2019-11-13 18:22:08 +00:00
if [ "$(uci -q get openmptcprouter.settings.master)" = "" ]; then
uci -q set openmptcprouter.settings.master="change"
fi
2019-01-19 20:21:16 +00:00
if [ "$(uci -q get openmptcprouter.settings.master)" != "dynamic" ]; then
uci -q commit network
2019-08-27 20:24:45 +00:00
uci -q commit openmptcprouter
2019-01-19 20:21:16 +00:00
fi
2018-12-25 08:49:36 +00:00
_log "Change master interface from $masterintf ($masterlatency ms) to $OMR_TRACKER_INTERFACE ($OMR_TRACKER_LATENCY ms)"
fi
2018-10-31 11:38:56 +00:00
fi
fi
}
2018-11-27 14:18:43 +00:00
2018-12-15 20:33:58 +00:00
# If a service is down, force restart it
2020-03-27 09:23:56 +00:00
if [ "$(pgrep ss-redir)" = "" ] && [ "$(pgrep ss-local)" = "" ] && [ "$(uci -q get shadowsocks-libev.sss0.disabled)" != "1" ] && [ "$(uci -q get shadowsocks-libev.sss0.server)" != "" ] && [ "$(uci -q get shadowsocks-libev.sss0.server)" != "192.18.1.3" ] && [ "$(uci -q get shadowsocks-libev.sss0.key)" != "" ]; then
2018-12-15 20:33:58 +00:00
_log "Can't find Shadowsocks, restart it..."
/etc/init.d/shadowsocks-libev restart
2018-12-17 16:00:48 +00:00
sleep 5
2018-12-15 20:33:58 +00:00
fi
2020-09-02 08:07:24 +00:00
if [ "$(pgrep glorytun)" = "" ] && [ "$(uci -q get glorytun.vpn.enable)" = "1" ] && [ -f /etc/init.d/glorytun ]; then
2018-12-15 20:33:58 +00:00
_log "Can't find Glorytun, restart it..."
/etc/init.d/glorytun restart
/etc/init.d/glorytun-udp restart
2018-12-17 16:00:48 +00:00
sleep 5
2018-12-15 20:33:58 +00:00
fi
2020-05-05 08:48:55 +00:00
if [ "$(pgrep openvpn)" = "" ] && [ -f /etc/init.d/openvpn ]; then
openvpn_enable=0
openvpn_enabled() {
[ "$(uci -q get openvpn.$1.enabled)" = "1" ] && openvpn_enable=1
}
config_load openvpn
config_foreach openvpn_enabled openvpn
if [ "$openvpn_enable" = "1" ]; then
_log "Can't find OpenVPN, restart it"
/etc/init.d/openvpn restart
sleep 5
fi
2018-12-15 20:33:58 +00:00
fi
2020-05-05 08:48:55 +00:00
2019-07-16 19:57:43 +00:00
if [ "$(pgrep mlvpn)" = "" ] && [ "$(uci -q get mlvpn.general.enable)" = "1" ] && [ -f /etc/init.d/mlvpn ]; then
2018-12-15 20:33:58 +00:00
_log "Can't find MLVPN, restart it..."
/etc/init.d/mlvpn restart
2018-12-17 16:00:48 +00:00
sleep 5
2018-12-15 20:33:58 +00:00
fi
2019-09-08 17:13:04 +00:00
if [ "$(pgrep dsvpn)" = "" ] && [ "$(uci -q get dsvpn.vpn.enable)" = "1" ] && [ -f /etc/init.d/dsvpn ]; then
_log "Can't find DSVPN, restart it..."
/etc/init.d/dsvpn restart
sleep 5
fi
2020-09-04 20:05:58 +00:00
if [ "$(pgrep v2ray)" = "" ] && [ "$(uci -q get v2ray.main.enabled)" = "1" ] && [ -f /etc/init.d/v2ray ]; then
_log "Can't find V2Ray, restart it..."
/etc/init.d/v2ray restart
sleep 5
fi
2018-12-15 20:33:58 +00:00
2019-01-06 18:11:38 +00:00
set_get_config() {
local server=$1
2019-01-27 13:56:55 +00:00
[ -n "$server" ] && uci -q set openmptcprouter.${server}.get_config=1
2019-01-06 18:11:38 +00:00
}
2020-03-27 09:23:56 +00:00
if [ "$(uci -q get shadowsocks-libev.sss0.disabled)" != "1" ] && [ "$(uci -q get shadowsocks-libev.sss0.key)" = "" ] && [ "$(uci -q get shadowsocks-libev.sss0.server)" != "" ] && [ "$(uci -q get shadowsocks-libev.sss0.server)" != "192.18.1.3" ]; then
2019-01-06 18:11:38 +00:00
config_load openmptcprouter
config_foreach set_get_config server
uci -q commit openmptcprouter
fi
if [ "$(uci -q get glorytun.vpn.enable)" = "1" ] && [ "$(uci -q get glorytun.vpn.key)" = "" ]; then
config_load openmptcprouter
config_foreach set_get_config server
uci -q commit openmptcprouter
fi
2020-09-04 20:05:58 +00:00
if [ "$(uci -q get v2ray.main.enabled)" = "1" ] && [ "$(uci -q get v2ray.omrout.s_vless_user_id)" = "" ]; then
config_load openmptcprouter
config_foreach set_get_config server
uci -q commit openmptcprouter
fi
2020-08-19 13:40:38 +00:00
if [ -n "$(logread | tail -n 2 | grep 'Ring expansion failed')" ]; then
_log "Workaround Ring expansion failed problem"
echo 1 > /sys/bus/pci/devices/0000:00:00.0/remove
sleep 2
echo 1 > /sys/bus/pci/rescan
fi
2020-03-27 09:23:56 +00:00
#if [ "$(uci -q show openmptcprouter | grep get_config=\'1\')" != "" ] || [ "$(uci -q show openmptcprouter | grep admin_error=\'1\')" != "" ]; then
# /etc/init.d/openmptcprouter-vps restart >/dev/null 2>&1
# sleep 5
#fi