| 
									
										
										
										
											2008-05-30 16:47:24 +00:00
										 |  |  | #!/bin/sh | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | # vim:textwidth=80:tabstop=4:shiftwidth=4:smartindent:autoindent | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CLIARGS="$*"				# Grab any args passed to safe_asterisk | 
					
						
							|  |  |  | TTY=9						# TTY (if you want one) for Asterisk to run on | 
					
						
							|  |  |  | CONSOLE=yes					# Whether or not you want a console | 
					
						
							| 
									
										
										
										
											2003-02-18 18:15:30 +00:00
										 |  |  | #NOTIFY=ben@alkaloid.net	# Who to notify about crashes | 
					
						
							| 
									
										
										
										
											2006-08-14 01:13:32 +00:00
										 |  |  | #EXEC=/path/to/somescript	# Run this command if Asterisk crashes | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | #LOGFILE=/path/to/logfile	# Where to place the normal logfile (disabled if blank) | 
					
						
							|  |  |  | #SYSLOG=local0				# Which syslog facility to use (disabled if blank) | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | MACHINE=`hostname`			# To specify which machine has crashed when getting the mail | 
					
						
							| 
									
										
										
										
											2003-02-18 18:15:30 +00:00
										 |  |  | DUMPDROP=/tmp | 
					
						
							| 
									
										
										
										
											2006-01-24 22:06:37 +00:00
										 |  |  | SLEEPSECS=4 | 
					
						
							| 
									
										
										
										
											2005-08-14 02:19:16 +00:00
										 |  |  | ASTSBINDIR=__ASTERISK_SBIN_DIR__ | 
					
						
							| 
									
										
										
										
											2009-02-21 13:13:35 +00:00
										 |  |  | ASTVARRUNDIR=__ASTERISK_VARRUN_DIR__ | 
					
						
							|  |  |  | ASTPIDFILE=${ASTVARRUNDIR}/asterisk.pid | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # comment this line out to have this script _not_ kill all mpg123 processes when | 
					
						
							|  |  |  | # asterisk exits | 
					
						
							|  |  |  | KILLALLMPG123=1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # run asterisk with this priority | 
					
						
							| 
									
										
										
										
											2006-01-24 22:06:37 +00:00
										 |  |  | PRIORITY=0 | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # set system filemax on supported OSes if this variable is set | 
					
						
							|  |  |  | # SYSMAXFILES=262144 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-16 19:54:11 +00:00
										 |  |  | # Asterisk allows full permissions by default, so set a umask, if you want | 
					
						
							|  |  |  | # restricted permissions. | 
					
						
							|  |  |  | #UMASK=022 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | # set max files open with ulimit. On linux systems, this will be automatically | 
					
						
							|  |  |  | # set to the system's maximum files open devided by two, if not set here. | 
					
						
							|  |  |  | # MAXFILES=32768 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-01 12:17:33 +00:00
										 |  |  | message() { | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 	echo "$1" >&2 | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 	if test "x$SYSLOG" != "x" ; then | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 	    logger -p "${SYSLOG}.warn" -t safe_asterisk[$$] "$1" | 
					
						
							|  |  |  | 	fi | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 	if test "x$LOGFILE" != "x" ; then | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 	    echo "safe_asterisk[$$]: $1" >> "$LOGFILE" | 
					
						
							|  |  |  | 	fi | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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. | 
					
						
							| 
									
										
										
										
											2011-05-05 15:04:24 +00:00
										 |  |  | VERSION=`${ASTSBINDIR}/asterisk -nrx 'core show version'` | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | if test "`echo $VERSION | cut -c 1-8`" = "Asterisk" ; then | 
					
						
							| 
									
										
										
										
											2008-05-05 03:25:35 +00:00
										 |  |  | 	message "Asterisk is already running.  $0 will exit now." | 
					
						
							|  |  |  | 	exit 1 | 
					
						
							|  |  |  | fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | # since we're going to change priority and open files limits, we need to be | 
					
						
							|  |  |  | # root. if running asterisk as other users, pass that to asterisk on the command | 
					
						
							|  |  |  | # line. | 
					
						
							|  |  |  | # if we're not root, fall back to standard everything. | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | if test `id -u` != 0 ; then | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 	echo "Oops. I'm not root. Falling back to standard prio and file max." >&2 | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | 	echo "This is NOT suitable for large systems." >&2 | 
					
						
							|  |  |  | 	PRIORITY=0 | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 	message "safe_asterisk was started by `id -n` (uid `id -u`)." | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | else | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 	if `uname -s | grep Linux >/dev/null 2>&1`; then | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | 		# maximum number of open files is set to the system maximum divided by two if | 
					
						
							|  |  |  | 		# MAXFILES is not set. | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 		if test "x$MAXFILES" = "x" ; then | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | 			# just check if file-max is readable | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 			if test -r /proc/sys/fs/file-max ; then | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | 				MAXFILES=$(( `cat /proc/sys/fs/file-max` / 2 )) | 
					
						
							|  |  |  | 			fi | 
					
						
							|  |  |  | 		fi | 
					
						
							|  |  |  | 		SYSCTL_MAXFILES="fs.file-max" | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 	elif `uname -s | grep Darwin /dev/null 2>&1`; then | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | 		SYSCTL_MAXFILES="kern.maxfiles" | 
					
						
							|  |  |  | 	fi | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 	if test "x$SYSMAXFILES" != "x"; then | 
					
						
							|  |  |  | 		if test "x$SYSCTL_MAXFILES" != "x"; then | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | 			sysctl -w $SYSCTL_MAXFILES=$SYSMAXFILES | 
					
						
							|  |  |  | 		fi | 
					
						
							|  |  |  | 	fi | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	# set the process's filemax to whatever set above | 
					
						
							|  |  |  | 	ulimit -n $MAXFILES | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 	if test ! -d ${ASTVARRUNDIR} ; then | 
					
						
							| 
									
										
										
										
											2009-02-21 13:13:35 +00:00
										 |  |  | 		mkdir -p ${ASTVARRUNDIR} | 
					
						
							|  |  |  | 		chmod 770 ${ASTVARRUNDIR} | 
					
						
							|  |  |  | 	fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-16 19:54:11 +00:00
										 |  |  | if test "x$UMASK" != "x"; then | 
					
						
							|  |  |  | 	umask $UMASK | 
					
						
							|  |  |  | fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | # | 
					
						
							|  |  |  | # Let Asterisk dump core | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | ulimit -c unlimited | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-05-27 23:15:47 +00:00
										 |  |  | # | 
					
						
							|  |  |  | # Don't fork when running "safely" | 
					
						
							|  |  |  | # | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | ASTARGS="" | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | if test "x$TTY" != "x" ; then | 
					
						
							|  |  |  | 	if test -c /dev/tty${TTY} ; then | 
					
						
							| 
									
										
										
										
											2003-02-18 18:15:30 +00:00
										 |  |  | 		TTY=tty${TTY} | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 	elif test -c /dev/vc/${TTY} ; then | 
					
						
							| 
									
										
										
										
											2003-02-18 18:15:30 +00:00
										 |  |  | 		TTY=vc/${TTY} | 
					
						
							|  |  |  | 	else | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 		message "Cannot find specified TTY (${TTY})" | 
					
						
							| 
									
										
										
										
											2003-02-18 18:15:30 +00:00
										 |  |  | 		exit 1 | 
					
						
							|  |  |  | 	fi | 
					
						
							| 
									
										
										
										
											2003-05-07 22:33:55 +00:00
										 |  |  | 	ASTARGS="${ASTARGS} -vvvg" | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 	if test "x$CONSOLE" != "xno" ; then | 
					
						
							| 
									
										
										
										
											2002-05-27 23:15:47 +00:00
										 |  |  | 		ASTARGS="${ASTARGS} -c" | 
					
						
							|  |  |  | 	fi | 
					
						
							|  |  |  | fi | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | if test ! -w "${DUMPDROP}" ; then	 | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 	message "Cannot write to ${DUMPDROP}" | 
					
						
							| 
									
										
										
										
											2003-02-18 18:15:30 +00:00
										 |  |  | 	exit 1 | 
					
						
							|  |  |  | fi | 
					
						
							| 
									
										
										
										
											2002-05-27 23:15:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-05-11 16:37:16 +00:00
										 |  |  | # | 
					
						
							|  |  |  | # Don't die if stdout/stderr can't be written to | 
					
						
							|  |  |  | # | 
					
						
							| 
									
										
										
										
											2007-06-18 17:50:01 +00:00
										 |  |  | trap '' PIPE | 
					
						
							| 
									
										
										
										
											2007-05-11 16:37:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-19 21:11:31 +00:00
										 |  |  | # | 
					
						
							|  |  |  | # Run scripts to set any environment variables or do any other system-specific setup needed | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | if test -d /etc/asterisk/startup.d ; then | 
					
						
							| 
									
										
										
										
											2006-04-19 21:11:31 +00:00
										 |  |  | 	for script in /etc/asterisk/startup.d/*.sh; do | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 		if test -r ${script} ; then | 
					
						
							| 
									
										
										
										
											2009-05-26 13:06:50 +00:00
										 |  |  | 			. ${script} | 
					
						
							| 
									
										
										
										
											2006-04-19 21:11:31 +00:00
										 |  |  | 		fi | 
					
						
							|  |  |  | 	done | 
					
						
							|  |  |  | fi | 
					
						
							| 
									
										
										
										
											2002-05-27 23:15:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | run_asterisk() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	while :; do  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 		if test "x$TTY" != "x" ; then | 
					
						
							| 
									
										
										
										
											2003-02-18 18:15:30 +00:00
										 |  |  | 			cd /tmp | 
					
						
							|  |  |  | 			stty sane < /dev/${TTY} | 
					
						
							| 
									
										
										
										
											2008-08-01 12:17:33 +00:00
										 |  |  | 			nice -n $PRIORITY ${ASTSBINDIR}/asterisk -f ${CLIARGS} ${ASTARGS} > /dev/${TTY} 2>&1 < /dev/${TTY} | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2003-02-18 18:15:30 +00:00
										 |  |  | 			cd /tmp | 
					
						
							| 
									
										
										
										
											2007-05-11 16:37:16 +00:00
										 |  |  | 			nice -n $PRIORITY ${ASTSBINDIR}/asterisk -f ${CLIARGS} ${ASTARGS} | 
					
						
							| 
									
										
										
										
											2002-05-27 23:15:47 +00:00
										 |  |  | 		fi | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | 		EXITSTATUS=$? | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 		message "Asterisk ended with exit status $EXITSTATUS" | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 		if test "x$EXITSTATUS" = "x0" ; then | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | 			# Properly shutdown.... | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 			message "Asterisk shutdown normally." | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | 			exit 0 | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 		elif test "0$EXITSTATUS" -gt "128" ; then | 
					
						
							|  |  |  | 			EXITSIGNAL=$(($EXITSTATUS - 128)) | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | 			echo "Asterisk exited on signal $EXITSIGNAL." | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 			if test "x$NOTIFY" != "x" ; then | 
					
						
							| 
									
										
										
										
											2004-12-01 05:10:32 +00:00
										 |  |  | 				echo "Asterisk on $MACHINE exited on signal $EXITSIGNAL.  Might want to take a peek." | \ | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | 				mail -s "Asterisk Died" $NOTIFY | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 				message "Exited on signal $EXITSIGNAL" | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | 			fi | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 			if test "x$EXEC" != "x" ; then | 
					
						
							| 
									
										
										
										
											2006-08-14 01:13:32 +00:00
										 |  |  | 				$EXEC | 
					
						
							|  |  |  | 			fi | 
					
						
							| 
									
										
										
										
											2007-05-11 16:37:16 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			PID=`cat ${ASTPIDFILE}` | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 			DATE=`date "+%Y-%m-%dT%H:%M:%S%z"` | 
					
						
							|  |  |  | 			if test -f /tmp/core.${PID} ; then | 
					
						
							|  |  |  | 				mv /tmp/core.${PID} ${DUMPDROP}/core.`hostname`-$DATE & | 
					
						
							|  |  |  | 			elif test -f /tmp/core ; then | 
					
						
							|  |  |  | 				mv /tmp/core ${DUMPDROP}/core.`hostname`-$DATE & | 
					
						
							| 
									
										
										
										
											2003-02-18 18:15:30 +00:00
										 |  |  | 			fi | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 			message "Asterisk died with code $EXITSTATUS." | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			PID=`cat ${ASTPIDFILE}` | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 			DATE=`date "+%Y-%m-%dT%H:%M:%S%z"` | 
					
						
							|  |  |  | 			if test -f /tmp/core.${PID} ; then | 
					
						
							|  |  |  | 				mv /tmp/core.${PID} ${DUMPDROP}/core.`hostname`-$DATE & | 
					
						
							|  |  |  | 			elif test -f /tmp/core ; then | 
					
						
							|  |  |  | 				mv /tmp/core ${DUMPDROP}/core.`hostname`-$DATE & | 
					
						
							| 
									
										
										
										
											2003-02-18 18:15:30 +00:00
										 |  |  | 			fi | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | 		fi | 
					
						
							| 
									
										
										
										
											2007-09-06 16:57:20 +00:00
										 |  |  | 		message "Automatically restarting Asterisk." | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | 		sleep $SLEEPSECS | 
					
						
							| 
									
										
										
										
											2010-01-12 03:21:40 +00:00
										 |  |  | 		if test "0$KILLALLMPG123" -gt "0" ; then | 
					
						
							| 
									
										
										
										
											2008-10-07 18:00:48 +00:00
										 |  |  | 			pkill -9 mpg123 | 
					
						
							| 
									
										
										
										
											2006-01-24 21:45:42 +00:00
										 |  |  | 		fi | 
					
						
							| 
									
										
										
										
											2002-07-30 14:17:55 +00:00
										 |  |  | 	done | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | run_asterisk & |