Files
asterisk/contrib/init.d/rc.redhat.asterisk
T

179 lines
4.1 KiB
Bash
Raw Normal View History

2002-06-19 02:35:40 +00:00
#!/bin/sh
2007-06-04 17:12:35 +00:00
# $Id$
2002-06-19 02:35:40 +00:00
#
# asterisk Starts, Stops and Reloads Asterisk.
2002-06-19 02:35:40 +00:00
#
2006-10-31 06:31:34 +00:00
# chkconfig: 2345 90 60
# description: Asterisk PBX and telephony daemon.
2002-06-19 02:35:40 +00:00
# processname: asterisk
# pidfile: __ASTERISK_VARRUN_DIR__/asterisk.pid
#
2005-11-30 21:22:38 +00:00
# Thu Nov 17 2005 Gregory Boehnlein <damin@nacs.net>
# - Updated Version to 1.3
# - Reversed behavior of LD_ASSUME_KERNEL=2.4.1
# - Added detailed failure messages
#
# Sun Jul 18 2004 Gregory Boehnlein <damin@nacs.net>
# - Updated Version to 1.2
# - Added test for safe_asterisk
# - Verified SIGTERM issued by "killproc" ensures "stop gracefully"
# - Added support for -U and -G command line options
# - Modified "reload" to call asterisk -rx 'reload'
2002-06-19 02:35:40 +00:00
2010-01-11 23:53:32 +00:00
### BEGIN INIT INFO
# Provides: asterisk
# Required-Start: $network $syslog $named $local_fs $remote_fs
# Required-Stop: $network $syslog $named $local_fs $remote_fs
# Should-Start: dahdi misdn lcr wanrouter mysql postgresql
# Should-Stop: dahdi misdn lcr wanrouter mysql postgresql
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Asterisk PBX
# Description: the Asterisk Open Source PBX
### END INIT INFO
2006-03-25 05:10:07 +00:00
# Use this option to specify a different configuration directory
#AST_CONFIG=__ASTERISK_ETC_DIR__
2006-03-25 05:10:07 +00:00
# Installation directory
AST_SBIN=__ASTERISK_SBIN_DIR__
2006-03-25 05:10:07 +00:00
2002-06-19 02:35:40 +00:00
# Source function library.
. /etc/rc.d/init.d/functions
2006-03-25 05:10:07 +00:00
if ! [ -x $AST_SBIN/asterisk ] ; then
2006-10-02 19:43:00 +00:00
echo "ERROR: $AST_SBIN/asterisk not found"
2005-11-30 21:22:38 +00:00
exit 0
fi
2006-03-25 05:10:07 +00:00
if ! [ -d $AST_CONFIG ] ; then
2006-03-28 17:49:39 +00:00
echo "ERROR: $AST_CONFIG directory not found"
2005-11-30 21:22:38 +00:00
exit 0
fi
# Full path to asterisk binary
2006-03-25 05:10:07 +00:00
DAEMON=$AST_SBIN/asterisk
# Full path to safe_asterisk script
2006-03-25 05:10:07 +00:00
SAFE_ASTERISK=$AST_SBIN/safe_asterisk
2006-03-25 05:10:07 +00:00
# Allow configuration overrides in /etc/sysconfig/asterisk
CONFIG0=`readlink $0`
2006-03-28 17:49:39 +00:00
if [ "$CONFIG0" = "" ]; then
2006-03-25 05:10:07 +00:00
CONFIGFILE=/etc/sysconfig/`basename $0`
else
CONFIGFILE=/etc/sysconfig/`basename $CONFIG0`
fi
[ -r $CONFIGFILE ] && . $CONFIGFILE
2002-06-19 02:35:40 +00:00
RETVAL=0
start() {
2008-05-05 03:25:35 +00:00
# Check if Asterisk is already running. If it is, then bug out, because
# starting safe_asterisk when Asterisk is running is very bad.
VERSION=`${AST_SBIN}/asterisk -rx 'core show version' 2>/dev/null`
2008-05-30 16:47:24 +00:00
if [ "`echo $VERSION | cut -c 1-8`" = "Asterisk" ]; then
2008-05-05 03:25:35 +00:00
echo "Asterisk is already running."
2011-09-20 22:29:24 +00:00
exit 0
2008-05-05 03:25:35 +00:00
fi
# Start daemons.
echo -n $"Starting asterisk: "
if [ -f $SAFE_ASTERISK ] ; then
DAEMON=$SAFE_ASTERISK
fi
if [ $AST_USER ] ; then
ASTARGS="-U $AST_USER"
fi
if [ $AST_GROUP ] ; then
2006-03-25 05:10:07 +00:00
ASTARGS="$ASTARGS -G $AST_GROUP"
fi
if [ $AST_CONFIG ]; then
2008-08-06 20:15:34 +00:00
ASTARGS="$ASTARGS -C $AST_CONFIG/asterisk.conf"
elif [ $ALTCONF ]; then
ASTARGS="$ASTARGS -C $ALTCONF"
fi
if [ "x$COREDUMP" = "xyes" ]; then
ASTARGS="$ASTARGS -g"
fi
if [ "0$MAXLOAD" -gt "0" ]; then
ASTARGS="$ASTARGS -L $MAXLOAD"
fi
if [ "0$MAXCALLS" -gt "0" ]; then
ASTARGS="$ASTARGS -M $MAXCALLS"
fi
if [ "0$VERBOSITY" -gt "0" ]; then
for i in `seq 1 $VERBOSITY`; do
ASTARGS="$ASTARGS -v"
done
fi
if [ "x$INTERNALTIMING" = "xyes" ]; then
ASTARGS="$ASTARGS -I"
fi
if [ "x$TEMPRECORDINGLOCATION" = "xyes" -o "x$TMPRECORDINGLOCATION" = "xyes" ]; then
ASTARGS="$ASTARGS -t"
fi
if [ "x$COLOR" = "xyes" ]; then
export TERM=linux
daemon sh -c "$DAEMON $ASTARGS -c" >/dev/null </dev/null 2>&1 &
else
daemon $DAEMON $ASTARGS
fi
RETVAL=$?
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/asterisk
echo
return $RETVAL
}
stop() {
# Stop daemons.
2009-11-02 17:15:31 +00:00
if [ -f $SAFE_ASTERISK ]; then
# Kill safe_asterisk first, to prevent us from starting up 2 instances of safe_asterisk
echo -n $"Stopping safe_asterisk: "
killproc `basename $SAFE_ASTERISK`
echo
fi
echo -n $"Shutting down asterisk: "
2009-11-02 17:15:31 +00:00
killproc `basename $DAEMON`
RETVAL=$?
[ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/asterisk
echo
return $RETVAL
}
restart() {
stop
start
}
reload() {
$DAEMON -rx 'module reload' > /dev/null 2> /dev/null
}
2002-06-19 02:35:40 +00:00
# See how we were called.
case "$1" in
start)
start
;;
2002-06-19 02:35:40 +00:00
stop)
stop
;;
restart)
restart
2002-06-19 02:35:40 +00:00
;;
reload)
reload
;;
condrestart)
[ -f /var/lock/subsys/asterisk ] && restart || :
;;
status)
status asterisk
2002-06-19 02:35:40 +00:00
;;
*)
echo "Usage: asterisk {start|stop|restart|reload|condrestart|status}"
exit 1
2002-06-19 02:35:40 +00:00
esac
exit $?