commit:     b06dd7a7632c479976144dfb3f3cdcd0ef89e1ad
Author:     Jaco Kroon <jaco <AT> uls <DOT> co <DOT> za>
AuthorDate: Wed Nov 10 07:41:33 2021 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Nov 12 01:32:55 2021 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b06dd7a7

net-misc/asterisk: 16.22.0

Bug: https://bugs.gentoo.org/822084
Package-Manager: Portage-3.0.28, Repoman-3.0.3
Signed-off-by: Jaco Kroon <jaco <AT> uls.co.za>
Signed-off-by: Sam James <sam <AT> gentoo.org>

 net-misc/asterisk/Manifest                         |   1 +
 net-misc/asterisk/asterisk-16.22.0.ebuild          | 366 +++++++++++++++++++++
 .../files/asterisk.tmpfiles-16.22.0-18.8.0.conf    |   2 +
 net-misc/asterisk/files/initd-16.22.0-18.8.0       | 363 ++++++++++++++++++++
 4 files changed, 732 insertions(+)

diff --git a/net-misc/asterisk/Manifest b/net-misc/asterisk/Manifest
index 8691e94e2c5..f0c07322a8a 100644
--- a/net-misc/asterisk/Manifest
+++ b/net-misc/asterisk/Manifest
@@ -2,6 +2,7 @@ DIST asterisk-13.38.3.tar.gz 33711458 BLAKE2B 
a1f37c210e7e95962665310b542d9a3b68
 DIST asterisk-16.19.1.tar.gz 27870922 BLAKE2B 
e7b2ceac60f9db19802acc6c69b233556834815e1a9a3d17b2fd331d2577beb356f31a531a6d8fde70f78e9362bd8b6dbc796f906557c82bcd4847a612c788a3
 SHA512 
7b74fedce91ac597f3cc7a03b401ae7506bc6479faf008f3ea9c0f4783d85c5ce06d71bf73333d4bc1609a2cb96511d931d79f3bc8613906f370f9b4015b30b9
 DIST asterisk-16.20.0.tar.gz 27888074 BLAKE2B 
74f7812db787e5dcb041850fc7e80229e05ef0849cf373be29f9a3ac2eb0f2244fc6f2bd2a3f411c4d37d968184dfbc140e55ad62de53e6beb0b2340179b831c
 SHA512 
0e270c2d00eda1aea3135eba427a77ac2abe66a31c868cf700d5cc26bde65fded6f2191d5e4af361b2e055ae04f2943611ca1fa19815a4a690076a83fb899148
 DIST asterisk-16.21.1.tar.gz 27912610 BLAKE2B 
75b93fbde52d72906bb613b1d42b7fe592fac9a6af76aabb11dab1bb15b2ad8134f8cfe0a9a58f5f72928e046b0b6111d8e899909d6baca3fd820b583c6acd35
 SHA512 
399875d3e70e2ebae8b27edc9d97b485d7acfe7a99c1f6e2a6212ccac9cd77fd4e720ccb1cf4d16a441fb8f894d8b9a64785c48bc606a0cfd105d2b7ab16d766
+DIST asterisk-16.22.0.tar.gz 27925083 BLAKE2B 
ce700f8924fb2c7c8fc521879c0768595eb7462bb3aa78dd8b64c8a268b357e522ece17c6c4a02a4e17c16bad5141d5c2c15b602d335567be5a3df49f67300ca
 SHA512 
7032da647f4063320fb2ea9c3cd7b0079fbb907e5c8f9d5cdc4197c82d07c99c75bfdcace5c74a593573cd0d9a1b9eb73b2030dc0b13604abb481a311a742173
 DIST asterisk-18.5.1.tar.gz 27953748 BLAKE2B 
543f2bfbe1527f3a168dc73d3d9f20e80e95be9de9532a97ff6a5c70a548d525c39ce5251b80dbcd1c0e31c066fc48520e6c373b1404bf24a00b0a48ad134bcd
 SHA512 
95f30c14602587827c7d7bc4652639163f4fe6338fade35d533525aa8825d7a5082c9d6fa4671a5f4f89bd90a0d657ce7e51fd4216558bd367abcb10b25aeb23
 DIST asterisk-18.6.0.tar.gz 27970531 BLAKE2B 
