diff options
author | russell <russell@f38db490-d61c-443f-a65b-d21fe96a405b> | 2009-01-16 15:51:43 +0000 |
---|---|---|
committer | russell <russell@f38db490-d61c-443f-a65b-d21fe96a405b> | 2009-01-16 15:51:43 +0000 |
commit | 52acc4c45786fc04da9536c2801eb2b483cc2009 (patch) | |
tree | 3e0b68760b7b6d49c72de4fd5b747ed4d5726ad3 /contrib/init.d/rc.mandrake.asterisk | |
parent | 5d9d64e584ec5220835eb10a124b555d449fa3d3 (diff) | |
parent | caebf8461f9849f484eb5bbd649880e457c20e31 (diff) |
Creating tag for the release of asterisk-1.4.23-rc4
git-svn-id: http://svn.digium.com/svn/asterisk/tags/1.4.23-rc4@168755 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'contrib/init.d/rc.mandrake.asterisk')
-rwxr-xr-x | contrib/init.d/rc.mandrake.asterisk | 195 |
1 files changed, 195 insertions, 0 deletions
diff --git a/contrib/init.d/rc.mandrake.asterisk b/contrib/init.d/rc.mandrake.asterisk new file mode 100755 index 000000000..1493f4fa9 --- /dev/null +++ b/contrib/init.d/rc.mandrake.asterisk @@ -0,0 +1,195 @@ +#!/bin/sh +# +# asterisk: Starts the asterisk service +# +# Version: @(#) /etc/rc.d/init.d/asterisk 1.0 +# +# chkconfig: 2345 95 10 +# description: Starts the asterisk service +# +# processname: asterisk +# + +# $Id$ + +TTY=9 # TTY (if you want one) for Asterisk to run on +CONSOLE=yes # Whether or not you want a console +NOTIFY=root # Who to notify about crashes +DUMPDROP=/tmp +HOSTNAME=`hostname` +ASTSBINDIR=/usr/sbin + +if [ 0`readlink $0` = "0" ]; then + CONFIGFILE=/etc/sysconfig/`basename $0` +else + CONFIG0=`readlink $0` + CONFIGFILE=/etc/sysconfig/`basename $CONFIG0` +fi + +# Setup environment +cd /usr/src +if [ -f /usr/lib/asterisk/modules/chan_h323.so -a `grep -c ^noload=chan_h323.so /etc/asterisk/modules.conf` -eq 0 ]; then + OPENH323DIR=/usr/src/h323/openh323 + PWLIBDIR=/usr/src/h323/pwlib +else + OPENH323DIR=/usr/src/oh323/openh323 + PWLIBDIR=/usr/src/oh323/pwlib +fi + +# Put overrides in /etc/sysconfig/asterisk +[ -f $CONFIGFILE ] && . $CONFIGFILE + +LD_LIBRARY_PATH=$OPENH323DIR/lib:$PWLIBDIR/lib +export OPENH323DIR PWLIBDIR LD_LIBRARY_PATH + +# Source function library. +. /etc/rc.d/init.d/functions + +# +# Don't fork when running "safely" +# +ASTARGS="-p" +if [ "$TTY" != "" ]; then + if [ -c /dev/tty${TTY} ]; then + TTY=tty${TTY} + elif [ -c /dev/vc/${TTY} ]; then + TTY=vc/${TTY} + else + echo "Cannot find your TTY (${TTY})" >&2 + exit 1 + fi + ASTARGS="${ASTARGS} -vvv" + if [ "$CONSOLE" != "no" ]; then + ASTARGS="${ASTARGS} -c" + fi +fi +if [ ! -w ${DUMPDROP} ]; then + echo "Cannot write to ${DUMPDROP}" >&2 + exit 1 +fi + +# +# Let Asterisk dump core +# +ulimit -c unlimited + +#launch_asterisk() +#{ +#} + +SIGMSG=("None", "Hangup" "Interrupt" "Quit" "Illegal instruction" "Trace trap" "IOT Trap" "Bus Error" "Floating-point exception" "Killed" "User-defined signal 1" "Segmentation violation" "User-defined signal 2" "Broken pipe" "Alarm clock" "Termination" "Stack fault") + +run_asterisk() +{ + while :; do + + if [ "$TTY" != "" ]; then + cd /tmp + stty sane < /dev/${TTY} + asterisk ${ASTARGS} > /dev/${TTY} 2>&1 < /dev/${TTY} + else + cd /tmp + asterisk ${ASTARGS} + fi + EXITSTATUS=$? + echo "Asterisk ended with exit status $EXITSTATUS" + if [ "$EXITSTATUS" = "0" ]; then + # Properly shutdown.... + echo "Asterisk shutdown normally." + exit 0 + elif [ $EXITSTATUS -gt 128 ]; then + EXITSIGNAL=$(($EXITSTATUS - 128)) + EXITMSG=${SIGMSG[$EXITSIGNAL]} + echo "Asterisk exited on signal $EXITSIGNAL - $EXITMSG." + if [ "$NOTIFY" != "" ]; then + echo "Asterisk exited on signal $EXITSIGNAL - $EXITMSG. Might want to take a peek." | \ + mail -s "Asterisk Died ($HOSTNAME)" $NOTIFY + fi + if [ -f /tmp/core ]; then + mv /tmp/core ${DUMPDROP}/core.`hostname`-`date -Iseconds` & + fi + else + echo "Asterisk died with code $EXITSTATUS. Aborting." + if [ -f /tmp/core ]; then + mv /tmp/core ${DUMPDROP}/core.`hostname`-`date -Iseconds` & + fi + exit 0 + fi + echo "Automatically restarting Asterisk." + done +} + +case "$1" in + start) + # Check if Asterisk is already running. If it is, then bug out, because + # starting Asterisk when Asterisk is already running is very bad. + VERSION=`${ASTSBINDIR}/asterisk -rx 'core show version'` + if [ "`echo $VERSION | cut -c 1-8`" = "Asterisk" ]; then + echo "Asterisk is already running. $0 will exit now." + exit 1 + fi + + gprintf "Starting asterisk: " + run_asterisk >/dev/null 2>&1 & + sleep 2 # Give it time to die + succeeded=`pidof asterisk|awk '{print NF}'` + if [ $succeeded = "0" ]; then + failure + else + success + fi + echo + ;; + stop) + gprintf "Stopping asterisk: " + asterisk -r -x "stop gracefully" >/dev/null 2>&1 + killall -9 mpg123 2>/dev/null + success + echo + ;; + restart) + $0 stop + usleep 100000 + $0 start + ;; + reload) + gprintf "Reloading asterisk: " + asterisk -r -x "reload" >/dev/null 2>&1 + success + echo + ;; + stopnow) + gprintf "Stopping asterisk: " + asterisk -r -x "stop now" >/dev/null 2>&1 + success + echo + ;; + restartnow) + $0 stopnow + $0 start + ;; + fullrestart) + $0 stop + service zaptel restart + $0 start + ;; + fullrestartnow) + $0 stopnow + service zaptel restart + $0 start + ;; + status) + succeeded=`pidof asterisk|awk '{print NF}'` + if [ $succeeded = "0" ]; then + echo "Asterisk is not running" + else + echo "Asterisk is currently running with $succeeded threads" + fi + ;; + *) + gprintf "*** Usage: $0 {start|stop[now]|reload|[full]restart[now]|status}\n" + exit 1 +esac + +exit 0 + |