shadowsocks_install/shadowsocks-debian
2015-03-10 11:29:30 +08:00

104 lines
2.0 KiB
Bash

#!/bin/sh
### BEGIN INIT INFO
# Provides: shadowsocks
# Required-Start: $network $local_fs $remote_fs
# Required-Stop: $network $local_fs $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Fast tunnel proxy that helps you bypass firewalls
# Description: A secure socks5 proxy, designed to protect your Internet traffic.
### END INIT INFO
# Author: Teddysun <i@teddysun.com>
NAME=shadowsocks
BIN=/usr/bin/ssserver
CONFIG_FILE=/etc/shadowsocks.json
PID_DIR=/var/run
PID_FILE=$PID_DIR/shadowsocks.pid
RET_VAL=0
[ -x $BIN ] || exit 0
check_running() {
if [[ -r $PID_FILE ]]; then
read PID <$PID_FILE
if [[ -d "/proc/$PID" ]]; then
return 0
else
rm -f $PID_FILE
return 1
fi
else
return 2
fi
}
do_status() {
check_running
case $? in
0)
echo "$NAME running with PID $PID"
;;
1)
echo "$NAME not running, remove PID file $PID_FILE"
;;
2)
echo "Could not find PID file $PID_FILE, $NAME does not appear to be running"
;;
esac
return 0
}
do_start() {
if [[ ! -d $PID_DIR ]]; then
mkdir $PID_DIR || echo "failed creating PID directory $PID_DIR"; exit 1
fi
if check_running; then
echo "$NAME already running with PID $PID"
return 0
fi
if [[ ! -r $CONFIG_FILE ]]; then
echo "config file $CONFIG_FILE not found"
return 1
fi
echo "starting $NAME"
# sudo will set the group to the primary group of $USER
$BIN -c $CONFIG_FILE -d start
PID=$!
echo $PID > $PID_FILE
sleep 0.3
if ! check_running; then
echo "start failed"
return 1
fi
echo "$NAME running with PID $PID"
return 0
}
do_stop() {
if check_running; then
echo "stopping $NAME with PID $PID"
kill $PID
rm -f $PID_FILE
else
echo "Could not find PID file $PID_FILE"
fi
}
do_restart() {
do_stop
do_start
}
case "$1" in
start|stop|restart|status)
do_$1
;;
*)
echo "Usage: shadowsocks {start|stop|restart|status}"
RET_VAL=1
;;
esac
exit $RET_VAL