a2eaecc962b236e6e455b8d305c05f33fab8e4d6c63eae1506b8354710d6e3e0e3c6da59600555d880520bb58a13950f830057ac03bc82628ab27b2627de52c9
 SHA512 
17ad7e4dc86f75d4e70f779b6fe6958ee544233b20a36847a6624a7f07b135ddb415f5dca245843ea359e9a6a7c75bfc40ce36fca1df5a7a12549ae522fa2590
 DIST asterisk-18.7.1.tar.gz 27995503 BLAKE2B 
edc13b33243507114fbf2a514fb67d462ca2f8095e4eba95dccd194b4495c3be256ddff280b7400182fed7ffc4d0a462c687f5a23e2162933e0603464e851d54
 SHA512 
5e08ed7e95d00538fd24ed46644818d690fe8c5b8f8d6b9a7d01120c7de28138372f8e166950730b65bd0ffc3e1028af89377bde598bee549ca86d369f9427df

diff --git a/net-misc/asterisk/asterisk-16.22.0.ebuild 
b/net-misc/asterisk/asterisk-16.22.0.ebuild
new file mode 100644
index 00000000000..735b5ef050f
--- /dev/null
+++ b/net-misc/asterisk/asterisk-16.22.0.ebuild
@@ -0,0 +1,366 @@
+# Copyright 1999-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+LUA_COMPAT=( lua5-{1..4} )
+
+inherit autotools linux-info lua-single systemd toolchain-funcs tmpfiles
+
+DESCRIPTION="Asterisk: A Modular Open Source PBX System"
+HOMEPAGE="https://www.asterisk.org/";
+SRC_URI="https://downloads.asterisk.org/pub/telephony/asterisk/releases/${P}.tar.gz";
+LICENSE="GPL-2"
+SLOT="0/${PV%%.*}"
+KEYWORDS="~amd64 ~arm ~arm64 ~ppc ~ppc64 ~x86"
+
+IUSE_VOICEMAIL_STORAGE=(
+       +voicemail_storage_file
+       voicemail_storage_odbc
+       voicemail_storage_imap
+)
+IUSE="${IUSE_VOICEMAIL_STORAGE[*]} alsa blocks bluetooth calendar +caps 
cluster codec2 curl dahdi debug deprecated doc freetds gtalk http iconv ilbc 
ldap lua mysql newt odbc oss pjproject portaudio postgres radius selinux snmp 
span speex srtp +ssl static statsd syslog systemd unbound vorbis xmpp"
+IUSE_EXPAND="VOICEMAIL_STORAGE"
+REQUIRED_USE="gtalk? ( xmpp )
+       lua? ( ${LUA_REQUIRED_USE} )
+       ^^ ( ${IUSE_VOICEMAIL_STORAGE[*]//+/} )
+       voicemail_storage_odbc? ( odbc )
+"
+
+PATCHES=(
+       "${FILESDIR}/${PN}-16.16.2-no-var-run-install.patch"
+)
+
+DEPEND="acct-user/asterisk
+       acct-group/asterisk
+       dev-db/sqlite:3
+       dev-libs/popt
+       >=dev-libs/jansson-2.11:=
+       dev-libs/libedit
+       dev-libs/libxml2:2
+       dev-libs/libxslt
+       sys-apps/util-linux
+       sys-libs/zlib
+       virtual/libcrypt:=
+       alsa? ( media-libs/alsa-lib )
+       bluetooth? ( net-wireless/bluez:= )
+       calendar? (
+               net-libs/neon:=
+               dev-libs/libical:=
+               dev-libs/iksemel
+       )
+       caps? ( sys-libs/libcap )
+       blocks? ( sys-libs/blocksruntime )
+       cluster? ( sys-cluster/corosync )
+       codec2? ( media-libs/codec2:= )
+       curl? ( net-misc/curl )
+       dahdi? (
+               net-libs/libpri
+               net-misc/dahdi-tools
+       )
+       freetds? ( dev-db/freetds )
+       gtalk? ( dev-libs/iksemel )
+       http? ( dev-libs/gmime:2.6 )
+       iconv? ( virtual/libiconv )
+       ilbc? ( media-libs/libilbc )
+       ldap? ( net-nds/openldap )
+       lua? ( ${LUA_DEPS} )
+       mysql? ( dev-db/mysql-connector-c:= )
+       newt? ( dev-libs/newt )
+       odbc? ( dev-db/unixODBC )
+       pjproject? ( >=net-libs/pjproject-2.9:= )
+       portaudio? ( media-libs/portaudio )
+       postgres? ( dev-db/postgresql:* )
+       radius? ( net-dialup/freeradius-client )
+       snmp? ( net-analyzer/net-snmp:= )
+       span? ( media-libs/spandsp )
+       speex? (
+               media-libs/libogg
+               media-libs/speex
+               media-libs/speexdsp
+       )
+       srtp? ( net-libs/libsrtp:0 )
+       ssl? (
+               dev-libs/openssl:0=
+       )
+       systemd? ( sys-apps/systemd )
+       !systemd? ( !sys-apps/systemd )
+       unbound? ( net-dns/unbound )
+       vorbis? (
+               media-libs/libogg
+               media-libs/libvorbis
+       )
+       voicemail_storage_imap? ( virtual/imap-c-client )
+       xmpp? ( dev-libs/iksemel )
+"
+
+RDEPEND="${DEPEND}
+       net-misc/asterisk-core-sounds
+       net-misc/asterisk-extra-sounds
+       net-misc/asterisk-moh-opsound
+       selinux? ( sec-policy/selinux-asterisk )
+       syslog? ( virtual/logger )"
+
+BDEPEND="dev-libs/libxml2:2
+       virtual/pkgconfig"
+
+QA_DT_NEEDED="/usr/lib.*/libasteriskssl[.]so[.][0-9]\+"
+
+_make_args=(
+       "NOISY_BUILD=yes"
+       "ASTDBDIR=\$(ASTDATADIR)/astdb"
+       "ASTVARRUNDIR=/run/asterisk"
+       "ASTCACHEDIR=/var/cache/asterisk"
+       "OPTIMIZE="
+       "DEBUG="
+       "DESTDIR=${D}"
+       "CONFIG_SRC=configs/samples"
+       "CONFIG_EXTEN=.sample"
+)
+
+pkg_pretend() {
+       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
+
+       [[ "${MERGE_TYPE}" == binary ]] && return
+
+       if tc-is-clang; then
+               use blocks || die "CC=clang requires USE=blocks"
+       else
+               use blocks && die "USE=blocks can only be used with CC=clang"
+       fi
+}
+
+pkg_setup() {
+       use lua && lua-single_pkg_setup
+}
+
+src_prepare() {
+       default
+       AT_M4DIR="autoconf third-party third-party/pjproject 
third-party/jansson" eautoreconf
+}
+
+src_configure() {
+       local vmst
+       local copt cstate
+
+       econf \
+               LUA_VERSION="${ELUA#lua}" \
+               --libdir="/usr/$(get_libdir)" \
+               --localstatedir="/var" \
+               --with-crypto \
+               --with-gsm=internal \
+               --with-popt \
+               --with-z \
+               --with-libedit \
+               --without-jansson-bundled \
+               --without-pjproject-bundled \
+               $(use_with caps cap) \
+               $(use_with codec2) \
+               $(use_with lua lua) \
+               $(use_with http gmime) \
+               $(use_with newt) \
+               $(use_with pjproject) \
+               $(use_with portaudio) \
+               $(use_with ssl) \
+               $(use_with unbound)
+
+       _menuselect() {
+               menuselect/menuselect "$@" || die "menuselect $* failed."
+       }
+
+       _use_select() {
+               local state=$(use "$1" && echo enable || echo disable)
+               shift # remove use from parameters
+
+               while [[ -n $1 ]]; do
+                       _menuselect --${state} "$1" menuselect.makeopts
+                       shift
+               done
+       }
+
+       # 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
+
+       # That NATIVE_ARCH chatter really is quite bothersome
+       sed -i 's/NATIVE_ARCH=/NATIVE_ARCH=0/' build_tools/menuselect-deps || 
die "Unable to squelch noisy build system"
+
+       # Compile menuselect binary for optional components
+       emake "${_make_args[@]}" menuselect.makeopts
+
+       # Disable BUILD_NATIVE (bug #667498)
+       _menuselect --disable build_native menuselect.makeopts
+
+       # Broken functionality is forcibly disabled (bug #360143)
+       _menuselect --disable chan_misdn menuselect.makeopts
+       _menuselect --disable chan_ooh323 menuselect.makeopts
+
+       # Utility set is forcibly enabled (bug #358001)
+       _menuselect --enable smsq menuselect.makeopts
+       _menuselect --enable streamplayer menuselect.makeopts
+       _menuselect --enable aelparse menuselect.makeopts
+       _menuselect --enable astman menuselect.makeopts
+
+       # this is connected, otherwise it would not find
+       # ast_pktccops_gate_alloc symbol
+       _menuselect --enable chan_mgcp menuselect.makeopts
+       _menuselect --enable res_pktccops menuselect.makeopts
+
+       # SSL is forcibly enabled, IAX2 & DUNDI are expected to be available
+       _menuselect --enable pbx_dundi menuselect.makeopts
+       _menuselect --enable func_aes menuselect.makeopts
+       _menuselect --enable chan_iax2 menuselect.makeopts
+
+       # SQlite3 is now the main database backend, enable related features
+       _menuselect --enable cdr_sqlite3_custom menuselect.makeopts
+       _menuselect --enable cel_sqlite3_custom menuselect.makeopts
+
+       # The others are based on USE-flag settings
+       _use_select alsa         chan_alsa
+       _use_select bluetooth    chan_mobile
+       _use_select calendar     res_calendar 
res_calendar_{caldav,ews,exchange,icalendar}
+       _use_select cluster      res_corosync
+       _use_select codec2       codec_codec2
+       _use_select curl         func_curl res_config_curl res_curl
+       _use_select dahdi        app_dahdiras app_meetme chan_dahdi codec_dahdi 
res_timing_dahdi
+       _use_select deprecated   app_macro
+       _use_select freetds      {cdr,cel}_tds
+       _use_select gtalk        chan_motif
+       _use_select http         res_http_post
+       _use_select iconv        func_iconv
+       _use_select ilbc         codec_ilbc format_ilbc
+       _use_select ldap         res_config_ldap
+       _use_select lua          pbx_lua
+       _use_select mysql        app_mysql cdr_mysql res_config_mysql
+       _use_select odbc         cdr_adaptive_odbc res_config_odbc 
{cdr,cel,res,func}_odbc
+       _use_select oss          chan_oss
+       _use_select postgres     {cdr,cel}_pgsql res_config_pgsql
+       _use_select radius       {cdr,cel}_radius
+       _use_select snmp         res_snmp
+       _use_select span         res_fax_spandsp
+       _use_select speex        {codec,func}_speex
+       _use_select speex        format_ogg_speex
+       _use_select srtp         res_srtp
+       _use_select statsd       res_statsd res_{endpoint,chan}_stats
+       _use_select syslog       cdr_syslog
+       _use_select vorbis       format_ogg_vorbis
+       _use_select xmpp         res_xmpp
+
+       # Voicemail storage ...
+       for vmst in "${IUSE_VOICEMAIL_STORAGE[@]}"; do
+               if use "${vmst#+}"; then
+                       _menuselect --enable "$(echo "${vmst##*_}" | tr 
'[:lower:]' '[:upper:]')_STORAGE" menuselect.makeopts
+               fi
+       done
+
+       if use debug; then
+               for o in DONT_OPTIMIZE DEBUG_FD_LEAKS MALLOC_DEBUG 
BETTER_BACKTRACES; do
+                       _menuselect --enable "${o}" menuselect.makeopts
+               done
+       fi
+
+       if [[ -n "${GENTOO_ASTERISK_CUSTOM_MENUSELECT:+yes}" ]]; then
+               for copt in ${GENTOO_ASTERISK_CUSTOM_MENUSELECT}; do
+                       cstate=--enable
+                       [[ "${copt}" == -* ]] && cstate=--disable
+                       ebegin "Custom option ${copt#[-+]} ${cstate:2}d"
+                       _menuselect ${cstate} "${copt#[-+]}"
+                       eend $?
+               done
+       fi
+}
+
+src_compile() {
+       emake "${_make_args[@]}"
+}
+
+src_install() {
+       local d
+
+       dodir "/usr/$(get_libdir)/pkgconfig"
+
+       diropts -m 0750 -o root -g asterisk
+       dodir /etc/asterisk
+
+       emake "${_make_args[@]}" install install-configs
+
+       fowners asterisk: /var/lib/asterisk/astdb
+
+       if use radius; then
+               insinto /etc/radiusclient/
+               doins contrib/dictionary.digium
+       fi
+
+       # keep directories
+       diropts -m 0750 -o asterisk -g root
+       keepdir 
/var/spool/asterisk/{system,tmp,meetme,monitor,dictate,voicemail,recording,outgoing}
+       diropts -m 0750 -o asterisk -g asterisk
+       keepdir /var/log/asterisk/{cdr-csv,cdr-custom}
+
+       newinitd "${FILESDIR}"/initd-16.22.0-18.8.0 asterisk
+       newconfd "${FILESDIR}"/confd-16.16.2-r1 asterisk
+
+       systemd_dounit "${FILESDIR}"/asterisk.service
+       newtmpfiles "${FILESDIR}"/asterisk.tmpfiles-16.22.0-18.8.0.conf 
asterisk.conf
+       systemd_install_serviced "${FILESDIR}"/asterisk.service.conf
+
+       # Reset diropts else dodoc uses it for doc installations.
+       diropts -m0755
+
+       # install the upgrade documentation
+       dodoc UPGRADE* BUGS CREDITS
+
+       # install extra documentation
+       use doc && dodoc doc/*.{txt,pdf}
+
+       # install logrotate snippet; bug #329281
+       #
+       insinto /etc/logrotate.d
+       newins "${FILESDIR}/1.6.2/asterisk.logrotate4" asterisk
+
+       # Asterisk installs a few folders that's empty by design,
+       # but still required.  This finds them, and marks them for
+       # portage.
+       while read d <&3; do
+               keepdir "${d#${ED}}"
+       done 3< <(find "${ED}"/var -type d -empty || die "Find failed.")
+}
+
+pkg_postinst() {
+       tmpfiles_process asterisk.conf
+
+       if [ -z "${REPLACING_VERSIONS}" ]; then
+               elog "Asterisk Wiki: https://wiki.asterisk.org/wiki/";
+               elog "Gentoo VoIP IRC Channel: #gentoo-voip @ irc.libera.chat"
+       elif [ "$(ver_cut 1 "${REPLACING_VERSIONS}")" != "$(ver_cut 1)" ]; then
+               elog "You are updating from Asterisk $(ver_cut 1 
"${REPLACING_VERSIONS}") upgrade document:"
+               elog 
"https://wiki.asterisk.org/wiki/display/AST/Upgrading+to+Asterisk+$(ver_cut 1)"
+               elog "Gentoo VoIP IRC Channel: #gentoo-voip @ irc.libera.chat"
+       fi
+
+       if use deprecated; then
+               ewarn "You really aught to port whatever code you have that 
depends on this since these are going to go away."
+               ewarn "Refer: 
https://wiki.asterisk.org/wiki/display/AST/Module+Deprecation";
+       fi
+
+       if [[ -n "${GENTOO_ASTERISK_CUSTOM_MENUSELECT:+yes}" ]]; then
+               ewarn "You are using GENTOO_ASTERISK_CUSTOM_MENUSELECT, this 
should only be used"
+               ewarn "for debugging, for anything else, please file a bug on 
https://bugs.gentoo.org";
+       fi
+
+       if [[ -f /var/lib/asterisk/astdb.sqlite3 ]]; then
+               ewarn "Default astdb location has changed from 
/var/lib/asterisk to /var/lib/asterisk/astdb"
+               ewarn "You still have a /var/lib/asterisk/astdb.sqlite file.  
You need to either set"
+               ewarn "astdbdir in /etc/asterisk/asterisk.conf to 
/var/lib/asterisk or follow these"
+               ewarn "steps to migrate:"
+               ewarn "1.  /etc/init.d/asterisk stop"
+               ewarn "2.  mv /var/lib/asterisk/astdb.sqlite 
/var/lib/asterisk/astdb/"
+               ewarn "3.  /etc/init.d/asterisk start"
+               ewarn "This update was done partly for security reasons so that 
/var/lib/asterisk can be root owned."
+       fi
+}

diff --git a/net-misc/asterisk/files/asterisk.tmpfiles-16.22.0-18.8.0.conf 
b/net-misc/asterisk/files/asterisk.tmpfiles-16.22.0-18.8.0.conf
new file mode 100644
index 00000000000..224d060a3c9
--- /dev/null
+++ b/net-misc/asterisk/files/asterisk.tmpfiles-16.22.0-18.8.0.conf
@@ -0,0 +1,2 @@
+d /run/asterisk 0750 asterisk asterisk
+d /var/cache/asterisk 0750 asterisk asterisk

diff --git a/net-misc/asterisk/files/initd-16.22.0-18.8.0 
b/net-misc/asterisk/files/initd-16.22.0-18.8.0
new file mode 100644
index 00000000000..ed6fa8bca74
--- /dev/null
+++ b/net-misc/asterisk/files/initd-16.22.0-18.8.0
@@ -0,0 +1,363 @@
+#!/sbin/openrc-run
+# Copyright 1999-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+extra_started_commands="forcestop reload"
+
+depend() {
+       need net
+       use nscd dns dahdi mysql postgresql slapd capi
+}
+
+is_running() {
+       [ -r "${ast_rundir}/asterisk.pid" ] || return 1
+       PID="$(cat "${ast_rundir}/asterisk.pid")"
+       [ -d "/proc/${PID}" ] || return 1
+       EXE="$(readlink -f /proc/${PID}/exe)"
+       EXE="${EXE% (deleted)}" # in case asterisk got upgraded and we're still 
looking at an old one.
+       [ "${EXE}" = /usr/sbin/asterisk ] || return 1 # pid got re-used for 
another process.
+
+       # PID reported in pidfile is active, and is still an asterisk instance.
+       return 0
+}
+
+# Sets up a few variables for us for use
+# ast_instancename: eg, asterisk when RC_SVCNAME=asterisk, or asterisk(foo) 
when asterisk.foo.
+# ast_rundir: directory to be used as run folder (pid and ctl files).
+setup_svc_variables()
+{
+       local t
+
+       ast_instancename=asterisk
+       ast_rundir=/run/${RC_SVCNAME}
+       ast_logdir=/var/log/${RC_SVCNAME}
+       ast_confdir=/etc/${RC_SVCNAME/.//}
+       ast_cachedir=/var/cache/asterisk
+       ast_stop_timeout=120
+       ast_stop_method="gracefully"
+
+       if [ "${RC_SVCNAME}" != "asterisk" ]; then
+               t="${RC_SVCNAME#asterisk.}"
+               if [ "${RC_SVCNAME}" = "${t}" ]; then
+                       eerror "Invalid SVCNAME of ${RC_SVCNAME}, must be of 
the format asterisk.name."
+                       return 1
+               fi
+               ast_instancename+="(${t})"
+       fi
+
+       [ -n "${ASTERISK_RUNDIR}" ] && ast_rundir="${ASTERISK_RUNDIR}"
+       [ -n "${ASTERISK_LOGDIR}" ] && ast_logdir="${ASTERISK_LOGDIR}"
+       [ -n "${ASTERISK_CONFDIR}" ] && ast_confdir="${ASTERISK_CONFDIR}"
+       [ -n "${ASTERISK_CACHEDIR}" ] && ast_confdir="${ASTERISK_CACHEDIR}"
+       [ -n "${ASTERISK_STOP_TIMEOUT}" ] && 
ast_stop_timeout="${ASTERISK_STOP_TIMEOUT}"
+       case "${ASTERISK_STOP_METHOD}" in
+               gracefully|when\ convenient|now)
+                       ast_stop_method="${ASTERISK_STOP_METHOD}"
+               ;;
+       esac
+       ast_group=
+       if [ -n "${ASTERISK_USER}" ]; then
+               ast_user="${ASTERISK_USER%%:*}"
+               if [ "${ast_user}" != "${ASTERISK_USER}" ]; then
+                       ast_group="${ASTERISK_USER#*:}"
+                       ast_group="${ast_group%%:*}"
+               fi
+       fi
+
+       [ -z "${ast_user}" ] && ast_user=asterisk
+
+       ast_pgroup="$(getent group $(getent passwd "${ast_user}" | awk -F: '{ 
print $4 }') | sed -re 's/:.*//')"
+
+       return 0
+}
+
+asterisk_run_loop() {
+       local result=0 signal=0
+
+       echo "Initializing ${ast_instancename} wrapper"
+       OPTS="$*"
+
+       trap "rm -f '${ast_rundir}/wrapper_loop.running'" EXIT
+       touch "${ast_rundir}/wrapper_loop.running"
+
+       while [ -r "${ast_rundir}/wrapper_loop.running" ]; do
+               if [ -n "${TTY}" ]; then
+                       /usr/bin/stty -F "${TTY}" sane
+                       ${NICE} /usr/sbin/asterisk -C 
"${ast_confdir}/asterisk.conf" ${OPTS} >"${TTY}" 2>&1 <"${TTY}"
+                       result=$?
+               else
+                       ${NICE} /usr/sbin/asterisk -C 
"${ast_confdir}/asterisk.conf" ${OPTS} >/dev/null 2>&1
+                       result=$?
+               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-"
+                               yesno "${ASTERISK_CORE_USEHOSTNAME}" && 
CORE_TARGET+="$(hostname)-"
+                               CORE_TARGET+="$(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\r\n${MSG}\r\n" |\
+                                /usr/sbin/sendmail "${ASTERISK_NOTIFY_EMAIL}"
+               fi
+               sleep "${ASTERISK_RESTART_DELAY}"
+               echo "Restarting Asterisk..."
+       done
+
+       echo "Terminating wrapper loop."
+       return 0
+}
+
+start() {
+       local OPTS PID
+       local tmp x
+
+       local OPTS ARGS
+
+       setup_svc_variables || return $?
+
+       ebegin "Starting ${ast_instancename} 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...
+
+       # ensure that ASTERISK_RESTART_DELAY is integer.
+       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
+                       checkpath -d -m 0755 -o ${ast_user}:${ast_group} 
"${ASTERISK_CORE_DIR}"
+               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
+       else
+               NICE=""
+       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 yesno "${ASTERISK_CONSOLE}" && [ -n "${TTY}" ]; then
+               einfo "Starting Asterisk console : Yes"
+               OPTS="${OPTS} -c"
+       fi
+
+       if ! getent passwd "${ast_user}" &>/dev/null; then
+               eerror "Requested to run asterisk as ${ast_user}, which doesn't 
exist."
+               return 1
+       fi
+       OPTS="${OPTS} -U ${ast_user}"
+
+       if [ -n "${ast_group}" ] && ! getent group "${ast_group}" &>/dev/null; 
then
+               eerror "Requested to run ${ast_instancename} with group 
${ast_group}, which doesn't exist."
+               return 1
+       fi
+       [ -n "${ast_group}" ] && OPTS="${OPTS} -G ${ast_group}"
+
+       if [ "${ast_user}" = root ]; then
+               ewarn "Starting asterisk as root is not recommended (SERIOUS 
SECURITY CONSIDERATIONS)."
+       elif [ "${ast_group}" = root ]; then
+               ewarn "Starting asterisk with group root is not recommended 
(SERIOUS SECURITY CONSIDERATIONS)."
+       fi
+
+       checkpath -d -m 0755 -o "${ast_user}:${ast_group}" "${ast_logdir}" 
"${ast_rundir}"
+       checkpath -d -m 0750 -o "${ast_user}:${ast_group}" "${ast_cachedir}"
+
+       einfo "Starting asterisk as      : 
${ast_user}:${ast_group:-${ast_pgroup} (+supplementaries)}"
+       asterisk_run_loop ${OPTS} 2>&1 | logger -t 
"wrapper:${ast_instancename}" &>/dev/null &
+       result=$?
+
+       if [ $result -eq 0 ]; then
+               # 2 seconds should be enough for asterisk to start
+               sleep 2
+               is_running
+               result=$?
+
+               [ $result -eq 0 ] || wrapperstop
+       fi
+
+       eoutdent
+       eend $result
+
+       if [ $result -eq 0 ] && yesno "${ASTERISK_WAITBOOTED}"; then
+               if [ ! -r "${ast_rundir}/asterisk.ctl" ]; then
+                       # asterisk can crash during startup ...
+                       ebegin "Waiting for ctl file to appear"
+                       while is_running && [ ! -r "${ast_rundir}/asterisk.ctl" 
]; do
+                               sleep 1
+                       done
+                       is_running
+                       result=$?
+                       eend $result
+               fi
+               if [ $result -eq 0 ]; then
+                       ebegin "Waiting for ${ast_instancename} to fully boot"
+                       /usr/sbin/asterisk -C "${ast_confdir}/asterisk.conf" -r 
-x "core waitfullybooted" &>/dev/null
+                       eend $?
+               fi
+       fi
+
+       return $result
+}
+
+wrapperstop() {
+       # Accomodate system upgrades (so a previous version of the wrapper 
script that still uses a pid file may be running).
+       if [ -r "${ast_rundir}/wrapper_loop.pid" ]; then
+               ebegin "Killing ${ast_instancename} wrapper script"
+               kill "$(cat /run/asterisk/wrapper_loop.pid)"
+               eend $?
+       fi
+
+       # The new one (due to "hardened" requirements) uses a simpler
+       # flag to indicate running or shutting down.
+       if [ -r "${ast_rundir}/wrapper_loop.running" ]; then
+               ebegin "Signalling ${ast_instancename} wrapper script to 
terminate"
+               rm "${ast_rundir}/wrapper_loop.running"
+               eend $?
+       fi
+
+       return 0
+}
+
+forcestop() {
+       setup_svc_variables || return $?
+
+       # Just to be sure - when we want to forcestop we should make it all 
tear down.
+       wrapperstop
+
+       ebegin "Stopping ${ast_instancename} PBX"
+       start-stop-daemon --stop --pidfile /run/asterisk/asterisk.pid
+       eend $?
+}
+
+stop() {
+       setup_svc_variables || return $?
+
+       wrapperstop
+
+       if ! is_running; then
+               eerror "${ast_instancename} is not running!"
+               return 0
+       fi
+
+       ebegin "Stopping ${ast_instancename} PBX ${ast_stop_method}"
+       /usr/sbin/asterisk -C "${ast_confdir}/asterisk.conf" -r -x "core stop 
${ast_stop_method}" &>/dev/null
+       # Now we have to wait until asterisk has _really_ stopped.
+       sleep 1
+       if is_running; then
+               einfon "Waiting for ${ast_instancename} to shutdown ."
+               local cnt=0
+               while is_running; do
+                       cnt="$(expr $cnt + 2)"
+                       if [ ${ast_stop_timeout} -gt 0 -a $cnt -gt 
${ast_stop_timeout} ] ; then
+                               echo
+                               eend 1 "Failed waiting for ${ast_instancename} 
to stop."
+                               return 1
+                       fi
+                       sleep 2
+                       echo -n "."
+               done
+               echo
+       fi
+       eend 0
+}
+
+reload() {
+       setup_svc_variables || return $?
+
+       if is_running; then
+               ebegin "Forcing ${ast_instancename} to reload configuration"
+               /usr/sbin/asterisk -C "${ast_confdir}/asterisk.conf" -r -x 
"module reload" &>/dev/null
+               eend $?
+       else
+               eerror "${ast_instancename} is not running!"
+       fi
+}

Reply via email to