2018-05-09 09:15:43 +00:00
#!/bin/sh
# vim: set noexpandtab tabstop=4 shiftwidth=4 softtabstop=4 :
name=$0
basename="$(basename $0)"
2022-09-25 17:02:32 +00:00
if [ -f /usr/sbin/iptables-legacy ]; then
IPTABLES="/usr/sbin/iptables-legacy"
2022-09-30 06:57:51 +00:00
IPTABLESSAVE="/usr/sbin/iptables-legacy-save"
2022-09-25 17:02:32 +00:00
else
IPTABLES="/usr/sbin/iptables"
2022-09-30 06:57:51 +00:00
IPTABLESSAVE="/usr/sbin/iptables-save"
2022-09-25 17:02:32 +00:00
fi
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"
2021-01-28 19:45:45 +00:00
public_ipv4="$(curl -s -4 -m 3 $check_ipv4_website)"
uci -q set openmptcprouter.omr.detected_public_ipv4="${public_ipv4}"
[ -n "$public_ipv4" ] && {
uci -q set upnpd.config.external_ip="${public_ipv4}"
uci -q commit upnpd
}
2020-03-31 17:13:10 +00:00
if [ "$(uci -q get openmptcprouter.omr.shadowsocks)" != "down" ]; then
uci -q set openmptcprouter.omr.detected_ss_ipv4="$(curl -s -4 --socks5 "${proxy}" --max-time 3 $check_ipv4_website)"
2020-11-07 17:57:47 +00:00
else
uci -q del openmptcprouter.omr.detected_ss_ipv4
2020-03-31 17:13:10 +00:00
fi
2019-03-06 17:24:22 +00:00
if [ "$(uci -q get openmptcprouter.settings.disable_ipv6)" != "1" ]; then
2020-07-29 08:56:25 +00:00
uci -q set openmptcprouter.omr.detected_public_ipv6="$(curl -s -6 -m 3 $check_ipv6_website)"
2020-11-07 17:57:47 +00:00
else
uci -q del openmptcprouter.omr.detected_public_ipv6
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}
2020-11-05 09:21:14 +00:00
wait_test=${OMR_TRACKER_WAIT_TEST:-0}
2021-01-25 08:32:23 +00:00
server=${OMR_TRACKER_SERVER:-sss0}
2023-09-29 13:03:16 +00:00
type=${OMR_TRACKER_SS_TYPE:-libev}
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=""
2021-01-25 09:08:54 +00:00
[ "${last}" -ge "${retry}" ] || [ "$(uci -q get openmptcprouter.omr.ss_${server})" = "" ] && {
2021-02-05 18:48:15 +00:00
_log "Shadowsocks ${server} is up (can contact via http ${host})"
2023-08-24 12:36:42 +00:00
OMR_TRACKER_STATUS_MSG="Shadowsocks ${server} is up (can contact via http ${host})"
2021-01-25 09:08:54 +00:00
uci -q set openmptcprouter.omr.ss_${server}="up"
2018-12-17 16:01:03 +00:00
uci -q commit openmptcprouter.omr
2023-08-24 12:36:42 +00:00
mail_alert="$(uci -q get omr-tracker.proxy.mail_alert)"
#[ -z "$mail_alert" ] && mail_alert="$(uci -q get omr-tracker.defaults.mail_alert)"
[ "$mail_alert" = "1" ] && [ -n "$(uci -q get mail.default.to)" ] && {
OMR_SYSNAME="$(uci -q get system.@system[0].hostname)"
if [ "$(uci -q get omr-tracker.defaults.mail_up_subject)" != "" ] && [ "$(uci -q get omr-tracker.defaults.mail_up_message)" != "" ]; then
mail_subject="$(uci -q get omr-tracker.defaults.mail_up_subject)"
mail_subject=`echo $mail_subject | sed -e "s/%SYSNAME%/$OMR_SYSNAME/g" -e "s/%INTERFACE%/Shadowsocks Proxy/g" -e "s/%DEVICE%/Shadowsocks Proxy/g" -e "s/%MESSAGE%/$OMR_TRACKER_STATUS_MSG/g"`
mail_message="$(uci -q get omr-tracker.defaults.mail_up_message)"
mail_message=`echo $mail_message | sed -e "s/%SYSNAME%/$OMR_SYSNAME/g" -e "s/%INTERFACE%/Shadowsocks Proxy/g" -e "s/%DEVICE%/Shadowsocks Proxy/g" -e "s/%MESSAGE%/$OMR_TRACKER_STATUS_MSG/g"`
echo -e "Subject: ${mail_subject}\n\n${mail_message}" | sendmail $(uci -q get mail.default.to)
else
echo -e "Subject: $OMR_SYSNAME: Shadowsocks Proxy is UP." | sendmail $(uci -q get mail.default.to)
fi
}
script_alert_up="$(uci -q get omr-tracker.proxy.script_alert_up)"
[ -n "$script_alert_up" ] && eval $script_alert_up
2018-10-13 19:40:15 +00:00
}
2023-09-29 13:03:16 +00:00
if [ -z "$($IPTABLESSAVE 2>/dev/null | grep :ssr)" ]; then
if [ "$type" = "libev" ] && [ "$(uci -q get shadowsocks-libev.ss_rules.disabled)" != "1" ]; then
_log "Reload Shadowsocks rules"
/etc/init.d/shadowsocks-libev rules_up 2> /dev/null
_get_ip
elif [ "$type" = "rust" ] && [ "$(uci -q get shadowsocks-rust.ss_rules.disabled)" != "1" ]; then
_log "Reload Shadowsocks Rust rules"
/etc/init.d/shadowsocks-rust rules_up 2> /dev/null
_get_ip
fi
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}" ] && {
2022-09-25 17:02:32 +00:00
if [ -n "$($IPTABLES -w -t nat -L -n 2>/dev/null | grep ssr)" ]; then
2021-02-05 18:48:15 +00:00
_log "Shadowsocks ${server} is down (can't contact via http ${nocontact})"
2023-08-24 12:36:42 +00:00
OMR_TRACKER_STATUS_MSG="Shadowsocks ${server} is down (can't contact via http ${nocontact})"
2021-01-25 09:08:54 +00:00
uci -q set openmptcprouter.omr.ss_${server}="down"
2018-12-17 16:01:03 +00:00
uci -q commit openmptcprouter.omr
2023-09-29 13:03:16 +00:00
if [ "$(uci show openmptcprouter.omr | grep ss_ | grep up)" = "" ]; then
[ "$type" = "libev" ] && /etc/init.d/shadowsocks-libev rules_down 2> /dev/null
[ "$type" = "rust" ] && /etc/init.d/shadowsocks-rust rules_down 2> /dev/null
fi
2019-07-22 15:48:43 +00:00
_get_ip
server_ping=false
2023-09-29 13:03:16 +00:00
if [ "$type" = "libev" ]; then
serverip="$(uci -q get shadowsocks-libev.${server}.server)"
disabled="$(uci -q get shadowsocks-libev.${server}.disabled)"
elif [ "$type" = "rust" ]; then
serverip="$(uci -q get shadowsocks-rust.${server}.server)"
disabled="$(uci -q get shadowsocks-rust.${server}.disabled)"
fi
2021-01-25 08:32:23 +00:00
_ping_server $serverip
2019-07-22 15:48:43 +00:00
if [ "$server_ping" = false ]; then
2021-01-25 08:32:23 +00:00
_log "Server $server ($serverip) seems down, no answer to ping"
2023-08-24 12:36:42 +00:00
OMR_TRACKER_STATUS_MSG="${OMR_TRACKER_STATUS_MSG} - Server $server ($serverip) seems down, no answer to ping"
2019-07-22 15:48:43 +00:00
fi
2023-08-24 12:36:42 +00:00
mail_alert="$(uci -q get omr-tracker.proxy.mail_alert)"
#[ -z "$mail_alert" ] && mail_alert="$(uci -q get omr-tracker.defaults.mail_alert)"
[ "$mail_alert" = "1" ] && [ -n "$(uci -q get mail.default.to)" ] && {
OMR_SYSNAME="$(uci -q get system.@system[0].hostname)"
if [ "$(uci -q get omr-tracker.defaults.mail_down_subject)" != "" ] && [ "$(uci -q get omr-tracker.defaults.mail_down_message)" != "" ]; then
mail_subject="$(uci -q get omr-tracker.defaults.mail_down_subject)"
mail_subject=`echo $mail_subject | sed -e "s/%SYSNAME%/$OMR_SYSNAME/g" -e "s/%INTERFACE%/Shadowsocks Proxy/g" -e "s/%DEVICE%/Shadowsocks Proxy/g" -e "s/%MESSAGE%/$OMR_TRACKER_STATUS_MSG/g"`
mail_message="$(uci -q get omr-tracker.defaults.mail_down_message)"
mail_message=`echo $mail_message | sed -e "s/%SYSNAME%/$OMR_SYSNAME/g" -e "s/%INTERFACE%/Shadowsocks Proxy/g" -e "s/%DEVICE%/Shadowsocks Proxy/g" -e "s/%MESSAGE%/$OMR_TRACKER_STATUS_MSG/g"`
echo -e "Subject: ${mail_subject}\n\n${mail_message}" | sendmail $(uci -q get mail.default.to)
else
echo -e "Subject: $OMR_SYSNAME: Shadowsocks Proxy is down\n\nConnection failure of ShadowSocks proxy detected. The reason is \"$OMR_TRACKER_STATUS_MSG\"." | sendmail $(uci -q get mail.default.to)
fi
}
script_alert_down="$(uci -q get omr-tracker.proxy.script_alert_down)"
[ -n "$script_alert_down" ] && eval $script_alert_down
2023-09-29 13:03:16 +00:00
if [ "$disabled" != "1" ]; then
if [ "$type" = "libev" ] && [ "$(pgrep ss-redir)" = "" ] && [ "$(uci -q get shadowsocks-libev.${server}.key)" != "" ]; then
_log "Can't find shadowsocks, restart it..."
/etc/init.d/shadowsocks-libev restart
sleep 5
fi
2023-10-06 09:16:52 +00:00
if [ "$type" = "rust" ] && [ "$(pgrep sslocal)" = "" ] && [ "$(uci -q get shadowsocks-libev.${server}.key)" != "" ]; then
2023-09-29 13:03:16 +00:00
_log "Can't find shadowsocks rust, restart it..."
/etc/init.d/shadowsocks-rust restart
sleep 5
fi
2021-03-11 15:54:46 +00:00
fi
2020-11-05 09:21:14 +00:00
sleep $wait_test
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