1*4882a593Smuzhiyun#! /bin/sh
2*4882a593Smuzhiyun### BEGIN INIT INFO
3*4882a593Smuzhiyun# Provides:          transmission-daemon
4*4882a593Smuzhiyun# Required-Start:    networking
5*4882a593Smuzhiyun# Required-Stop:     networking
6*4882a593Smuzhiyun# Default-Start:     2 3 5
7*4882a593Smuzhiyun# Default-Stop:      0 1 6
8*4882a593Smuzhiyun# Short-Description: Start the transmission BitTorrent daemon client.
9*4882a593Smuzhiyun### END INIT INFO
10*4882a593Smuzhiyun
11*4882a593Smuzhiyun# Original Author: Lennart A. JÃŒtte, based on Rob Howell's script
12*4882a593Smuzhiyun# Modified by Maarten Van Coile & others (on IRC)
13*4882a593Smuzhiyun
14*4882a593Smuzhiyun# Do NOT "set -e"
15*4882a593Smuzhiyun
16*4882a593Smuzhiyun#
17*4882a593Smuzhiyun# ----- CONFIGURATION -----
18*4882a593Smuzhiyun#
19*4882a593Smuzhiyun# For the default location Transmission uses, visit:
20*4882a593Smuzhiyun# http://trac.transmissionbt.com/wiki/ConfigFiles
21*4882a593Smuzhiyun# For a guide on how set the preferences, visit:
22*4882a593Smuzhiyun# http://trac.transmissionbt.com/wiki/EditConfigFiles
23*4882a593Smuzhiyun# For the available environement variables, visit:
24*4882a593Smuzhiyun# http://trac.transmissionbt.com/wiki/EnvironmentVariables
25*4882a593Smuzhiyun#
26*4882a593Smuzhiyun# The name of the user that should run Transmission.
27*4882a593Smuzhiyun# It's RECOMENDED to run Transmission in it's own user,
28*4882a593Smuzhiyun# by default, this is set to 'transmission'.
29*4882a593Smuzhiyun# For the sake of security you shouldn't set a password
30*4882a593Smuzhiyun# on this user
31*4882a593SmuzhiyunUSERNAME=transmission
32*4882a593Smuzhiyun
33*4882a593Smuzhiyun
34*4882a593Smuzhiyun# ----- *ADVANCED* CONFIGURATION -----
35*4882a593Smuzhiyun# Only change these options if you know what you are doing!
36*4882a593Smuzhiyun#
37*4882a593Smuzhiyun# The folder where Transmission stores the config & web files.
38*4882a593Smuzhiyun# ONLY change this you have it at a non-default location
39*4882a593Smuzhiyun#TRANSMISSION_HOME="/var/config/transmission-daemon"
40*4882a593Smuzhiyun#TRANSMISSION_WEB_HOME="/usr/share/transmission/web"
41*4882a593Smuzhiyun#
42*4882a593Smuzhiyun# The arguments passed on to transmission-daemon.
43*4882a593Smuzhiyun# ONLY change this you need to, otherwise use the
44*4882a593Smuzhiyun# settings file as per above.
45*4882a593Smuzhiyun#TRANSMISSION_ARGS=""
46*4882a593Smuzhiyun
47*4882a593Smuzhiyun
48*4882a593Smuzhiyun# ----- END OF CONFIGURATION -----
49*4882a593Smuzhiyun#
50*4882a593Smuzhiyun# PATH should only include /usr/* if it runs after the mountnfs.sh script.
51*4882a593SmuzhiyunPATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
52*4882a593SmuzhiyunDESC="bittorrent client"
53*4882a593SmuzhiyunNAME=transmission-daemon
54*4882a593SmuzhiyunDAEMON=$(which $NAME)
55*4882a593SmuzhiyunPIDFILE=/var/run/$NAME.pid
56*4882a593SmuzhiyunSCRIPTNAME=/etc/init.d/$NAME
57*4882a593Smuzhiyun
58*4882a593Smuzhiyun# Exit if the package is not installed
59*4882a593Smuzhiyun[ -x "$DAEMON" ] || exit 0
60*4882a593Smuzhiyun
61*4882a593Smuzhiyun# Read configuration variable file if it is present
62*4882a593Smuzhiyun[ -r /etc/default/$NAME ] && . /etc/default/$NAME
63*4882a593Smuzhiyun
64*4882a593Smuzhiyun# Load the VERBOSE setting and other rcS variables
65*4882a593Smuzhiyun[ -f /etc/default/rcS ] && . /etc/default/rcS
66*4882a593Smuzhiyun
67*4882a593Smuzhiyun#
68*4882a593Smuzhiyun# Function that starts the daemon/service
69*4882a593Smuzhiyun#
70*4882a593Smuzhiyun
71*4882a593Smuzhiyundo_start()
72*4882a593Smuzhiyun{
73*4882a593Smuzhiyun    # Export the configuration/web directory, if set
74*4882a593Smuzhiyun    if [ -n "$TRANSMISSION_HOME" ]; then
75*4882a593Smuzhiyun          export TRANSMISSION_HOME
76*4882a593Smuzhiyun    fi
77*4882a593Smuzhiyun    if [ -n "$TRANSMISSION_WEB_HOME" ]; then
78*4882a593Smuzhiyun          export TRANSMISSION_WEB_HOME
79*4882a593Smuzhiyun    fi
80*4882a593Smuzhiyun
81*4882a593Smuzhiyun    # Return
82*4882a593Smuzhiyun    #   0 if daemon has been started
83*4882a593Smuzhiyun    #   1 if daemon was already running
84*4882a593Smuzhiyun    #   2 if daemon could not be started
85*4882a593Smuzhiyun    start-stop-daemon --chuid $USERNAME --start --pidfile $PIDFILE --make-pidfile \
86*4882a593Smuzhiyun            --exec $DAEMON --background --test -- -f $TRANSMISSION_ARGS > /dev/null \
87*4882a593Smuzhiyun            || return 1
88*4882a593Smuzhiyun    start-stop-daemon --chuid $USERNAME --start --pidfile $PIDFILE --make-pidfile \
89*4882a593Smuzhiyun            --exec $DAEMON --background -- -f $TRANSMISSION_ARGS \
90*4882a593Smuzhiyun            || return 2
91*4882a593Smuzhiyun}
92*4882a593Smuzhiyun
93*4882a593Smuzhiyun#
94*4882a593Smuzhiyun# Function that stops the daemon/service
95*4882a593Smuzhiyun#
96*4882a593Smuzhiyundo_stop()
97*4882a593Smuzhiyun{
98*4882a593Smuzhiyun        # Return
99*4882a593Smuzhiyun        #   0 if daemon has been stopped
100*4882a593Smuzhiyun        #   1 if daemon was already stopped
101*4882a593Smuzhiyun        #   2 if daemon could not be stopped
102*4882a593Smuzhiyun        #   other if a failure occurred
103*4882a593Smuzhiyun        start-stop-daemon --stop --quiet --retry=TERM/10/KILL/5 --pidfile $PIDFILE --exec $DAEMON
104*4882a593Smuzhiyun        RETVAL="$?"
105*4882a593Smuzhiyun        [ "$RETVAL" = 2 ] && return 2
106*4882a593Smuzhiyun
107*4882a593Smuzhiyun        # Wait for children to finish too if this is a daemon that forks
108*4882a593Smuzhiyun        # and if the daemon is only ever run from this initscript.
109*4882a593Smuzhiyun        # If the above conditions are not satisfied then add some other code
110*4882a593Smuzhiyun        # that waits for the process to drop all resources that could be
111*4882a593Smuzhiyun        # needed by services started subsequently.  A last resort is to
112*4882a593Smuzhiyun        # sleep for some time.
113*4882a593Smuzhiyun
114*4882a593Smuzhiyun        start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
115*4882a593Smuzhiyun        [ "$?" = 2 ] && return 2
116*4882a593Smuzhiyun
117*4882a593Smuzhiyun        # Many daemons don't delete their pidfiles when they exit.
118*4882a593Smuzhiyun        rm -f $PIDFILE
119*4882a593Smuzhiyun
120*4882a593Smuzhiyun        return "$RETVAL"
121*4882a593Smuzhiyun}
122*4882a593Smuzhiyun
123*4882a593Smuzhiyuncase "$1" in
124*4882a593Smuzhiyun  start)
125*4882a593Smuzhiyun        echo "Starting $DESC" "$NAME..."
126*4882a593Smuzhiyun        do_start
127*4882a593Smuzhiyun        case "$?" in
128*4882a593Smuzhiyun                0|1) echo "   Starting $DESC $NAME succeeded" ;;
129*4882a593Smuzhiyun                *)   echo "   Starting $DESC $NAME failed" ;;
130*4882a593Smuzhiyun        esac
131*4882a593Smuzhiyun        ;;
132*4882a593Smuzhiyun  stop)
133*4882a593Smuzhiyun        echo "Stopping $DESC $NAME..."
134*4882a593Smuzhiyun        do_stop
135*4882a593Smuzhiyun        case "$?" in
136*4882a593Smuzhiyun                0|1) echo "   Stopping $DESC $NAME succeeded" ;;
137*4882a593Smuzhiyun                *)   echo "   Stopping $DESC $NAME failed" ;;
138*4882a593Smuzhiyun        esac
139*4882a593Smuzhiyun        ;;
140*4882a593Smuzhiyun  restart|force-reload)
141*4882a593Smuzhiyun        #
142*4882a593Smuzhiyun        # If the "reload" option is implemented then remove the
143*4882a593Smuzhiyun        # 'force-reload' alias
144*4882a593Smuzhiyun        #
145*4882a593Smuzhiyun        echo "Restarting $DESC $NAME..."
146*4882a593Smuzhiyun        do_stop
147*4882a593Smuzhiyun        case "$?" in
148*4882a593Smuzhiyun          0|1)
149*4882a593Smuzhiyun                do_start
150*4882a593Smuzhiyun                case "$?" in
151*4882a593Smuzhiyun                    0|1) echo "   Restarting $DESC $NAME succeeded" ;;
152*4882a593Smuzhiyun                    *)   echo "   Restarting $DESC $NAME failed: couldn't start $NAME" ;;
153*4882a593Smuzhiyun                esac
154*4882a593Smuzhiyun                ;;
155*4882a593Smuzhiyun          *)
156*4882a593Smuzhiyun                echo "   Restarting $DESC $NAME failed: couldn't stop $NAME" ;;
157*4882a593Smuzhiyun        esac
158*4882a593Smuzhiyun        ;;
159*4882a593Smuzhiyun  *)
160*4882a593Smuzhiyun        echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
161*4882a593Smuzhiyun        exit 3
162*4882a593Smuzhiyun        ;;
163*4882a593Smuzhiyunesac
164