2018-05-09 09:15:43 +00:00
|
|
|
#!/bin/sh
|
|
|
|
# vim: set noexpandtab tabstop=4 shiftwidth=4 softtabstop=4 :
|
|
|
|
|
|
|
|
name=$0
|
|
|
|
basename="$(basename $0)"
|
|
|
|
|
2019-09-16 16:08:31 +00:00
|
|
|
_log() {
|
2018-05-09 09:15:43 +00:00
|
|
|
logger -p daemon.info -t "${basename}" "$@"
|
|
|
|
}
|
|
|
|
|
2019-07-22 15:48:43 +00:00
|
|
|
_ping_server() {
|
2019-07-23 06:22:28 +00:00
|
|
|
local host=$1
|
2019-07-22 15:48:43 +00:00
|
|
|
ret=$(ping \
|
|
|
|
-w "$OMR_TRACKER_TIMEOUT" \
|
|
|
|
-c 1 \
|
|
|
|
-q \
|
|
|
|
"${host}"
|
|
|
|
) && echo "$ret" | grep -sq " 0% packet loss" && {
|
|
|
|
server_ping=true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
_get_ip() {
|
2018-12-17 16:01:03 +00:00
|
|
|
uci -q set openmptcprouter.omr=router
|
2019-03-09 08:03:34 +00:00
|
|
|
if [ "$(uci -q get openmptcprouter.settings.external_check)" != "0" ]; then
|
2019-07-29 08:36:22 +00:00
|
|
|
check_ipv4_website="$(uci -q get openmptcprouter.settings.check_ipv4_website)"
|
|
|
|
[ -z "$check_ipv4_website" ] && check_ipv4_website="http://ip.openmptcprouter.com"
|
|
|
|
check_ipv6_website="$(uci -q get openmptcprouter.settings.check_ipv6_website)"
|
2019-12-23 11:36:29 +00:00
|
|
|
[ -z "$check_ipv6_website" ] && check_ipv6_website="http://ipv6.openmptcprouter.com"
|
2019-07-29 08:36:22 +00:00
|
|
|
uci -q set openmptcprouter.omr.detected_public_ipv4="$(wget -4 -qO- -T 3 $check_ipv4_website)"
|
|
|
|
uci -q set openmptcprouter.omr.detected_ss_ipv4="$(curl -s -4 --socks5 "${proxy}" --max-time 3 $check_ipv4_website)"
|
2019-03-06 17:24:22 +00:00
|
|
|
if [ "$(uci -q get openmptcprouter.settings.disable_ipv6)" != "1" ]; then
|
2019-07-29 08:36:22 +00:00
|
|
|
uci -q set openmptcprouter.omr.detected_public_ipv6="$(wget -6 -qO- -T 3 $check_ipv6_website)"
|
2019-03-06 17:24:22 +00:00
|
|
|
# uci -q set openmptcprouter.omr.detected_ss_ipv6=$(curl -s -6 --socks5 ":::1111" --max-time 3 http://ip.openmptcprouter.com)
|
|
|
|
fi
|
2018-08-24 11:34:09 +00:00
|
|
|
fi
|
2019-06-25 16:05:00 +00:00
|
|
|
uci -q commit openmptcprouter
|
2018-08-24 11:34:09 +00:00
|
|
|
}
|
|
|
|
|
2018-05-14 11:41:44 +00:00
|
|
|
timeout=${OMR_TRACKER_TIMEOUT:-5}
|
2018-05-12 06:04:08 +00:00
|
|
|
interval=${OMR_TRACKER_INTERVAL:-10}
|
2018-05-13 19:24:27 +00:00
|
|
|
retry=${OMR_TRACKER_TRIES:-4}
|
2018-05-12 06:04:08 +00:00
|
|
|
proxy=${OMR_TRACKER_PROXY:-127.0.0.1:1111}
|
2018-11-12 08:38:04 +00:00
|
|
|
hosts=${OMR_TRACKER_HOSTS:-1.1.1.1 1.0.0.1}
|
2018-05-13 19:24:27 +00:00
|
|
|
|
|
|
|
nodns=0
|
2018-05-09 09:15:43 +00:00
|
|
|
|
|
|
|
last=0
|
2018-11-12 08:38:04 +00:00
|
|
|
nocontact=""
|
2018-12-17 16:01:03 +00:00
|
|
|
uci -q set openmptcprouter.omr=router
|
2019-06-25 16:05:00 +00:00
|
|
|
uci -q delete openmptcprouter.omr.shadowsocks=""
|
2019-07-23 15:44:41 +00:00
|
|
|
_get_ip
|
2018-08-24 11:34:09 +00:00
|
|
|
|
2018-05-09 09:15:43 +00:00
|
|
|
while true; do
|
2018-06-11 08:47:51 +00:00
|
|
|
host="${hosts%% *}"
|
|
|
|
[ "$host" = "$hosts" ] || {
|
|
|
|
hosts="${hosts#* } $host"
|
|
|
|
}
|
2019-02-16 16:10:03 +00:00
|
|
|
if [ "$(curl -s -I -w %{http_code} --socks5 ${proxy} --max-time ${timeout} $host -o /dev/null)" != "000" ]; then
|
2018-11-12 08:38:04 +00:00
|
|
|
nocontact=""
|
2018-12-17 16:01:03 +00:00
|
|
|
[ "${last}" -ge "${retry}" ] || [ "$(uci -q get openmptcprouter.omr.shadowsocks)" = "" ] && {
|
2020-01-07 17:05:00 +00:00
|
|
|
_log "Shadowsocks is up (can contact via http ${host})"
|
2018-12-14 12:19:58 +00:00
|
|
|
uci -q set openmptcprouter.omr.shadowsocks="up"
|
2018-12-17 16:01:03 +00:00
|
|
|
uci -q commit openmptcprouter.omr
|
2018-10-13 19:40:15 +00:00
|
|
|
}
|
2019-12-03 21:52:34 +00:00
|
|
|
if [ -z "$(iptables -t nat -L -n | grep ss_rules_forward)" ] && [ "$(uci -q get shadowsocks-libev.ss_rules.disabled)" != "1" ]; then
|
2019-09-16 16:08:31 +00:00
|
|
|
_log "Reload Shadowsocks rules"
|
2018-10-13 11:53:54 +00:00
|
|
|
/etc/init.d/shadowsocks-libev rules_up 2> /dev/null
|
2019-07-22 15:48:43 +00:00
|
|
|
_get_ip
|
2018-10-13 19:40:15 +00:00
|
|
|
fi
|
2019-07-23 15:44:41 +00:00
|
|
|
[ "$(uci -q get openmptcprouter.omr.detected_public_ipv4)" = "" ] || ([ "$(uci -q get openmptcprouter.settings.disable_ipv6)" != "1" ] && [ "$(uci -q get openmptcprouter.omr.detected_public_ipv6)" = "" ]) && _get_ip
|
2018-06-06 11:25:32 +00:00
|
|
|
last=0
|
|
|
|
else
|
|
|
|
last=$((last + 1 ))
|
2018-11-12 08:38:04 +00:00
|
|
|
[ -z "$nocontact" ] && nocontact="$host" || nocontact="$nocontact, $host"
|
2018-10-26 14:48:21 +00:00
|
|
|
[ "${last}" -ge "${retry}" ] && {
|
2019-12-03 21:52:34 +00:00
|
|
|
if [ -n "$(iptables -t nat -L -n | grep ss_rules_forward)" ]; then
|
2020-01-07 17:05:00 +00:00
|
|
|
_log "Shadowsocks is down (can't contact via http ${nocontact})"
|
2018-12-14 12:19:58 +00:00
|
|
|
uci -q set openmptcprouter.omr.shadowsocks="down"
|
2018-12-17 16:01:03 +00:00
|
|
|
uci -q commit openmptcprouter.omr
|
2018-10-13 19:40:15 +00:00
|
|
|
/etc/init.d/shadowsocks-libev rules_down 2> /dev/null
|
2019-07-22 15:48:43 +00:00
|
|
|
_get_ip
|
|
|
|
server_ping=false
|
2019-07-23 06:22:28 +00:00
|
|
|
server="$(uci -q get shadowsocks-libev.sss0.server)"
|
|
|
|
_ping_server $server
|
2019-07-22 15:48:43 +00:00
|
|
|
if [ "$server_ping" = false ]; then
|
2019-09-16 16:08:31 +00:00
|
|
|
_log "Server ($server) seems down, no answer to ping"
|
2019-07-22 15:48:43 +00:00
|
|
|
fi
|
2018-10-13 19:40:15 +00:00
|
|
|
fi
|
2018-06-06 11:25:32 +00:00
|
|
|
}
|
|
|
|
fi
|
2018-05-09 09:15:43 +00:00
|
|
|
sleep "${interval}"
|
|
|
|
done
|