blob: 7b5ffd5cc270d5f73e7a660c21247c3001152a29 [file] [log] [blame]
#!/bin/bash
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
#
# This Source Code Form is "Incompatible With Secondary Licenses", as
# defined by the Mozilla Public License, v. 2.0.
# bugzilla-queue This starts, stops, and restarts the Bugzilla jobqueue.pl
# daemon, which manages sending queued mail and possibly
# other queued tasks in the future.
#
# chkconfig: 345 85 15
# description: Bugzilla queue runner
#
### BEGIN INIT INFO
# Provides: bugzilla-queue
# Required-Start: $local_fs $syslog
# Required-Stop: $local_fs $syslog
# Default-Start: 3 5
# Default-Stop: 0 1 2 6
# Short-Description: Start and stop the Bugzilla queue runner.
# Description: The Bugzilla queue runner (jobqueue.pl) sends any mail
# that Bugzilla has queued to be sent in the background. If you
# have enabled the use_mailer_queue parameter in Bugzilla, you
# must run this daemon.
### END INIT INFO
NAME=`basename $0`
#################
# Configuration #
#################
# This should be the path to your Bugzilla
BUGZILLA=/var/www/html/bugzilla
# Who owns the Bugzilla directory and files?
USER=root
# If you want to pass any options to the daemon (like -d for debugging)
# specify it here.
OPTIONS=""
# You can also override the configuration by creating a
# /etc/sysconfig/bugzilla-queue file so that you don't
# have to edit this script.
if [ -r /etc/sysconfig/$NAME ]; then
. /etc/sysconfig/$NAME
fi
##########
# Script #
##########
BIN=$BUGZILLA/jobqueue.pl
if [ ! -x $BIN ]; then
echo "$BIN not installed"
if [ "$1" = "stop" ]; then
exit 0
else
exit 5
fi
fi
# Source LSB function library.
. /lib/lsb/init-functions
# Reset status of this service.
rc_reset
# Return values for all commands but status:
# 0 - success
# 1 - generic or unspecified error
# 2 - invalid or excess argument(s)
# 3 - unimplemented feature (e.g. "reload")
# 4 - user had insufficient privileges
# 5 - program is not installed
# 6 - program is not configured
# 7 - program is not running
# 8--199 - reserved (8--99 LSB, 100--149 distrib, 150--199 appl)
#
# Note that starting an already running service, stopping
# or restarting a not-running service as well as the restart
# with force-reload (in case signaling is not supported) are
# considered a success.
case "$1" in
start)
echo -n "Starting $NAME "
# Start daemon with startproc(8). If this fails the return value
# is set appropriately by startproc.
start_daemon -u $USER $BIN ${OPTIONS} start
# Remember status and be verbose
rc_status -v
;;
stop)
echo -n "Shutting down $NAME "
# Stop daemon with killproc(8) and if this fails killproc sets the
# return value according to LSB.
killproc -TERM $BIN
# Remember status and be verbose
rc_status -v
;;
status)
echo -n "Checking for service $NAME "
# Check status with checkproc(8), if process is running checkproc
# will return with exit status 0.
# Return value is slightly different for the status command:
# 0 - service up and running
# 1 - service dead, but /var/run/ pid file exists
# 2 - service dead, but /var/lock/ lock file exists
# 3 - service not running (unused)
# 4 - service status unknown :-(
# 5--199 reserved (5--99 LSB, 100--149 distro, 150--199 appl.)
# NOTE: checkproc returns LSB compliant status values.
checkproc $BIN
# NOTE: rc_status knows that we called this init script with
# "status" option and adapts its messages accordingly.
rc_status -v
# Run jobqueue's own check function too.
$BIN check
;;
restart)
# Stop the service and regardless of whether it was running or not,
# start it again.
$0 stop
$0 start
# Remember status and be quiet.
rc_status
;;
try-restart|condrestart)
# Do a restart only if the service was active before.
# NOTE: try-restart is now part of LSB (as of 1.9). RH has a
# similar command named condrestart.
if [ "$1" = "condrestart" ]; then
echo "${attn} Use try-restart ${done}(LSB)${attn} rather than condrestart ${warn}(RH)${norm}"
fi
$0 status
if [ $? -eq 0 ]; then
$0 restart
else
rc_reset # Not running is not a failure.
fi
# Remember status and be quiet
rc_status
;;
force-reload)
# The jobqueue.pl daemon does not support SIGHUP for reload. Just
# restart the service if it is running.
echo -n "Reload service $NAME "
$0 try-restart
rc_status
;;
reload)
# The jobqueue.pl daemon does not support SIGHUP for reload.
rc_failed 3
rc_status -v
;;
*)
echo "Usage: $0 {start|stop|status|try-restart|restart|force-reload|reload}"
exit 1
esac
rc_exit