commit:     de4e9bccfe1cce7643756077e100100ef41f7ddb
Author:     Jaco Kroon <jaco <AT> uls <DOT> co <DOT> za>
AuthorDate: Tue Aug 13 09:45:57 2024 +0000
Commit:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
CommitDate: Tue Aug 13 16:57:45 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=de4e9bcc

net-misc/asterisk: back-port security fix for 16.30.1

Bug: https://bugs.gentoo.org/937844
Signed-off-by: Jaco Kroon <jaco <AT> uls.co.za>
Closes: https://github.com/gentoo/gentoo/pull/38129
Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>

 net-misc/asterisk/asterisk-16.30.1-r3.ebuild       | 361 +++++++++++++++++++++
 ...ager.c-Add-entries-to-Originate-blacklist.patch | 205 ++++++++++++
 2 files changed, 566 insertions(+)

diff --git a/net-misc/asterisk/asterisk-16.30.1-r3.ebuild 
b/net-misc/asterisk/asterisk-16.30.1-r3.ebuild
new file mode 100644
index 000000000000..0d859d8098ae
--- /dev/null
+++ b/net-misc/asterisk/asterisk-16.30.1-r3.ebuild
@@ -0,0 +1,361 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+LUA_COMPAT=( lua5-{1..4} )
+
+inherit autotools linux-info lua-single toolchain-funcs
+
+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 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}/asterisk-16.16.2-no-var-run-install.patch"
+       "${FILESDIR}/asterisk-16.29.1_18.15.1_20.0.1-noexec_stack.patch"
+       "${FILESDIR}/asterisk-16.30.1-r1-iax2_jitterbuffer.patch"
+       
"${FILESDIR}/asterisk-16.30.1-r3-manager.c-Add-entries-to-Originate-blacklist.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 )
+       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? ( net-libs/c-client[ssl=] )
+       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 )"
+PDEPEND="net-misc/asterisk-base"
+
+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" \
+               AC_CONFIG_SUBDIRS=menuselect eautoreconf
+}
+
+src_configure() {
+       local vmst
+       local copt cstate
+
+       econf \
+               SED=sed \
+               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 astdb2* tools.  We've been on sqlite long enough
+       # that this should really no longer be a problem (bug 
#https://bugs.gentoo.org/872194)
+       _menuselect --disable astdb2sqlite3 menuselect.makeopts
+       _menuselect --disable astdb2bdb 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
+
+       # Disable conversion tools (which fails to compile in some cases).
+       _menuselect --disable astdb2bdb 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 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}
+
+       # 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}
+
+       # 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() {
+       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-16.30.1-r3-manager.c-Add-entries-to-Originate-blacklist.patch
 
