docker-qBittorrentvpn/qbittorrent/qbittorrent.init

132 lines
3.4 KiB
Plaintext
Raw Normal View History

2018-02-05 00:10:44 +00:00
#!/bin/bash
2018-02-04 03:24:00 +00:00
### BEGIN INIT INFO
# Provides: qbittorrent-nox
# Required-Start: $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Starts QBittorrent
# Description: Start qbittorrent-nox on start. Change USER= before running
### END INIT INFO
# Author: Jesper Smith
# Added log support and cleanup by DementedZA
#Edit the user that qbittorrent-nox will run as.
2018-02-04 03:48:54 +00:00
USER=${PUID}
GROUP=${PGID}
2018-02-04 03:24:00 +00:00
# No need to edit these. Logging is sent to /var/log/qbittorrent-nox.log by default.
PATH="/sbin:/usr/sbin:/bin:/usr/bin"
SCRIPTNAME="/etc/init.d/qbittorrent"
NAME="qbittorrent-nox"
2018-02-05 01:15:05 +00:00
DESC="qBittorrent"
2018-02-04 03:24:00 +00:00
PIDFILE="/var/run/$NAME.pid"
2018-02-05 01:14:48 +00:00
QBTLOG="/config/qBittorrent/data/logs/qbittorrent-daemon.log"
2018-02-04 03:24:00 +00:00
DAEMON="/usr/bin/qbittorrent-nox"
2018-02-04 03:32:35 +00:00
DAEMON_ARGS="--profile=/config"
DAEMONSTRING="$DAEMON $DAEMON_ARGS >> $QBTLOG 2>&1"
2018-02-04 03:24:00 +00:00
export DBUS_SESSION_BUS_ADDRESS=""
# Read configuration variable file if it is present
#[ -r /etc/default/$NAME ] && . /etc/default/$NAME
# Load the VERBOSE setting and other rcS variables
. /lib/init/vars.sh
# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions
#
# Function that starts the daemon/service
#
do_start()
{
#Check for log file. If it doesn't exist, create it.
if [ -f $QBTLOG ];
then
echo "Logging to $QBTLOG."
else
echo "Log file $QBTLOG doesn't exist. Creating it..."
touch $QBTLOG
2018-02-04 12:11:08 +00:00
chown $USER:$GROUP $QBTLOG
2018-02-04 03:24:00 +00:00
if [ -f $QBTLOG ];
then
echo "Logfile created. Logging to $QBTLOG"
else
echo "Couldn't create logfile $QBTLOG. Please investigate."
fi
fi
# Return
# 0 if daemon has been started
# 1 if daemon was already running
# 2 if daemon could not be started
2018-02-04 03:32:35 +00:00
start-stop-daemon --start --chuid $USER:$GROUP --test --quiet --make-pidfile --pidfile $PIDFILE --background --exec /bin/bash -- -c "$DAEMONSTRING" || return 1
2018-02-04 03:24:00 +00:00
2018-02-04 03:32:35 +00:00
start-stop-daemon --start --chuid $USER:$GROUP --make-pidfile --pidfile $PIDFILE --background --exec /bin/bash -- -c "$DAEMONSTRING" || return 2
2018-02-04 03:24:00 +00:00
sleep 1
2018-02-05 01:55:04 +00:00
echo "[info] Started qBittorrent daemon successfully..." | ts '%Y-%m-%d %H:%M:%.S'
2018-02-04 03:24:00 +00:00
}
#
# Function that stops the daemon/service
#
do_stop()
{
start-stop-daemon --stop --exec "$DAEMONPATH$DAEMON"
sleep 2
return "$?"
}
case "$1" in
start)
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
do_start
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
stop)
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
do_stop
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
status)
status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $?
;;
restart|force-reload)
log_daemon_msg "Restarting $DESC" "$NAME"
do_stop
case "$?" in
0|1)
do_start
case "$?" in
0) log_end_msg 0 ;;
1) log_end_msg 1 ;; # Old process is still running
*) log_end_msg 1 ;; # Failed to start
esac
;;
*)
# Failed to stop
log_end_msg 1
;;
esac
;;
*)
#echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
echo "Usage: service qbittorrent {start|stop|status|restart|force-reload}" >&2
exit 3
;;
esac