4 # Required-Start: $local_fs $remote_fs $network $named $time
5 # Required-Stop: $local_fs $remote_fs
6 # Default-Start: 2 3 4 5
8 # Short-Description: Controls the metaproxy daemon
9 # Description: Controls the Metaproxy daemon /usr/bin/metaproxy .
14 # PATH should only include /usr/* if it runs after the mountnfs.sh script
15 PATH=/sbin:/usr/sbin:/bin:/usr/bin
19 PIDFILE=/var/run/$NAME.pid
20 SCRIPTNAME=/etc/init.d/$NAME
22 # Exit if the package is not installed
23 [ -x "$DAEMON" ] || exit 0
25 # Read user information
26 . /etc/metaproxy/metaproxy.user
28 # Read configuration variable file if it is present
29 [ -r /etc/default/$NAME ] && . /etc/default/$NAME
31 # Load the VERBOSE setting and other rcS variables
34 # Define LSB log_* functions.
35 # Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
36 . /lib/lsb/init-functions
39 # Function that starts the daemon/service
44 # 0 if daemon has been started
45 # 1 if daemon was already running
46 # 2 if daemon could not be started
47 start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \
49 start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- \
52 # Add code here, if necessary, that waits for the process to be ready
53 # to handle requests from services started subsequently which depend
54 # on this one. As a last resort, sleep for some time.
58 # Function that stops the daemon/service
63 # 0 if daemon has been stopped
64 # 1 if daemon was already stopped
65 # 2 if daemon could not be stopped
66 # other if a failure occurred
67 start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE
69 [ "$RETVAL" = 2 ] && return 2
70 # Wait for children to finish too if this is a daemon that forks
71 # and if the daemon is only ever run from this initscript.
72 # If the above conditions are not satisfied then add some other code
73 # that waits for the process to drop all resources that could be
74 # needed by services started subsequently. A last resort is to
75 # sleep for some time.
76 #start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
77 #[ "$?" = 2 ] && return 2
78 # Many daemons don't delete their pidfiles when they exit.
84 # Function that sends a SIGUSR1 to the daemon/service
88 # If the daemon can reload its configuration without
89 # restarting (for example, when it is sent a SIGHUP),
90 # then implement that here.
92 $DAEMON -t $DAEMON_OPTS > /dev/null || return 2
93 start-stop-daemon --stop --signal USR1 --quiet --retry=5 --pidfile $PIDFILE --name $NAME
95 # Return if daemon could not be stopped
96 [ "$RETVAL" = 2 ] && return 2
97 # daemon not running or stopped
99 # Return if it was not running, in which case we don't start it
100 [ "$RETVAL" = 1 ] && return 0
101 start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- \
109 [ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
112 0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
113 2) [ "$VERBOSE" = no ] && \
114 log_daemon_msg "Starting $DESC" "$NAME"
120 [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
123 0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
124 2) [ "$VERBOSE" = no ] && \
125 log_daemon_msg "Stopping $DESC" "$NAME"
132 # If do_reload() is not implemented then leave this commented out
133 # and leave 'force-reload' as an alias for 'restart'.
135 # our reload makes a new PID. systemd doesn't allow it. MP-620
136 if test -n "$_use_systemctl"; then
137 log_daemon_msg "Using systemd. Not reloading $DESC" "$NAME"
140 log_daemon_msg "Reloading $DESC" "$NAME"
147 # If the "reload" option is implemented then remove the
148 # 'force-reload' alias
150 log_daemon_msg "Restarting $DESC" "$NAME"
157 1) log_end_msg 1 ;; # Old process is still running
158 *) log_end_msg 1 ;; # Failed to start
168 $DAEMON -t $DAEMON_OPTS > /dev/null || exit 2
172 status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $?
175 echo "Usage: $SCRIPTNAME {start|stop|status|restart|reload|force-reload}" >&2