1
0
Fork 0
mirror of https://github.com/Ysurac/openmptcprouter-feeds.git synced 2025-02-15 03:51:51 +00:00
openmptcprouter-feeds/omr-tracker/files/etc/init.d/omr-tracker

206 lines
6.6 KiB
Text
Raw Normal View History

2018-01-23 14:38:27 +00:00
#!/bin/sh /etc/rc.common
# shellcheck disable=SC2039
# vim: set noexpandtab tabstop=4 shiftwidth=4 softtabstop=4 :
2018-11-27 14:20:49 +00:00
# Copyright (C) 2018 Ycarus (Yannick Chabanois) <ycarus@zugaina.org>
# Released under GPL 3. See LICENSE for the full terms.
2018-01-23 14:38:27 +00:00
# shellcheck disable=SC2034
{
START=90
STOP=10
USE_PROCD=1
}
_validate_section() {
local tmp_hosts=$hosts tmp_timeout=$timeout tmp_tries=$tries
2018-08-28 20:59:40 +00:00
local tmp_interval=$interval tmp_interval_tries=$interval_tries tmp_options=$options tmp_type=$type tmp_enabled=$enabled
2018-01-23 14:38:27 +00:00
uci_validate_section omr-tracker "$1" "$2" \
'hosts:list(host)' \
'timeout:uinteger' \
'tries:uinteger' \
2018-01-23 14:38:27 +00:00
'interval:uinteger' \
2018-08-28 20:59:40 +00:00
'interval_tries:uinteger' \
'type:string:undef' \
2018-03-30 09:12:14 +00:00
'enabled:bool:1' \
2018-01-23 14:38:27 +00:00
'options:string'
[ -z "$hosts" ] && hosts=$tmp_hosts
[ -z "$timeout" ] && timeout=$tmp_timeout
[ -z "$tries" ] && tries=$tmp_tries
[ -z "$interval" ] && interval=$tmp_interval
2018-08-28 20:59:40 +00:00
[ -z "$interval_tries" ] && interval_tries=$tmp_interval_tries
2018-01-23 14:38:27 +00:00
[ -z "$options" ] && options=$tmp_options
[ "$type" = "undef" ] && type=${tmp_type:-ping}
2018-03-30 09:12:14 +00:00
[ -z "$enabled" ] && enabled=$tmp_enabled
2018-01-23 14:38:27 +00:00
}
_launch_tracker() {
case "$1" in
loopback|lan*|if0*) return;;
2018-01-23 14:38:27 +00:00
esac
2018-08-28 20:59:40 +00:00
local hosts timeout tries interval interval_tries options type enabled
2018-01-23 14:38:27 +00:00
_validate_section "defaults" "defaults"
_validate_section "interface" "$1"
local ifname ip4table
2019-03-28 20:35:05 +00:00
ifname=$(ifstatus "$1" | jsonfilter -q -e '@["l3_device"]')
[ -z "$ifname" ] && ifname=$(ifstatus "$1_4" | jsonfilter -q -e '@["l3_device"]')
[ -z "$ifname" ] && config_get ifname "$1" ifname
2018-01-23 14:38:27 +00:00
config_get multipath "$1" multipath
config_get ifenabled "$1" auto
2018-02-20 21:19:31 +00:00
config_get gateway "$1" gateway
2018-01-23 14:38:27 +00:00
2018-06-06 11:25:32 +00:00
[ -z "$ifname" ] || [ -z "$multipath" ] || [ "$multipath" = "off" ] && [ "$1" != "glorytun" ] && [ "$1" != "omrvpn" ] && return
[ "${ifenabled}" = "0" ] && return
2018-05-25 20:00:24 +00:00
[ "${enabled}" = "0" ] && return
[ -z "${hosts}" ] && [ "$type" != "none" ] && return
2018-08-28 20:59:40 +00:00
[ -z "${interval_tries}" ] && interval_tries=1
2018-01-23 14:38:27 +00:00
procd_open_instance
# shellcheck disable=SC2086
procd_set_param command /bin/omr-tracker "$1" $options
procd_append_param env "OMR_TRACKER_HOSTS=$hosts"
procd_append_param env "OMR_TRACKER_TIMEOUT=$timeout"
procd_append_param env "OMR_TRACKER_TRIES=$tries"
procd_append_param env "OMR_TRACKER_INTERVAL=$interval"
2018-08-28 20:59:40 +00:00
procd_append_param env "OMR_TRACKER_INTERVAL_TRIES=$interval_tries"
2018-01-23 14:38:27 +00:00
procd_append_param env "OMR_TRACKER_TABLE=$ip4table"
procd_append_param env "OMR_TRACKER_DEVICE=$ifname"
2018-02-20 21:19:31 +00:00
procd_append_param env "OMR_TRACKER_DEVICE_GATEWAY=$gateway"
2018-03-01 15:03:05 +00:00
procd_append_param env "OMR_TRACKER_TYPE=$type"
2018-03-27 08:35:03 +00:00
procd_set_param limits nofile="51200 51200"
2018-01-23 14:38:27 +00:00
procd_set_param respawn 0 10 0
procd_set_param stderr 1
procd_close_instance
}
2020-05-20 08:03:51 +00:00
_launch_server_tracker() {
local hosts timeout tries interval interval_tries options type enabled
_validate_section "defaults" "defaults"
2020-05-20 08:03:51 +00:00
_validate_section "server" "server"
[ "${enabled}" = "0" ] && return
[ -z "${interval_tries}" ] && interval_tries=1
procd_open_instance
# shellcheck disable=SC2086
procd_set_param command /bin/omr-tracker-server "$1" $options
procd_append_param env "OMR_TRACKER_TIMEOUT=$timeout"
procd_append_param env "OMR_TRACKER_TRIES=$tries"
procd_append_param env "OMR_TRACKER_INTERVAL=$interval"
procd_append_param env "OMR_TRACKER_INTERVAL_TRIES=$interval_tries"
procd_set_param limits nofile="51200 51200"
procd_set_param respawn 0 10 0
procd_set_param stderr 1
procd_close_instance
}
2018-05-09 09:15:43 +00:00
_initialize_shadowsocks_tracker() {
local redir_tcp server tracker_server
config_get redir_tcp ss_rules redir_tcp
config_get tracker_server "tracker" server
2020-02-25 13:19:56 +00:00
if [ "$redir_tcp" != "all" ]; then
config_get server $redir_tcp server
2020-02-25 21:06:37 +00:00
elif [ "$tracker_server" != "" ]; then
2020-02-25 13:19:56 +00:00
server=$tracker_server
else
server="sss0"
fi
config_get ss_disabled $server disabled 0
2019-05-23 17:52:39 +00:00
[ -z "$tracker_server" ] && {
logger -t "omr-tracker" "Create ShadowSock tracker ss_local..."
uci -q batch <<-EOF >/dev/null
set shadowsocks-libev.tracker=ss_local
set shadowsocks-libev.tracker.server=$server
set shadowsocks-libev.tracker.local_address="127.0.0.1"
set shadowsocks-libev.tracker.local_port=1111
set shadowsocks-libev.tracker.mode=tcp_and_udp
set shadowsocks-libev.tracker.timeout=600
set shadowsocks-libev.tracker.fast_open=1
set shadowsocks-libev.tracker.syslog=0
set shadowsocks-libev.tracker.reuse_port=1
set shadowsocks-libev.tracker.mptcp=1
set shadowsocks-libev.tracker.verbose=0
commit shadowsocks-libev
EOF
/etc/init.d/shadowsocks-libev restart
}
[ -n "$tracker_server" ] && [ "$server" = "$tracker_server" ] || {
logger -t "omr-tracker" "Set ShadowSock tracker to current server ($tracker_server -> $server)..."
uci -q batch <<-EOF >/dev/null
set shadowsocks-libev.tracker.server=$server
commit shadowsocks-libev
EOF
2018-05-09 09:15:43 +00:00
/etc/init.d/shadowsocks-libev restart
}
}
_launch_shadowsocks_tracker() {
2020-03-27 09:22:43 +00:00
local hosts timeout tries interval local_port enabled server
2018-05-09 09:15:43 +00:00
[ "$1" = "tracker" ] || return
2018-05-09 09:53:45 +00:00
_validate_section "shadowsocks" "shadowsocks"
2018-05-09 09:15:43 +00:00
config_get local_port "$1" local_port
local disabled
config_get disabled "$1" disabled 0
2020-03-27 09:22:43 +00:00
config_get server "$1" server
2018-05-09 09:15:43 +00:00
[ "$enabled" = "0" ] || [ "$disabled" = "1" ] || [ -z "$hosts" ] && return
2020-03-27 09:22:43 +00:00
[ -z "$server" ] || [ "$(uci -q get shadowsocks-libev.$server.server)" = "192.168.1.3" ] || [ "$(uci -q get shadowsocks-libev.$server.server)" = "" ] && return
2018-05-09 09:15:43 +00:00
procd_open_instance
# shellcheck disable=SC2086
procd_set_param command /bin/omr-tracker-ss "$1"
procd_append_param env "OMR_TRACKER_HOSTS=$hosts"
procd_append_param env "OMR_TRACKER_TIMEOUT=$timeout"
procd_append_param env "OMR_TRACKER_TRIES=$tries"
procd_append_param env "OMR_TRACKER_INTERVAL=$interval"
procd_append_param env "OMR_TRACKER_PROXY=127.0.0.1:$local_port"
procd_set_param limits nofile="51200 51200"
procd_set_param respawn 0 10 0
procd_set_param stderr 1
procd_close_instance
}
2020-05-20 08:03:51 +00:00
_multi_server() {
config_get backup $1 backup
[ "$backup" = "1" ] && multiserver=true
}
2018-01-23 14:38:27 +00:00
start_service() {
local ss_disabled
2019-05-23 17:52:39 +00:00
logger -t "omr-tracker" "Launching..."
2018-05-09 09:15:43 +00:00
config_load shadowsocks-libev
_initialize_shadowsocks_tracker
2018-01-23 14:38:27 +00:00
config_load network
config_foreach _launch_tracker interface
2018-05-09 09:15:43 +00:00
if [ "$ss_disabled" != "1" ]; then
config_load shadowsocks-libev
config_foreach _launch_shadowsocks_tracker ss_local
2020-08-20 14:07:29 +00:00
#elif [ "$(uci -q get shadowsocks-libev.sss0.disabled)" != "1" ]; then
# /etc/init.d/shadowsocks-libev rules_down
fi
2020-05-20 08:03:51 +00:00
multiserver=false
config_load openmptcprouter
config_foreach _multi_server server
[ "$multiserver" = true ] && _launch_server_tracker
2019-05-23 17:52:39 +00:00
logger -t "omr-tracker" "Launched"
2018-01-23 14:38:27 +00:00
}
service_triggers() {
procd_add_reload_trigger omr-tracker network shadowsocks-libev
2018-01-23 14:38:27 +00:00
}
reload_service() {
stop
start
}