b/net-misc/asterisk/files/asterisk-16.30.1-r3-manager.c-Add-entries-to-Originate-blacklist.patch
new file mode 100644
index 000000000000..f33e73037979
--- /dev/null
+++ 
b/net-misc/asterisk/files/asterisk-16.30.1-r3-manager.c-Add-entries-to-Originate-blacklist.patch
@@ -0,0 +1,205 @@
+From faddd99f2b9408b524e5eb8a01589fe1fa282df2 Mon Sep 17 00:00:00 2001
+From: George Joseph <[email protected]>
+Date: Mon, 22 Jul 2024 08:05:03 -0600
+Subject: [PATCH 1/2] manager.c: Add entries to Originate blacklist
+
+Added Reload and DBdeltree to the list of dialplan application that
+can't be executed via the Originate manager action without also
+having write SYSTEM permissions.
+
+Added CURL, DB*, FILE, ODBC and REALTIME* to the list of dialplan
+functions that can't be executed via the Originate manager action
+without also having write SYSTEM permissions.
+
+If the Queue application is attempted to be run by the Originate
+manager action and an AGI parameter is specified in the app data,
+it'll be rejected unless the manager user has either the AGI or
+SYSTEM permissions.
+
+Resolves: #GHSA-c4cg-9275-6w44
+---
+ main/manager.c | 161 +++++++++++++++++++++++++++++++++++++++++++------
+ 1 file changed, 141 insertions(+), 20 deletions(-)
+
+diff --git a/main/manager.c b/main/manager.c
+index cb64a234e5..2ce88a3ab8 100644
+--- a/main/manager.c
++++ b/main/manager.c
+@@ -6325,6 +6325,145 @@ aocmessage_cleanup:
+       return 0;
+ }
+ 
++struct originate_permissions_entry {
++      const char *search;
++      int permission;
++      int (*searchfn)(const char *app, const char *data, const char *search);
++};
++
++/*!
++ * \internal
++ * \brief Check if the application is allowed for Originate
++ *
++ * \param app The "app" parameter
++ * \param data The "appdata" parameter (ignored)
++ * \param search The search string
++ * \retval 1 Match
++ * \retval 0 No match
++ */
++static int app_match(const char *app, const char *data, const char *search)
++{
++      /*
++       * We use strcasestr so we don't have to trim any blanks
++       * from the front or back of the string.
++       */
++      return !!(strcasestr(app, search));
++}
++
++/*!
++ * \internal
++ * \brief Check if the appdata is allowed for Originate
++ *
++ * \param app The "app" parameter (ignored)
++ * \param data The "appdata" parameter
++ * \param search The search string
++ * \retval 1 Match
++ * \retval 0 No match
++ */
++static int appdata_match(const char *app, const char *data, const char 
*search)
++{
++      return !!(strstr(data, search));
++}
++
++/*!
++ * \internal
++ * \brief Check if the Queue application is allowed for Originate
++ *
++ * It's only allowed if there's no AGI parameter set
++ *
++ * \param app The "app" parameter
++ * \param data The "appdata" parameter
++ * \param search The search string
++ * \retval 1 Match
++ * \retval 0 No match
++ */
++static int queue_match(const char *app, const char *data, const char *search)
++{
++      char *parse;
++      AST_DECLARE_APP_ARGS(args,
++              AST_APP_ARG(queuename);
++              AST_APP_ARG(options);
++              AST_APP_ARG(url);
++              AST_APP_ARG(announceoverride);
++              AST_APP_ARG(queuetimeoutstr);
++              AST_APP_ARG(agi);
++              AST_APP_ARG(gosub);
++              AST_APP_ARG(rule);
++              AST_APP_ARG(position);
++      );
++
++      if (!strcasestr(app, "queue")) {
++              return 0;
++      }
++
++      parse = ast_strdupa(data);
++      AST_STANDARD_APP_ARGS(args, parse);
++
++      /*
++       * The Queue application is fine unless the AGI parameter is set.
++       * If it is, we need to check the user's permissions.
++       */
++      return !ast_strlen_zero(args.agi);
++}
++
++/*
++ * The Originate application and application data are passed
++ * to each searchfn in the list.  If a searchfn returns true
++ * and the user's permissions don't include the permissions specified
++ * in the list entry, the Originate action will be denied.
++ *
++ * If no searchfn returns true, the Originate action is allowed.
++ */
++static struct originate_permissions_entry originate_app_permissions[] = {
++      /*
++       * The app_match function checks if the search string is
++       * anywhere in the app parameter.  The check is case-insensitive.
++       */
++      { "agi", EVENT_FLAG_SYSTEM, app_match },
++      { "dbdeltree", EVENT_FLAG_SYSTEM, app_match },
++      { "exec", EVENT_FLAG_SYSTEM, app_match },
++      { "externalivr", EVENT_FLAG_SYSTEM, app_match },
++      { "mixmonitor", EVENT_FLAG_SYSTEM, app_match },
++      { "originate", EVENT_FLAG_SYSTEM, app_match },
++      { "reload", EVENT_FLAG_SYSTEM, app_match },
++      { "system", EVENT_FLAG_SYSTEM, app_match },
++      /*
++       * Since the queue_match function specifically checks
++       * for the presence of the AGI parameter, we'll allow
++       * the call if the user has either the AGI or SYSTEM
++       * permission.
++       */
++      { "queue", EVENT_FLAG_AGI | EVENT_FLAG_SYSTEM, queue_match },
++      /*
++       * The appdata_match function checks if the search string is
++       * anywhere in the appdata parameter.  Unlike app_match,
++       * the check is case-sensitive.  These are generally
++       * dialplan functions.
++       */
++      { "CURL", EVENT_FLAG_SYSTEM, appdata_match },
++      { "DB", EVENT_FLAG_SYSTEM, appdata_match },
++      { "EVAL", EVENT_FLAG_SYSTEM, appdata_match },
++      { "FILE", EVENT_FLAG_SYSTEM, appdata_match },
++      { "ODBC", EVENT_FLAG_SYSTEM, appdata_match },
++      { "REALTIME", EVENT_FLAG_SYSTEM, appdata_match },
++      { "SHELL", EVENT_FLAG_SYSTEM, appdata_match },
++      { NULL, 0 },
++};
++
++static int is_originate_app_permitted(const char *app, const char *data,
++      int permission)
++{
++      int i;
++
++      for (i = 0; originate_app_permissions[i].search; i++) {
++              if (originate_app_permissions[i].searchfn(app, data, 
originate_app_permissions[i].search)) {
++                      return !!(permission & 
originate_app_permissions[i].permission);
++              }
++      }
++
++      return 1;
++}
++
+ static int action_originate(struct mansession *s, const struct message *m)
+ {
+       const char *name = astman_get_header(m, "Channel");
+@@ -6418,26 +6557,8 @@ static int action_originate(struct mansession *s, const 
struct message *m)
+       }
+ 
+       if (!ast_strlen_zero(app) && s->session) {
+-              int bad_appdata = 0;
+-              /* To run the System application (or anything else that goes to
+-               * shell), you must have the additional System privilege */
+-              if (!(s->session->writeperm & EVENT_FLAG_SYSTEM)
+-                      && (
+-                              strcasestr(app, "system") ||      /* System(rm 
-rf /)
+-                                                                   
TrySystem(rm -rf /)       */
+-                              strcasestr(app, "exec") ||        /* 
Exec(System(rm -rf /))
+-                                                                   
TryExec(System(rm -rf /)) */
+-                              strcasestr(app, "agi") ||         /* 
AGI(/bin/rm,-rf /)
+-                                                                   
EAGI(/bin/rm,-rf /)       */
+-                              strcasestr(app, "mixmonitor") ||  /* 
MixMonitor(blah,,rm -rf)  */
+-                              strcasestr(app, "externalivr") || /* 
ExternalIVR(rm -rf)       */
+-                              strcasestr(app, "originate") ||   /* 
Originate(Local/1234,app,System,rm -rf) */
+-                              (strstr(appdata, "SHELL") && (bad_appdata = 1)) 
||       /* NoOp(${SHELL(rm -rf /)})  */
+-                              (strstr(appdata, "EVAL") && (bad_appdata = 1))  
         /* NoOp(${EVAL(${some_var_containing_SHELL})}) */
+-                              )) {
+-                      char error_buf[64];
+-                      snprintf(error_buf, sizeof(error_buf), "Originate 
Access Forbidden: %s", bad_appdata ? "Data" : "Application");
+-                      astman_send_error(s, m, error_buf);
++              if (!is_originate_app_permitted(app, appdata, 
s->session->writeperm)) {
++                      astman_send_error(s, m, "Originate Access Forbidden: 
app or data blacklisted");
+                       res = 0;
+                       goto fast_orig_cleanup;
+               }
+-- 
+2.44.2
+

Reply via email to