diff options
author | 2011-09-01 14:09:56 +0000 | |
---|---|---|
committer | 2011-09-01 14:09:56 +0000 | |
commit | e50e421346984cf49d565cf2f56cc6b09f21b459 (patch) | |
tree | 0063581ba1a7321a75cf3d8cb51f6fec7172630f /net-misc | |
parent | Change version scheme (diff) | |
download | gentoo-2-e50e421346984cf49d565cf2f56cc6b09f21b459.tar.gz gentoo-2-e50e421346984cf49d565cf2f56cc6b09f21b459.tar.bz2 gentoo-2-e50e421346984cf49d565cf2f56cc6b09f21b459.zip |
Version bump. New & improved init script by Jaco Kroon closes bug #363267. EAPI 4 porting by Agostino "ago" Sarubbo closes bug #380359.
(Portage version: 2.1.10.11/cvs/Linux x86_64)
Diffstat (limited to 'net-misc')
-rw-r--r-- | net-misc/asterisk/ChangeLog | 9 | ||||
-rw-r--r-- | net-misc/asterisk/asterisk-1.8.6.0.ebuild | 434 | ||||
-rw-r--r-- | net-misc/asterisk/files/1.8.0/asterisk.confd | 95 | ||||
-rw-r--r-- | net-misc/asterisk/files/1.8.0/asterisk.initd | 273 |
4 files changed, 810 insertions, 1 deletions
diff --git a/net-misc/asterisk/ChangeLog b/net-misc/asterisk/ChangeLog index 6c446a30cc42..45fa3b0a0aaa 100644 --- a/net-misc/asterisk/ChangeLog +++ b/net-misc/asterisk/ChangeLog @@ -1,6 +1,13 @@ # ChangeLog for net-misc/asterisk # Copyright 1999-2011 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/net-misc/asterisk/ChangeLog,v 1.342 2011/09/01 13:31:41 chainsaw Exp $ +# $Header: /var/cvsroot/gentoo-x86/net-misc/asterisk/ChangeLog,v 1.343 2011/09/01 14:09:56 chainsaw Exp $ + +*asterisk-1.8.6.0 (01 Sep 2011) + + 01 Sep 2011; Tony Vroon <chainsaw@gentoo.org> +files/1.8.0/asterisk.confd, + +files/1.8.0/asterisk.initd, +asterisk-1.8.6.0.ebuild: + Version bump. New & improved init script by Jaco Kroon closes bug #363267. + EAPI 4 porting by Agostino "ago" Sarubbo closes bug #380359. 01 Sep 2011; Tony Vroon <chainsaw@gentoo.org> -asterisk-1.6.2.18.2.ebuild, -asterisk-1.6.2.19-r2.ebuild: diff --git a/net-misc/asterisk/asterisk-1.8.6.0.ebuild b/net-misc/asterisk/asterisk-1.8.6.0.ebuild new file mode 100644 index 000000000000..de92a6fe0324 --- /dev/null +++ b/net-misc/asterisk/asterisk-1.8.6.0.ebuild @@ -0,0 +1,434 @@ +# Copyright 1999-2011 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/net-misc/asterisk/asterisk-1.8.6.0.ebuild,v 1.1 2011/09/01 14:09:56 chainsaw Exp $ + +EAPI=4 +inherit autotools base eutils linux-info multilib + +MY_P="${PN}-${PV/_/-}" + +DESCRIPTION="Asterisk: A Modular Open Source PBX System" +HOMEPAGE="http://www.asterisk.org/" +SRC_URI="http://downloads.asterisk.org/pub/telephony/asterisk/${MY_P}.tar.gz + mirror://gentoo/gentoo-asterisk-patchset-1.2.tar.bz2" +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~amd64 ~x86" + +IUSE="ais alsa bluetooth calendar +caps curl dahdi debug doc freetds gtalk h323 http iconv jabber jingle ldap lua mysql newt +samples odbc osplookup oss portaudio postgres radius snmp span speex ssl sqlite sqlite3 srtp static syslog usb vorbis" + +EPATCH_SUFFIX="patch" +PATCHES=( "${WORKDIR}/asterisk-patchset" ) + +RDEPEND="dev-libs/popt + dev-libs/libxml2 + ais? ( sys-cluster/openais ) + alsa? ( media-libs/alsa-lib ) + bluetooth? ( net-wireless/bluez ) + calendar? ( net-libs/neon + dev-libs/libical + dev-libs/iksemel ) + caps? ( sys-libs/libcap ) + curl? ( net-misc/curl ) + dahdi? ( >=net-libs/libpri-1.4.12_beta2 + net-misc/dahdi-tools ) + freetds? ( dev-db/freetds ) + gtalk? ( dev-libs/iksemel ) + h323? ( net-libs/openh323 ) + http? ( dev-libs/gmime:2.4 ) + iconv? ( virtual/libiconv ) + jabber? ( dev-libs/iksemel ) + jingle? ( dev-libs/iksemel ) + ldap? ( net-nds/openldap ) + lua? ( dev-lang/lua ) + mysql? ( dev-db/mysql ) + newt? ( dev-libs/newt ) + odbc? ( dev-db/unixODBC ) + osplookup? ( net-libs/osptoolkit + dev-libs/openssl ) + portaudio? ( media-libs/portaudio ) + postgres? ( dev-db/postgresql-base ) + radius? ( net-dialup/radiusclient-ng ) + snmp? ( net-analyzer/net-snmp ) + span? ( media-libs/spandsp ) + speex? ( media-libs/speex ) + sqlite? ( dev-db/sqlite:0 ) + sqlite3? ( dev-db/sqlite:3 ) + srtp? ( net-libs/libsrtp ) + ssl? ( dev-libs/openssl ) + usb? ( dev-libs/libusb + media-libs/alsa-lib ) + vorbis? ( media-libs/libvorbis )" + +DEPEND="${RDEPEND} + !net-misc/asterisk-addons + !net-misc/asterisk-chan_unistim + !net-misc/zaptel" + +RDEPEND="${RDEPEND} + syslog? ( virtual/logger )" + +PDEPEND="net-misc/asterisk-core-sounds + net-misc/asterisk-extra-sounds + net-misc/asterisk-moh-opsound" + +S="${WORKDIR}/${MY_P}" + +pkg_setup() { + CONFIG_CHECK="~!NF_CONNTRACK_SIP" + local WARNING_NF_CONNTRACK_SIP="SIP (NAT) connection tracking is enabled. Some users + have reported that this module dropped critical SIP packets in their deployments. You + may want to disable it if you see such problems." + check_extra_config + + enewgroup asterisk + enewgroup dialout 20 + enewuser asterisk -1 -1 /var/lib/asterisk "asterisk,dialout" +} + +src_prepare() { + base_src_prepare + AT_M4DIR=autoconf eautoreconf +} + +src_configure() { + econf \ + --libdir="/usr/$(get_libdir)" \ + --localstatedir="/var" \ + --with-gsm=internal \ + --with-popt \ + --with-z \ + $(use_with caps cap) \ + $(use_with http gmime) \ + $(use_with newt) \ + $(use_with portaudio) \ + $(use_with ssl crypto) \ + $(use_with ssl) + + # + # blank out sounds/sounds.xml file to prevent + # asterisk from installing sounds files (we pull them in via + # asterisk-{core,extra}-sounds and asterisk-moh-opsound. + # + >"${S}"/sounds/sounds.xml + + # Compile menuselect binary for optional components + emake menuselect.makeopts + + # Broken functionality is forcibly disabled (bug #360143) + menuselect/menuselect --disable chan_misdn menuselect.makeopts + + # Utility set is forcibly enabled (bug #358001) + menuselect/menuselect --enable smsq menuselect.makeopts + menuselect/menuselect --enable streamplayer menuselect.makeopts + menuselect/menuselect --enable aelparse menuselect.makeopts + menuselect/menuselect --enable astman menuselect.makeopts + + # The others are based on USE-flag settings + if use ais; then + menuselect/menuselect --enable res_ais menuselect.makeopts + else + menuselect/menuselect --disable res_ais menuselect.makeopts + fi + if use alsa; then + menuselect/menuselect --enable chan_alsa menuselect.makeopts + else + menuselect/menuselect --disable chan_alsa menuselect.makeopts + fi + if use bluetooth; then + menuselect/menuselect --enable chan_mobile menuselect.makeopts + else + menuselect/menuselect --disable chan_mobile menuselect.makeopts + fi + if use calendar; then + menuselect/menuselect --enable res_calendar menuselect.makeopts + menuselect/menuselect --enable res_calendar_caldav menuselect.makeopts + menuselect/menuselect --enable res_calendar_ews menuselect.makeopts + menuselect/menuselect --enable res_calendar_exchange menuselect.makeopts + menuselect/menuselect --enable res_calendar_icalendar menuselect.makeopts + else + menuselect/menuselect --disable res_calendar menuselect.makeopts + menuselect/menuselect --disable res_calendar_caldav menuselect.makeopts + menuselect/menuselect --disable res_calendar_ews menuselect.makeopts + menuselect/menuselect --disable res_calendar_exchange menuselect.makeopts + menuselect/menuselect --disable res_calendar_icalendar menuselect.makeopts + fi + if use curl; then + menuselect/menuselect --enable func_curl menuselect.makeopts + menuselect/menuselect --enable res_config_curl menuselect.makeopts + menuselect/menuselect --enable res_curl menuselect.makeopts + else + menuselect/menuselect --disable func_curl menuselect.makeopts + menuselect/menuselect --disable res_config_curl menuselect.makeopts + menuselect/menuselect --disable res_curl menuselect.makeopts + fi + if use dahdi; then + menuselect/menuselect --enable app_dahdibarge menuselect.makeopts + menuselect/menuselect --enable app_dahdiras menuselect.makeopts + menuselect/menuselect --enable chan_dahdi menuselect.makeopts + menuselect/menuselect --enable codec_dahdi menuselect.makeopts + menuselect/menuselect --enable res_timing_dahdi menuselect.makeopts + else + menuselect/menuselect --disable app_dahdibarge menuselect.makeopts + menuselect/menuselect --disable app_dahdiras menuselect.makeopts + menuselect/menuselect --disable chan_dahdi menuselect.makeopts + menuselect/menuselect --disable codec_dahdi menuselect.makeopts + menuselect/menuselect --disable res_timing_dahdi menuselect.makeopts + fi + if use freetds; then + menuselect/menuselect --enable cdr_tds menuselect.makeopts + menuselect/menuselect --enable cel_tds menuselect.makeopts + else + menuselect/menuselect --disable cdr_tds menuselect.makeopts + menuselect/menuselect --disable cel_tds menuselect.makeopts + fi + if use gtalk; then + menuselect/menuselect --enable chan_gtalk menuselect.makeopts + else + menuselect/menuselect --disable chan_gtalk menuselect.makeopts + fi + if use h323; then + menuselect/menuselect --enable chan_ooh323 menuselect.makeopts + else + menuselect/menuselect --disable chan_ooh323 menuselect.makeopts + fi + if use http; then + menuselect/menuselect --enable res_http_post menuselect.makeopts + else + menuselect/menuselect --disable res_http_post menuselect.makeopts + fi + if use iconv; then + menuselect/menuselect --enable func_iconv menuselect.makeopts + else + menuselect/menuselect --disable func_iconv menuselect.makeopts + fi + if use jabber; then + menuselect/menuselect --enable res_jabber menuselect.makeopts + else + menuselect/menuselect --disable res_jabber menuselect.makeopts + fi + if use jingle; then + menuselect/menuselect --enable chan_jingle menuselect.makeopts + else + menuselect/menuselect --disable chan_jingle menuselect.makeopts + fi + if use ldap; then + menuselect/menuselect --enable res_config_ldap menuselect.makeopts + else + menuselect/menuselect --disable res_config_ldap menuselect.makeopts + fi + if use lua; then + menuselect/menuselect --enable pbx_lua menuselect.makeopts + else + menuselect/menuselect --disable pbx_lua menuselect.makeopts + fi + if use mysql; then + menuselect/menuselect --enable app_mysql menuselect.makeopts + menuselect/menuselect --enable cdr_mysql menuselect.makeopts + menuselect/menuselect --enable res_config_mysql menuselect.makeopts + else + menuselect/menuselect --disable app_mysql menuselect.makeopts + menuselect/menuselect --disable cdr_mysql menuselect.makeopts + menuselect/menuselect --disable res_config_mysql menuselect.makeopts + fi + if use odbc; then + menuselect/menuselect --enable cdr_adaptive_odbc menuselect.makeopts + menuselect/menuselect --enable cdr_odbc menuselect.makeopts + menuselect/menuselect --enable cel_odbc menuselect.makeopts + menuselect/menuselect --enable func_odbc menuselect.makeopts + menuselect/menuselect --enable res_config_odbc menuselect.makeopts + menuselect/menuselect --enable res_odbc menuselect.makeopts + else + menuselect/menuselect --disable cdr_adaptive_odbc menuselect.makeopts + menuselect/menuselect --disable cdr_odbc menuselect.makeopts + menuselect/menuselect --disable cel_odbc menuselect.makeopts + menuselect/menuselect --disable func_odbc menuselect.makeopts + menuselect/menuselect --disable res_config_odbc menuselect.makeopts + menuselect/menuselect --disable res_odbc menuselect.makeopts + fi + if use osplookup; then + menuselect/menuselect --enable app_osplookup menuselect.makeopts + else + menuselect/menuselect --disable app_osplookup menuselect.makeopts + fi + if use oss; then + menuselect/menuselect --enable chan_oss menuselect.makeopts + else + menuselect/menuselect --disable chan_oss menuselect.makeopts + fi + if use postgres; then + menuselect/menuselect --enable cdr_pgsql menuselect.makeopts + menuselect/menuselect --enable cel_pgsql menuselect.makeopts + menuselect/menuselect --enable res_config_pgsql menuselect.makeopts + else + menuselect/menuselect --disable cdr_pgsql menuselect.makeopts + menuselect/menuselect --disable cel_pgsql menuselect.makeopts + menuselect/menuselect --disable res_config_pgsql menuselect.makeopts + fi + if use radius; then + menuselect/menuselect --enable cdr_radius menuselect.makeopts + menuselect/menuselect --enable cel_radius menuselect.makeopts + else + menuselect/menuselect --disable cdr_radius menuselect.makeopts + menuselect/menuselect --disable cel_radius menuselect.makeopts + fi + if use snmp; then + menuselect/menuselect --enable res_snmp menuselect.makeopts + else + menuselect/menuselect --disable res_snmp menuselect.makeopts + fi + if use span; then + menuselect/menuselect --enable res_fax_spandsp menuselect.makeopts + else + menuselect/menuselect --disable res_fax_spandsp menuselect.makeopts + fi + if use speex; then + menuselect/menuselect --enable codec_speex menuselect.makeopts + menuselect/menuselect --enable func_speex menuselect.makeopts + else + menuselect/menuselect --disable codec_speex menuselect.makeopts + menuselect/menuselect --disable func_speex menuselect.makeopts + fi + if use sqlite; then + menuselect/menuselect --enable cdr_sqlite menuselect.makeopts + else + menuselect/menuselect --disable cdr_sqlite menuselect.makeopts + fi + if use sqlite3; then + menuselect/menuselect --enable cdr_sqlite3_custom menuselect.makeopts + menuselect/menuselect --enable cel_sqlite3_custom menuselect.makeopts + else + menuselect/menuselect --disable cdr_sqlite3_custom menuselect.makeopts + menuselect/menuselect --disable cel_sqlite3_custom menuselect.makeopts + fi + if use srtp; then + menuselect/menuselect --enable res_srtp menuselect.makeopts + else + menuselect/menuselect --disable res_srtp menuselect.makeopts + fi + if use syslog; then + menuselect/menuselect --enable cdr_syslog menuselect.makeopts + else + menuselect/menuselect --disable cdr_syslog menuselect.makeopts + fi + if use usb; then + menuselect/menuselect --enable chan_usbradio menuselect.makeopts + else + menuselect/menuselect --disable chan_usbradio menuselect.makeopts + fi + if use vorbis; then + menuselect/menuselect --enable format_ogg_vorbis menuselect.makeopts + else + menuselect/menuselect --disable format_ogg_vorbis menuselect.makeopts + fi +} + +src_compile() { + ASTLDFLAGS="${LDFLAGS}" emake +} + +src_install() { + mkdir -p "${D}"usr/$(get_libdir)/pkgconfig || die + emake DESTDIR="${D}" installdirs + emake DESTDIR="${D}" install + + if use samples; then + emake DESTDIR="${D}" samples + for conffile in "${D}"etc/asterisk/*.* + do + chown asterisk:asterisk $conffile + chmod 0660 $conffile + done + einfo "Sample files have been installed" + else + einfo "Skipping installation of sample files..." + rm -f "${D}"var/lib/asterisk/mohmp3/* || die + rm -f "${D}"var/lib/asterisk/sounds/demo-* || die + rm -f "${D}"var/lib/asterisk/agi-bin/* || die + rm -f "${D}"etc/asterisk/* || die + fi + rm -rf "${D}"var/spool/asterisk/voicemail/default || die + + # keep directories + diropts -m 0770 -o asterisk -g asterisk + keepdir /etc/asterisk + keepdir /var/lib/asterisk + keepdir /var/run/asterisk + keepdir /var/spool/asterisk + keepdir /var/spool/asterisk/{system,tmp,meetme,monitor,dictate,voicemail} + diropts -m 0750 -o asterisk -g asterisk + keepdir /var/log/asterisk/{cdr-csv,cdr-custom} + + newinitd "${FILESDIR}"/1.8.0/asterisk.initd asterisk + newconfd "${FILESDIR}"/1.8.0/asterisk.confd asterisk + + # install the upgrade documentation + # + dodoc README UPGRADE* BUGS CREDITS + + # install extra documentation + # + if use doc + then + dodoc doc/*.txt + dodoc doc/*.pdf + fi + + # install SIP scripts; bug #300832 + # + dodoc "${FILESDIR}/1.6.2/sip_calc_auth" + dodoc "${FILESDIR}/1.6.2/find_call_sip_trace.sh" + dodoc "${FILESDIR}/1.6.2/find_call_ids.sh" + dodoc "${FILESDIR}/1.6.2/call_data.txt" + + # install logrotate snippet; bug #329281 + # + insinto /etc/logrotate.d + newins "${FILESDIR}/1.6.2/asterisk.logrotate3" asterisk +} + +pkg_postinst() { + # + # Announcements, warnings, reminders... + # + einfo "Asterisk has been installed" + echo + elog "If you want to know more about asterisk, visit these sites:" + elog "http://www.asteriskdocs.org/" + elog "http://www.voip-info.org/wiki-Asterisk" + echo + elog "http://www.automated.it/guidetoasterisk.htm" + echo + elog "Gentoo VoIP IRC Channel:" + elog "#gentoo-voip @ irc.freenode.net" + echo + echo + elog "1.6 -> 1.8 changes that you may care about:" + elog "http://svn.asterisk.org/svn/${PN}/tags/${PV}/UPGRADE.txt" + elog "or: bzless ${ROOT}usr/share/doc/${PF}/UPGRADE.txt.bz2" +} + +pkg_config() { + einfo "Do you want to reset file permissions and ownerships (y/N)?" + + read tmp + tmp="$(echo $tmp | tr '[:upper:]' '[:lower:]')" + + if [[ "$tmp" = "y" ]] ||\ + [[ "$tmp" = "yes" ]] + then + einfo "Resetting permissions to defaults..." + + for x in spool run lib log; do + chown -R asterisk:asterisk "${ROOT}"var/${x}/asterisk + chmod -R u=rwX,g=rwX,o= "${ROOT}"var/${x}/asterisk + done + + chown -R root:asterisk "${ROOT}"etc/asterisk + chmod -R u=rwX,g=rwX,o= "${ROOT}"etc/asterisk + + einfo "done" + else + einfo "skipping" + fi +} diff --git a/net-misc/asterisk/files/1.8.0/asterisk.confd b/net-misc/asterisk/files/1.8.0/asterisk.confd new file mode 100644 index 000000000000..e46ad2371eb8 --- /dev/null +++ b/net-misc/asterisk/files/1.8.0/asterisk.confd @@ -0,0 +1,95 @@ +# Copyright 1999-2011 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/net-misc/asterisk/files/1.8.0/asterisk.confd,v 1.1 2011/09/01 14:09:56 chainsaw Exp $ + +# +# Additional options for asterisk +# +# see "asterisk -h" for a list of options +# +ASTERISK_OPTS="" + +# +# User and group to run asterisk as +# +# Value: double-colon separated list of user and group, or empty to run as root: +# +# +# "asterisk:asterisk" to run as user "asterisk" and group "asterisk" +# +# "asterisk" to run as user "asterisk" and all groups that user "asterisk" is a member of +# +# ":asterisk" to run as user "root" and group "asterisk" +# +# "" to run as user "root" and group "root" +# +ASTERISK_USER="asterisk" + +# +# Nicelevel +# +# Set the priority of the asterisk process +# +# Value: (highest) -20..19 (lowest) +# +#ASTERISK_NICE="19" + +# Send crash notifications emails to this address +# (needs a working mail service and /usr/sbin/sendmail to do so (e.g. ssmtp)) +# +# Value: Email address or empty to disable +# +#ASTERISK_NOTIFY_EMAIL="root" + +# +# Send asterisk's output to this terminal +# +# Value: Full path to device node or a number +# +#ASTERISK_TTY="/dev/tty9" + +# +# Start an asterisk console on the terminal specified by ASTERISK_TTY +# +# Warning! Use only for debugging, this is a potential security issue! +# +# Value: yes or no/empty +# +ASTERISK_CONSOLE="no" + +# +# Maximum size of core files. +# +# Value: Size in bytes, unlimited for no limit or empty to disable. +# +ASTERISK_CORE_SIZE="unlimited" + +# +# ASTERISK_CORE_DIR +# +# Value: Directory (will be created if non-existant), default is /tmp +# +ASTERISK_CORE_DIR="/var/lib/asterisk/coredump" + +# +# Max number of filedescriptors +# +# Value: Number of descriptors +# +ASTERISK_MAX_FD="4096" + +# +# Delay time before restarting asterisk after a crash. +# +# Value: Number of seconds to sleep after a crash before restarting. +# +ASTERISK_RESTART_DELAY=5 + +# +# Kill these tasks after asterisk crashed +# +# Warning! This will kill _ALL_ tasks with the specified names! +# +# Value: Space separated list of names in double quotes (e.g. "mpg123 mad") +# +#ASTERISK_CLEANUP_ON_CRASH="mpg123 asterisk-mpg123 mad" diff --git a/net-misc/asterisk/files/1.8.0/asterisk.initd b/net-misc/asterisk/files/1.8.0/asterisk.initd new file mode 100644 index 000000000000..627fa88d3f92 --- /dev/null +++ b/net-misc/asterisk/files/1.8.0/asterisk.initd @@ -0,0 +1,273 @@ +#!/sbin/runscript +# Copyright 1999-2011 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/net-misc/asterisk/files/1.8.0/asterisk.initd,v 1.1 2011/09/01 14:09:56 chainsaw Exp $ + +opts="${opts} forcestop reload" + +depend() { + need net + use nscd dns dahdi mysql postgresql slapd capi +} + +is_running() { + if [ -z "`pidof asterisk`" ]; then + return 1 + else + PID="`cat /var/run/asterisk/asterisk.pid`" + for x in `pidof asterisk`; do + if [ "${x}" = "${PID}" ]; then + return 0 + fi + done + fi + + return 1 +} + +asterisk_run_loop() { + local result=0 signal=0 + + echo "Initializing asterisk wrapper" + OPTS="$*" + + trap "rm /var/run/asterisk/wrapper_loop.pid" EXIT + cut -f4 -d' ' < /proc/self/stat > /var/run/asterisk/wrapper_loop.pid + + while :; do + if [ -n "${TTY}" ]; then + /usr/bin/stty -F ${TTY} sane + ${NICE} /usr/sbin/asterisk ${OPTS} >${TTY} 2>&1 <${TTY} + result=$? + else + set -o pipefail + ${NICE} /usr/sbin/asterisk ${OPTS} 2>&1 >/dev/null + result=$? + set +o pipefail + fi + + if [ $result -eq 0 ]; then + echo "Asterisk terminated normally" + break + else + if [ $result -gt 128 ]; then + signal=`expr $result - 128` + MSG="Asterisk terminated with Signal: $signal" + + CORE_TARGET="core-`date +%Y%m%d-%H%M%S`" + + local CORE_DUMPED=0 + if [ -f "${ASTERISK_CORE_DIR}/core" ]; then + mv "${ASTERISK_CORE_DIR}/core" \ + "${ASTERISK_CORE_DIR}/${CORE_TARGET}" + CORE_DUMPED=1 + + elif [ -f "${ASTERISK_CORE_DIR}/core.${PID}" ]; then + mv "${ASTERISK_CORE_DIR}/core.${PID}" \ + "${ASTERISK_CORE_DIR}/${CORE_TARGET}" + CORE_DUMPED=1 + + fi + + [ $CORE_DUMPED -eq 1 ] && \ + MSG="${MSG}\n\rCore dumped: ${ASTERISK_CORE_DIR}/${CORE_TARGET}" + else + MSG="Asterisk terminated with return code: $result" + fi + + # kill left-over tasks + for X in ${ASTERISK_CLEANUP_ON_CRASH}; do + kill -9 `pidof ${X}`; + done + fi + + [ -n "${TTY}" ] \ + && echo "${MSG}" >${TTY} \ + || echo "${MSG}" + + + if [ -n "${ASTERISK_NOTIFY_EMAIL}" ] && \ + [ -x /usr/sbin/sendmail ]; then + echo -e -n "Subject: Asterisk crashed\n\r${MSG}\n\r" |\ + /usr/sbin/sendmail "${ASTERISK_NOTIFY_EMAIL}" + fi + sleep "${ASTERISK_RESTART_DELAY}" + echo "Restarting Asterisk..." + done + return 0 +} + +start() { + local OPTS USER GROUP PID NICE="" + local tmp x + + local OPTS ARGS + + ebegin "Starting asterisk PBX" + + eindent + + # filter (redundant) arguments + OPTS=`echo "${ASTERISK_OPTS}" | sed -re "s:-[cfF]::g"` + + # default options + OPTS="${OPTS} -f" # don't fork / detach breaks wrapper script... + + # mangle yes/no options + ASTERISK_CONSOLE="`echo ${ASTERISK_CONSOLE} | tr '[:lower:]' '[:upper:]'`" + + ASTERISK_RESTART_DELAY="`echo "${ASTERISK_RESTART_DELAY}" | sed -re 's/^([0-9]*).*/\1/'`" + [ -z "${ASTERISK_RESTART_DELAY}" ] && ASTERISK_RESTART_DELAY=5 + + if [ -n "${ASTERISK_CORE_SIZE}" ] && + [ "${ASTERISK_CORE_SIZE}" != "0" ]; then + ulimit -c ${ASTERISK_CORE_SIZE} + + if [ -n "${ASTERISK_CORE_DIR}" ] && \ + [ ! -d "${ASTERISK_CORE_DIR}" ] + then + mkdir -m750 -p "${ASTERISK_CORE_DIR}" + + if [ -n "${ASTERISK_USER}" ]; then + chown -R "${ASTERISK_USER}" "${ASTERISK_CORE_DIR}" + fi + fi + ASTERISK_CORE_DIR="${ASTERISK_CORE_DIR:-/tmp}" + + cd "${ASTERISK_CORE_DIR}" + einfo "Core dump size : ${ASTERISK_CORE_SIZE}" + einfo "Core dump location : ${ASTERISK_CORE_DIR}" + + OPTS="${OPTS} -g" + fi + + if [ -n "${ASTERISK_MAX_FD}" ]; then + ulimit -n ${ASTERISK_MAX_FD} + einfo "Max open filedescriptors : ${ASTERISK_MAX_FD}" + fi + + if [ -n "${ASTERISK_NICE}" ]; then + if [ ${ASTERISK_NICE} -ge -20 ] && \ + [ ${ASTERISK_NICE} -le 19 ]; then + einfo "Nice level : ${ASTERISK_NICE}" + NICE="nice -n ${ASTERISK_NICE} --" + else + eerror "Nice value must be between -20 and 19" + return 1 + fi + fi + + if [ -n "${ASTERISK_NOTIFY_EMAIL}" ]; then + if [ -x /usr/sbin/sendmail ]; then + einfo "Email notifications go to : ${ASTERISK_NOTIFY_EMAIL}" + else + ewarn "Notifications disabled, /usr/sbin/sendmail doesn't exist or is not executable!" + unset ASTERISK_NOTIFY_EMAIL + fi + fi + + if [ -n "${ASTERISK_TTY}" ]; then + for x in ${ASTERISK_TTY} \ + /dev/tty${ASTERISK_TTY} \ + /dev/vc/${ASTERISK_TTY} + do + if [ -c "${x}" ]; then + TTY="${x}" + fi + done + [ -n "${TTY}" ] && \ + einfo "Messages are sent to : ${TTY}" + fi + + if [ "${ASTERISK_CONSOLE}" = "YES" ] && [ -n "${TTY}" ]; then + einfo "Starting Asterisk console : ${ASTERISK_CONSOLE}" + OPTS="${OPTS} -c" + fi + + if [ -n "${ASTERISK_USER}" ]; then + USER=`echo $ASTERISK_USER | sed 's/:.*//'` + GROUP=`echo $ASTERISK_USER | awk -F: '/.*:.*/ { print $2 }'` + if [ -n "${USER}" ]; then + OPTS="${OPTS} -U ${USER}" + fi + if [ -n "${GROUP}" ]; then + OPTS="${OPTS} -G ${GROUP}" + GROUP=":${GROUP}" # make it look nice... + fi + for element in `find /var/{log,run}/asterisk`; do + if [ `stat -c %U $element` != "${USER}" ]; then + ewarn "${USER} is not the owner of $element, fixing." + chown -R ${USER} /var/{log,run}/asterisk + chmod -R u+r /var/{log,run}/asterisk + chmod u+x /var/{log,run}/asterisk + fi; + done; + einfo "Starting asterisk as : ${USER}${GROUP}" + else + ewarn "Starting asterisk as root is not recommended." + fi + + asterisk_run_loop ${OPTS} 2>&1 | logger -t asterisk_wrapper & + result=$? + + if [ $result -eq 0 ]; then + # 2 seconds should be enough for asterisk to start + sleep 2 + is_running + result=$? + fi + + eoutdent + eend $result +} + +forcestop() { + ebegin "Stopping asterisk PBX" + start-stop-daemon --stop --pidfile /var/run/asterisk/asterisk.pid + eend $? +} + +stop() { + if ! is_running; then + eerror "Asterisk is not running!" + return 0 + fi + + if [ -r /var/run/asterisk/wrapper_loop.pid ]; then + ebegin "Killing wrapper script" + kill `cat /var/run/asterisk/wrapper_loop.pid` + eend $? + fi + + ebegin "Stopping asterisk PBX gracefully" + /usr/sbin/asterisk -r -x "core stop gracefully" &>/dev/null + # Now we have to wait until asterisk has _really_ stopped. + sleep 1 + if is_running; then + einfon "Waiting for asterisk to shutdown ." + local cnt=0 + while is_running; do + cnt=`expr $cnt + 1` + if [ $cnt -gt 60 ] ; then + # Waited 120 seconds now. Fail. + echo + eend 1 "Failed." + return + fi + sleep 2 + echo -n "." + done + echo + fi + eend 0 +} + +reload() { + if is_running; then + ebegin "Forcing asterisk to reload configuration" + /usr/sbin/asterisk -r -x "module reload" &>/dev/null + eend $? + else + eerror "Asterisk is not running!" + fi +} |