]> git.ipfire.org Git - thirdparty/asterisk.git/log
thirdparty/asterisk.git
8 years agoFix compiler warnings on Fedora 26 / GCC 7.
Corey Farrell [Fri, 28 Jul 2017 01:58:22 +0000 (21:58 -0400)] 
Fix compiler warnings on Fedora 26 / GCC 7.

GCC 7 has added capability to produce warnings, this fixes most of those
warnings.  The specific warnings are disabled in a few places:

* app_voicemail.c: truncation of paths more than 4096 chars in many places.
* chan_mgcp.c: callid truncated to 80 chars.
* cdr.c: two userfields are combined to cdr copy, fix would break ABI.
* tcptls.c: ignore use of deprecated method SSLv3_client_method().

ASTERISK-27156 #close

Change-Id: I65f280e7d3cfad279d16f41823a4d6fddcbc4c88

8 years agobundled_pjproject: Improve SSL/TLS error handling
George Joseph [Thu, 27 Jul 2017 11:35:51 +0000 (05:35 -0600)] 
bundled_pjproject:  Improve SSL/TLS error handling

OpenSSL has 2 levels or error processing.  It's possible for the
top layer to return SSL_ERROR_SYSCALL but the lower layer return
no error, in which case processing should continue.  Only the top
layer was being examined though so connections were being torn
down when they didn't need to be.  This patch adds the examination
of the lower level codes, and if they return no errors, allows
processing to continue.

ASTERISK-27001
Reported-by: Ian Gilmour
patches:
pjproject-2.6.patch submitted by Ian Gilmour (license 6889)

Updated-by: George Joseph and Sauw Ming (Teluu)
Merged to upstream pjproject on 7/27/2017 (commit 5631)

Change-Id: I23844ca0c68ef1ee550f14d46f6dae57d33b7bd2

8 years agochan_pjsip: add a new function PJSIP_DTMF_MODE
Torrey Searle [Mon, 26 Jun 2017 12:52:52 +0000 (14:52 +0200)] 
chan_pjsip: add a new function PJSIP_DTMF_MODE

This function is a replica of SIPDtmfMode, allowing the DTMF mode of a
PJSIP call to be modified on a per-call basis

ASTERISK-27085 #close

Change-Id: I20eef5da3e5d1d3e58b304416bc79683f87e7612

8 years agores_rtp_asterisk: Fix mapping of pjsip's ICE roles to ours
Sean Bright [Tue, 25 Jul 2017 20:17:45 +0000 (16:17 -0400)] 
res_rtp_asterisk: Fix mapping of pjsip's ICE roles to ours

Change-Id: Ia578ede1a55b21014581793992a429441903278b

8 years agoMerge "res_stasis_device_state: Unsubscribe should remove old subscriptions" into 13
Jenkins2 [Wed, 26 Jul 2017 12:09:31 +0000 (07:09 -0500)] 
Merge "res_stasis_device_state: Unsubscribe should remove old subscriptions" into 13

8 years agoMerge "app_voicemail.c: Allow mailbox entry on authentication retry prompt." into 13
Jenkins2 [Wed, 26 Jul 2017 11:43:20 +0000 (06:43 -0500)] 
Merge "app_voicemail.c: Allow mailbox entry on authentication retry prompt." into 13

8 years agoMerge "core: Add VP9 passthrough support." into 13
Joshua Colp [Tue, 25 Jul 2017 16:11:45 +0000 (11:11 -0500)] 
Merge "core: Add VP9 passthrough support." into 13

8 years agores_stasis_device_state: Unsubscribe should remove old subscriptions
Sergej Kasumovic [Thu, 20 Jul 2017 13:08:05 +0000 (15:08 +0200)] 
res_stasis_device_state: Unsubscribe should remove old subscriptions

Case scenario with Applications ARI:

* Once you subscribe to deviceState with Applications REST API, it will be
added into subscription pool.

* When you unsubscribe it will remove from the device_state_subscription
hash table but not from the subscription pool.

* When you subscribe again, it will add it to pool again.

* Now you will have two subscriptions and you will receive same event
twice.

This fix should now remove deviceState subscription from pool and it
should fix unsubscribe on deviceState.

ASTERISK-27130 #close

Change-Id: I718b70d770a086e39b4ddba4f69a3c616d4476c4

8 years agoMerge "say.c: Fix file locations for second, seconds, minute, minutes files" into 13
George Joseph [Tue, 25 Jul 2017 12:44:41 +0000 (07:44 -0500)] 
Merge "say.c: Fix file locations for second, seconds, minute, minutes files" into 13

8 years agocore: Add VP9 passthrough support.
Joshua Colp [Mon, 24 Jul 2017 18:30:59 +0000 (18:30 +0000)] 
core: Add VP9 passthrough support.

This change adds VP9 as a known codec and creates a cached
"vp9" media format for use.

Change-Id: I025a93ed05cf96153d66f36db1839109cc24c5cc

8 years agoformat.h: Fix a few minor errors in comments.
Matthew Fredrickson [Fri, 21 Jul 2017 20:57:46 +0000 (15:57 -0500)] 
format.h: Fix a few minor errors in comments.

A few minor problems were found in comments in format.h.  This patch fixes them.

Change-Id: I07f0bdb47b93359b361c4c3d8ecc87cd3199dd94

8 years agosay.c: Fix file locations for second, seconds, minute, minutes files
Rusty Newton [Fri, 21 Jul 2017 22:04:31 +0000 (17:04 -0500)] 
say.c: Fix file locations for second, seconds, minute, minutes files

The seconds and minutes files have always existed in the base language
directory of the Core package. So say.c has always been calling the wrong
location (under digits/) for those two files and in the case of second and
minute they didn't exist in the Core packages at all.

The 1.6 sounds release moves the second and minute files into Core from
Extra for the languages that already had them. A future release will include
the second and minute files for languages that didn't already have them.

This patch just changes all the target locations for second, seconds,
minute, and minutes that were under the digits subdir to be under the root of
sounds instead. Which is where the sounds will be for some languages after 1.6
sounds and for all languages after a future release.

ASTERISK-25810 #close

Change-Id: I05d9d4bee6a7237030530a46e7eb3df15f13f702
Reported-by: Nicolas Riendeau
8 years agoapp_voicemail.c: Allow mailbox entry on authentication retry prompt.
Richard Mudgett [Wed, 19 Jul 2017 23:11:19 +0000 (18:11 -0500)] 
app_voicemail.c: Allow mailbox entry on authentication retry prompt.

The following testsuite voicemail tests were failing to re-enter the
mailbox after the first login attempt.

tests/apps/voicemail/authenticate_invalid_mailbox
tests/apps/voicemail/authenticate_invalid_password

The tests were noting the start of the vm-incorrect-mailbox prompt and
immediately sending the mailbox for the next login attempt.  Since the
invalid message playback had to complete before the digits were
recognized, the test passed for the wrong reason and added approximately
20 seconds to the test times.

* Allow the vm-incorrect-mailbox prompt to get interrupted by the mailbox
digits like the initial vm-login prompt so the tests are able to enter the
intended mailbox.

Change-Id: I1dc53fe917bfe03a4587b2c4cd24c94696a69df8

8 years agoSounds: Update Makefile for Extra sounds 1.5.1 release
Rusty Newton [Fri, 21 Jul 2017 19:20:10 +0000 (14:20 -0500)] 
Sounds: Update Makefile for Extra sounds 1.5.1 release

Incrementing version for the Extra sounds release. 1.5.1 Extra sounds
removes two prompts that were moved into the Core packages in the 1.6 Core
sounds release.

ASTERISK-27142 #close

Change-Id: I82f017812b0ea9599e19dd4635afd55611f13ee7

8 years agoMerge "corosync: Fix corosync library name in configure.ac" into 13
Jenkins2 [Fri, 21 Jul 2017 11:38:41 +0000 (06:38 -0500)] 
Merge "corosync: Fix corosync library name in configure.ac" into 13

8 years agoMerge "pjsip: Increase maximum packet size." into 13
Jenkins2 [Thu, 20 Jul 2017 15:47:09 +0000 (10:47 -0500)] 
Merge "pjsip: Increase maximum packet size." into 13

8 years agocorosync: Fix corosync library name in configure.ac
Sean Bright [Thu, 20 Jul 2017 14:57:08 +0000 (10:57 -0400)] 
corosync: Fix corosync library name in configure.ac

Also add new corosync packages to install_prereq.

Reported by Travis Ryan in #asterisk-dev

Change-Id: Ib861c95ba630fed62dc54e56784ad8446ed9d2db

8 years agoMerge "app_playback.c: Use the timezonename parameter" into 13
Jenkins2 [Wed, 19 Jul 2017 14:34:07 +0000 (09:34 -0500)] 
Merge "app_playback.c: Use the timezonename parameter" into 13

8 years agoMerge "core: Add PARSE_TIMELEN support to ast_parse_arg and ACO." into 13
Jenkins2 [Wed, 19 Jul 2017 14:11:27 +0000 (09:11 -0500)] 
Merge "core: Add PARSE_TIMELEN support to ast_parse_arg and ACO." into 13

8 years agopjsip: Increase maximum packet size.
Benjamin Keith Ford [Tue, 18 Jul 2017 20:04:44 +0000 (15:04 -0500)] 
pjsip: Increase maximum packet size.

The maximum packet size for PJSIP has been increased to handle the
multiple streams being added for WebRTC.

Change-Id: I9ea1e8d02668c544acadcb1c6200e1cc1bd588b3

8 years agoapp_playback.c: Use the timezonename parameter
Holger Hans Peter Freyther [Tue, 11 Jul 2017 09:48:26 +0000 (11:48 +0200)] 
app_playback.c: Use the timezonename parameter

In say_date_generic the timezonename parameter is passed but never
used. Fix it by passing it to the ast_localtime function.

ASTERISK-27124

Change-Id: I6afa98f9163190043244b9f3ba91eb1874d1b586

8 years agoMerge "res_rtp_asterisk: Use RTP component for ICE if RTCP-MUX is in use." into 13
Joshua Colp [Mon, 17 Jul 2017 19:57:35 +0000 (14:57 -0500)] 
Merge "res_rtp_asterisk: Use RTP component for ICE if RTCP-MUX is in use." into 13

8 years agoMerge "app_confbridge: Make sure name recordings are always removed from the filesyst...
Jenkins2 [Mon, 17 Jul 2017 14:03:38 +0000 (09:03 -0500)] 
Merge "app_confbridge: Make sure name recordings are always removed from the filesystem" into 13

8 years agoMerge "chan_iax2: On reload make sure to check for existing MWI subscription" into 13
Jenkins2 [Mon, 17 Jul 2017 13:32:54 +0000 (08:32 -0500)] 
Merge "chan_iax2: On reload make sure to check for existing MWI subscription" into 13

8 years agoMerge "res/res_stasis_snoop: generate silence when audiohook returns null" into 13
Jenkins2 [Mon, 17 Jul 2017 13:03:40 +0000 (08:03 -0500)] 
Merge "res/res_stasis_snoop: generate silence when audiohook returns null" into 13

8 years agores_rtp_asterisk: Use RTP component for ICE if RTCP-MUX is in use.
Joshua Colp [Sun, 16 Jul 2017 17:18:39 +0000 (17:18 +0000)] 
res_rtp_asterisk: Use RTP component for ICE if RTCP-MUX is in use.

This change makes it so that if an RTCP packet is being sent
the RTP ICE component is used for sending if RTCP-MUX is in use.

ASTERISK-27133

Change-Id: I6200f611ede709602ee9b89501720c29545ed68b

8 years agores/res_stasis_snoop: generate silence when audiohook returns null
Torrey Searle [Tue, 11 Jul 2017 14:55:36 +0000 (16:55 +0200)] 
res/res_stasis_snoop: generate silence when audiohook returns null

Currently when rtp is paused, no packets are written to the
recorded audio file, causing the silence to be skipped and recording
not properly time aligned.  The read handler as been adapted to
return a silence frame of the correct size.

ASTERISK-27128 #close

Change-Id: I2d7f60650457860b9c70907b14426756b058a844

8 years agoapp_confbridge: Make sure name recordings are always removed from the filesystem
Sergej Kasumovic [Fri, 14 Jul 2017 06:25:36 +0000 (08:25 +0200)] 
app_confbridge: Make sure name recordings are always removed from the filesystem

This commit fixes two possible scenarios:

* When recording name and if during recording you hangup, file is never
removed. This is due to the fact file location is nulled.
* When recording name and if you hangup during thank-you prompt, file
is never removed.

ASTERISK-27123 #close

Change-Id: I39b7271408b4b54ce880c5111a886aa8f28c2625

8 years agochan_iax2: On reload make sure to check for existing MWI subscription
Sergej Kasumovic [Fri, 14 Jul 2017 06:11:50 +0000 (08:11 +0200)] 
chan_iax2: On reload make sure to check for existing MWI subscription

On every reload of chan_iax2 module, MWI subscription was added, which
results in additional taskprocessors being accumulated over time.

This commit fixes it by making sure we check for existing subscription
first.

This was verified with 'core show taskprocessors' CLI command.

ASTERISK-27122 #close

Change-Id: Ie2ef528fd5ca01b933eeb88188cc10967899cfb9

8 years agoSounds: Update for core sounds 1.6 release
Rusty Newton [Thu, 13 Jul 2017 20:43:42 +0000 (15:43 -0500)] 
Sounds: Update for core sounds 1.6 release

Added necessary lines to make the en_NZ language set selectable and to get
core sounds 1.6 pulled down.

ASTERISK-26807 #close
ASTERISK-25816 #close
ASTERISK-26274 #close

Change-Id: I84e4dd4696568cc1ba318d12ac4b075461d6eed4

8 years agocore: Add PARSE_TIMELEN support to ast_parse_arg and ACO.
Corey Farrell [Mon, 10 Jul 2017 19:04:58 +0000 (15:04 -0400)] 
core: Add PARSE_TIMELEN support to ast_parse_arg and ACO.

This adds support for parsing timelen values from config files.  This
includes support for all flags which apply to PARSE_INT32.  Support for
this parser is added to ACO via the OPT_TIMELEN_T option type.

Fixes an issue where extra characters provided to ast_app_parse_timelen
were ignored, they now cause an error.

Testing is included.

ASTERISK-27117 #close

Change-Id: I6b333feca7e3f83b4ef5bf2636fc0fd613742554

8 years agoMerge "res/res_pjsip_t38 ensure t38 requests get rejected quickly" into 13
Jenkins2 [Thu, 13 Jul 2017 15:11:40 +0000 (10:11 -0500)] 
Merge "res/res_pjsip_t38  ensure t38 requests get rejected quickly" into 13

8 years agobasic-pbx: Remove res_pjsip_multihomed from sample config
Sean Bright [Wed, 12 Jul 2017 20:07:42 +0000 (16:07 -0400)] 
basic-pbx: Remove res_pjsip_multihomed from sample config

ASTERISK-27127 #close
Reported by: HZMI8gkCvPpom0tM

Change-Id: I2b0c54570d58156e37166ac536728af3b6c01789

8 years agoMerge "res_musiconhold: Add kill_escalation_delay, kill_method to class" into 13
Jenkins2 [Wed, 12 Jul 2017 10:55:38 +0000 (05:55 -0500)] 
Merge "res_musiconhold:  Add kill_escalation_delay, kill_method to class" into 13

8 years agoMerge "http.c: Reduce log spam" into 13
Joshua Colp [Wed, 12 Jul 2017 09:25:20 +0000 (04:25 -0500)] 
Merge "http.c:  Reduce log spam" into 13

8 years agores_musiconhold: Add kill_escalation_delay, kill_method to class
George Joseph [Tue, 11 Jul 2017 12:26:27 +0000 (06:26 -0600)] 
res_musiconhold:  Add kill_escalation_delay, kill_method to class

By default, when res_musiconhold reloads or unloads, it sends a HUP
signal to custom applications (and all descendants), waits 100ms,
then sends a TERM signal, waits 100ms, then finally sends a KILL
signal.  An application which is interacting with an external
device and/or spawns children of its own may not be able to exit
cleanly in the default times, expecially if sent a KILL signal, or
if it's children are getting signals directly from
res_musiconhoild.

* To allow extra time, the 'kill_escalation_delay'
  class option can be used to set the number of milliseconds
  res_musiconhold waits before escalating kill signals, with the
  default being the current 100ms.

* To control to whom the signals are sent, the "kill_method" class
  option can be set to "process_group" (the default, existing
  behavior), which sends signals to the application and its
  descendants directly, or "process" which sends signals only to the
  application itself.

Change-Id: Iff70a1a9405685a9021a68416830c0db5158603b

8 years agoAvoid setting maxfiles for a remote asterisk
Tzafrir Cohen [Mon, 3 Jul 2017 12:30:37 +0000 (15:30 +0300)] 
Avoid setting maxfiles for a remote asterisk

Setting maxfiles (maximum number of open files) has no practical
effect on a remote asterisk (rasterisk, rasterisk -x).

It has an ill effect of printing an extra message, which
may be annoying in case of -x.

ASTERISK-27105 #close

Change-Id: Iaf9eb344e4b4b517df91b736b27ec55f6a6921a2

8 years agohttp.c: Reduce log spam
George Joseph [Wed, 5 Jul 2017 20:31:43 +0000 (14:31 -0600)] 
http.c:  Reduce log spam

Messages like "fwrite() failed: Connection reset by peer" are no
help whatsoever, especially since they can be caused simply by a
client disconnecting.

* Make those WARNINGs DEBUGs.
* Check the return of the headers fprintf.

Change-Id: I17bd5f3621514152a7b2b263c801324c5e96568b

8 years agoMerge "res_pjsip: Fix crash with from_user containing invalid characters." into 13
Jenkins2 [Tue, 11 Jul 2017 12:03:53 +0000 (07:03 -0500)] 
Merge "res_pjsip: Fix crash with from_user containing invalid characters." into 13

8 years agoMerge "json.c: Add backtrace log to find 'Invalid UTF-8 string' errors" into 13
Jenkins2 [Mon, 10 Jul 2017 16:22:06 +0000 (11:22 -0500)] 
Merge "json.c: Add backtrace log to find 'Invalid UTF-8 string' errors" into 13

8 years agoMerge "res_rtp_asterisk.c: Fix TURN deadlock by using ICE session group lock." into 13
Jenkins2 [Mon, 10 Jul 2017 16:05:23 +0000 (11:05 -0500)] 
Merge "res_rtp_asterisk.c: Fix TURN deadlock by using ICE session group lock." into 13

8 years agoMerge "bridge_native_rtp.c: Fix direct media video RTP instance ACL check." into 13
Jenkins2 [Mon, 10 Jul 2017 15:51:02 +0000 (10:51 -0500)] 
Merge "bridge_native_rtp.c: Fix direct media video RTP instance ACL check." into 13

8 years agores_pjsip: Fix crash with from_user containing invalid characters.
Benjamin Keith Ford [Fri, 7 Jul 2017 16:19:13 +0000 (11:19 -0500)] 
res_pjsip: Fix crash with from_user containing invalid characters.

If the from_user field contains certain characters (like @, {, ^, etc.),
PJSIP will return a null value for the URI when attempting to parse it.
This causes a crash when trying to dial out through a trunk that contains
these invalid characters in its from_user field.

This change checks the configuration and ensures that an endpoint will
not be created if the from_user contains an invalid character. It also
adds a null check to the PJSIP URI parsing as a backup.

ASTERISK-27036 #close
Reported by: Maxim Vasilev

Change-Id: I0396fdb5080604e0bdf1277464d5c8a85db913d0

8 years agojson.c: Add backtrace log to find 'Invalid UTF-8 string' errors
Richard Mudgett [Wed, 28 Jun 2017 00:27:43 +0000 (19:27 -0500)] 
json.c: Add backtrace log to find 'Invalid UTF-8 string' errors

Change-Id: I9020ff9f2b3749904317c0c173f47a1bbed6f929

8 years agoMerge "app_voicemail: Cleanup ODBC connection handling" into 13
Jenkins2 [Fri, 7 Jul 2017 21:24:52 +0000 (16:24 -0500)] 
Merge "app_voicemail: Cleanup ODBC connection handling" into 13

8 years agores_rtp_asterisk.c: Fix TURN deadlock by using ICE session group lock.
Richard Mudgett [Wed, 5 Jul 2017 18:39:45 +0000 (13:39 -0500)] 
res_rtp_asterisk.c: Fix TURN deadlock by using ICE session group lock.

When a message is received on the TURN socket, the code processing the
message needs to call into the ICE/STUN session for further processing.
This code path locks the TURN group lock then the ICE/STUN group lock.  In
another thread an ICE/STUN timer can fire off to send a keep alive message
over the TURN socket.  In this code path, the ICE/STUN group lock is
obtained then the TURN group lock is obtained to send the packet.  A
classic deadlock case if the group locks are not the same.

* Made TURN get created using the ICE/STUN session's group lock.

NOTE: I was originally concerned that the ICE/STUN session can get
recreated by ice_reset_session() for an event like RTCP multiplexing
causing a change during SDP negotiation.  In this case the TURN group lock
would become different.  However, TURN is also recreated as part of the
ICE/STUN recreation in ice_create() when all known ICE candidates are
added to the new ICE session.  While the ICE/STUN and TURN sessions are
being recreated there is a period where the group locks could be
different.

ASTERISK-27023 #close
Patches:
    res_rtp_asterisk-turn-deadlock-fix.patch (license #6502)
        patch uploaded by Michael Walton (modified)

Change-Id: Ic870edb99ce4988a8c8eb6e678ca7f19da1432b9

8 years agoMerge "Fix alembic branches" into 13
Joshua Colp [Thu, 6 Jul 2017 11:39:13 +0000 (06:39 -0500)] 
Merge "Fix alembic branches" into 13

8 years agoFix alembic branches
George Joseph [Thu, 6 Jul 2017 10:55:17 +0000 (04:55 -0600)] 
Fix alembic branches

Change-Id: I04f607f084bda9b1b7f626e8e9735c37dc751187

8 years agoMerge "core: Fix segfault when invoking 'data get' CLI command" into 13
Jenkins2 [Wed, 5 Jul 2017 23:29:28 +0000 (18:29 -0500)] 
Merge "core: Fix segfault when invoking 'data get' CLI command" into 13

8 years agoMerge "pjproject_bundled: Allow passing configure options to bundled" into 13
Jenkins2 [Wed, 5 Jul 2017 22:39:56 +0000 (17:39 -0500)] 
Merge "pjproject_bundled:  Allow passing configure options to bundled" into 13

8 years agobridge_native_rtp.c: Fix direct media video RTP instance ACL check.
Richard Mudgett [Fri, 23 Jun 2017 16:17:51 +0000 (11:17 -0500)] 
bridge_native_rtp.c: Fix direct media video RTP instance ACL check.

The video stream was using the audio stream RTP instance addresses to
check if the video RTP gets directed to an allowed direct media Access
Control List (ACL) address.  There is no guarantee that the video RTP
instance uses the same addresses as the audio RTP instance.

This looks like it has been a bug since v11 when direct media ACL was
first added to chan_sip and then faithfully reproduced through a couple
code refactorings into the new bridging architecture.

Change-Id: I8ddd56320e0eea769f3ceed3fa5b6bdfb51d681a

8 years agoMerge "pjsip_distributor.c: Fix deadlock with TCP type transports." into 13
George Joseph [Wed, 5 Jul 2017 21:08:18 +0000 (16:08 -0500)] 
Merge "pjsip_distributor.c: Fix deadlock with TCP type transports." into 13

8 years agoMerge "chan_sip: Only when different, add TCP|TLS in autodomain (SIP Domain Support...
Jenkins2 [Wed, 5 Jul 2017 21:06:44 +0000 (16:06 -0500)] 
Merge "chan_sip: Only when different, add TCP|TLS in autodomain (SIP Domain Support)." into 13

8 years agoMerge "pjsip_distributor.c: Fix unidentified_requests hash functions." into 13
Jenkins2 [Wed, 5 Jul 2017 20:07:51 +0000 (15:07 -0500)] 
Merge "pjsip_distributor.c: Fix unidentified_requests hash functions." into 13

8 years agoMerge "bridge_native_rtp: Keep rtp instance refs on bridge_channel" into 13
Jenkins2 [Wed, 5 Jul 2017 20:02:28 +0000 (15:02 -0500)] 
Merge "bridge_native_rtp: Keep rtp instance refs on bridge_channel" into 13

8 years agoMerge "chan_pjsip: Fix ability to send UPDATE on COLP" into 13
George Joseph [Wed, 5 Jul 2017 19:38:01 +0000 (14:38 -0500)] 
Merge "chan_pjsip:  Fix ability to send UPDATE on COLP" into 13

8 years agoMerge "channel: Clear channel flag in error branch." into 13
Jenkins2 [Wed, 5 Jul 2017 13:56:46 +0000 (08:56 -0500)] 
Merge "channel: Clear channel flag in error branch." into 13

8 years agocore: Fix segfault when invoking 'data get' CLI command
Sean Bright [Wed, 5 Jul 2017 12:42:07 +0000 (08:42 -0400)] 
core: Fix segfault when invoking 'data get' CLI command

Invoking 'data get /asterisk/core/channeltypes' caused a crash because
of an assumption of a tech's capabilities to be non-NULL. The
'Surrogate' tech, however, does have a NULL capabilities member,
resulting in a crash.

ASTERISK-27108 #close

Change-Id: I2fbe7715681f43d5565d1e1599269468c26b0e0a

8 years agochan_sip: Only when different, add TCP|TLS in autodomain (SIP Domain Support).
Alexander Traud [Mon, 3 Jul 2017 15:59:43 +0000 (17:59 +0200)] 
chan_sip: Only when different, add TCP|TLS in autodomain (SIP Domain Support).

When sip.conf contained tcpenable=yes and autodomain=yes, the TCP domain was
added in any case, because of a local Boolean-negation error of the return value
of ast_sockaddr_cmp. After fixing this error for TCP and TLS, the TLS domain was
still always added with tlsenable=yes, because the domains were not compared
just on the address but also on the port – and TLS is always on a different port
than UDP/TCP.

ASTERISK-27106

Change-Id: I14fe9e319e238320b094016980445ef3a5b3337c

8 years agochan_sip: Fix a typo for tlsbindaddr in autodomain (SIP Domain Support).
Alexander Traud [Mon, 3 Jul 2017 15:38:32 +0000 (17:38 +0200)] 
chan_sip: Fix a typo for tlsbindaddr in autodomain (SIP Domain Support).

Because of a copy-and-paste error when the struct ast_sockaddr changed,
tlsbindaddr was not added, when sip.conf contained autodomain=yes; see
"show sip domains" on the command-line interface (CLI) of Asterisk.

ASTERISK-27106

Change-Id: I3d0957150017c223136968ef1266f275d0d6695e

8 years agoapp_voicemail: Cleanup ODBC connection handling
Sean Bright [Thu, 29 Jun 2017 18:58:35 +0000 (14:58 -0400)] 
app_voicemail: Cleanup ODBC connection handling

The primary focus of this patch is adding a missing call to
ast_odbc_release_obj(), but is also a general cleanup of the ODBC
related code in app_voicemail.

ASTERISK-27093 #close

Change-Id: I8e285142eaeb3146b4287a928276b70db76c902b

8 years agochannel: Clear channel flag in error branch.
Corey Farrell [Sat, 1 Jul 2017 04:57:31 +0000 (00:57 -0400)] 
channel: Clear channel flag in error branch.

Clear channel flag AST_FLAG_END_DTMF_ONLY in ast_waitfordigit_full when
ast_read returns NULL.

ASTERISK-27100 #close

Change-Id: Id3039e9a4e74e0cb359f636c9fd0c9740ebf7d9d

8 years agoMerge "app_queue: Fix returning to dialplan when a queue is empty" into 13
Jenkins2 [Fri, 30 Jun 2017 19:45:43 +0000 (14:45 -0500)] 
Merge "app_queue: Fix returning to dialplan when a queue is empty" into 13

8 years agopjsip_distributor.c: Fix deadlock with TCP type transports.
Richard Mudgett [Thu, 29 Jun 2017 23:27:20 +0000 (18:27 -0500)] 
pjsip_distributor.c: Fix deadlock with TCP type transports.

When a SIP message comes in on a transport, pjproject obtains the lock on
the transport and pulls the data out of the socket.  Unlike UDP, the TCP
transport does not allow concurrent access.  Without concurrency the
transport lock is not released when the transport's message complete
callback is called.  The processing continues and eventually Asterisk
starts processing the SIP message.  The first thing Asterisk tries to do
is determine the associated dialog of the message to determine the
associated serializer.  To get the associated serializer safely requires
us to get the dialog lock.

To send a request or response message for a dialog, pjproject obtains the
dialog lock and then obtains the transport lock.  Deadlock can result
because of the opposite order the locks are obtained.

* Fix the deadlock by obtaining the serializer associated with the dialog
another way that doesn't involve obtaining the dialog lock.  In this case,
we use an ao2 container to hold the associated endpoint and serializer.
The new locks are held a brief time and won't overlap other existing lock
times.

ASTERISK-27090 #close

Change-Id: I9ed63f4da9649e9db6ed4be29c360968917a89bd

8 years agopjsip_distributor.c: Fix unidentified_requests hash functions.
Richard Mudgett [Thu, 29 Jun 2017 23:22:33 +0000 (18:22 -0500)] 
pjsip_distributor.c: Fix unidentified_requests hash functions.

The OBJ_SEARCH_xxx defines should not be used as if they were individual
bits.  They represent a multi-bit enumeration value field.

Change-Id: I32abc9a475396dab02402a7014357dd94284e17b

8 years agoMerge "res_rtp_asterisk: Fix issues with ICE renegotiation." into 13
Jenkins2 [Fri, 30 Jun 2017 16:29:29 +0000 (11:29 -0500)] 
Merge "res_rtp_asterisk: Fix issues with ICE renegotiation." into 13

8 years agopjproject_bundled: Allow passing configure options to bundled
George Joseph [Fri, 30 Jun 2017 13:31:52 +0000 (07:31 -0600)] 
pjproject_bundled:  Allow passing configure options to bundled

There wasn't any good way to pass options like --host or --build
down to the pjproject configure which makes cross-compiling difficult.

* Added a new PJPROJECT_CONFIGURE_OPTS environment variable which
  can be used to pass arbitrary options to pjproject configure.
* Automatically set the pjproject configure --host and --build
  options to match those supplied for the asterisk configure.

ASTERISK-27097 #close
Reported-by: Kinsey Moore
Change-Id: I5fa776e110262851173002a26ffe1172e4c35b2e

8 years agochan_pjsip: Fix ability to send UPDATE on COLP
George Joseph [Thu, 29 Jun 2017 19:50:14 +0000 (13:50 -0600)] 
chan_pjsip:  Fix ability to send UPDATE on COLP

When connected_line_method is "invite", we're supposed to determine
if the client can support UPDATE and if it can, send UPDATE instead
of INVITE to avoid the SDP renegotiation.  Not only was pjproject
not setting the PJSIP_INV_SUPPORT_UPDATE flag, we were testing
that invite_tsx wasn't NULL which isn't always the case.

* Updated chan_pjsip/update_connected_line_information to drop the
  requirement that invite_tsx isn't NULL.
* Submitted patch to pjproject sip_inv.c that sets the
  PJSIP_INV_SUPPORT_UPDATE flag correctly.
* Updated pjsip.conf.sample to clarify what happens when "invite"
  is specified.

ASTERISK-27095

Change-Id: Ic2381b3567b8052c616d96fbe79564c530e81560

8 years agoapp_queue: Fix returning to dialplan when a queue is empty
Ivan Poddubny [Tue, 27 Jun 2017 09:37:11 +0000 (11:37 +0200)] 
app_queue: Fix returning to dialplan when a queue is empty

The fix for ASTERISK-25665 introduced a regression.
The return value of queue_exec used to be 0 in case of leavewhenempty
but it was changed to -1 (returned from wait_our_turn and passed
transparently by queue_exec), thus leading to hangup instead of returning
back to dialplan.

This commit resets the value back to 0 in this case, restoring
original behavior.

ASTERISK-27065 #close
Reported by: Marek Cervenka

Change-Id: Id9c83b75aeda463250155e88c5004be52bbca5ac

8 years agoMerge "app_voicemail: IMAP connection control" into 13
Jenkins2 [Thu, 29 Jun 2017 14:03:05 +0000 (09:03 -0500)] 
Merge "app_voicemail: IMAP connection control" into 13

8 years agores_rtp_asterisk: Fix issues with ICE renegotiation.
Joshua Colp [Wed, 28 Jun 2017 14:03:31 +0000 (14:03 +0000)] 
res_rtp_asterisk: Fix issues with ICE renegotiation.

When re-inviting to add more streams it is possible for
the role of existing ICE sessions to be changed to the
incorrect value. This results in subsequent refreshes
within the sessions getting a role conflict and the ICE
session breaking down. This change only sets the role to
be the new value if an ICE renegotiation is actually
going to happen, otherwise the existing role is preserved.

As well if we encounter a situation where a unidirectional
ICE negotiation happens and the other side does not send us
candidates we will not store any information for sending
traffic, even though we know where they are reachable. This
change fixes this by using the source of the ICE traffic
itself as the target if no candidates are known and we
receive some ICE traffic.

ASTERISK-27088

Change-Id: I71228181e358917fcefc3100fad21b2fc02a59a9

8 years agobridge_native_rtp: Keep rtp instance refs on bridge_channel
George Joseph [Fri, 9 Jun 2017 03:50:43 +0000 (21:50 -0600)] 
bridge_native_rtp: Keep rtp instance refs on bridge_channel

There have been reports of deadlocks caused by an attempt to send a frame
to a channel's rtp instance after the channel has left the native bridge
and been destroyed.  This patch effectively causes the bridge channel to
keep a reference to the glue and both the audio and video rtp instances
so what gets started will get stopped.

ASTERISK-26978 #close
Reported-by: Ross Beer
Change-Id: I9e1ac49fa4af68d64826ccccd152593cf8cdb21a

8 years agores/res_pjsip_t38: fix incorrect increment of media_count
Torrey Searle [Tue, 27 Jun 2017 15:46:43 +0000 (17:46 +0200)] 
res/res_pjsip_t38: fix incorrect increment of media_count

The T38 sdp callback incorrectly has a side effect of incrementing
the media_count.  This can lead to core dumps.

Change-Id: I7bb2f4987de4046ec52cfc34e5ea0662dae32af8

8 years agores_pjsip: Add DTMF INFO Failback mode
Torrey Searle [Thu, 15 Jun 2017 08:12:41 +0000 (10:12 +0200)] 
res_pjsip:  Add DTMF INFO Failback mode

The existing auto dtmf mode reverts to inband if 4733 fails to be
negotiated.  This patch adds a new mode auto_info which will
switch to INFO instead of inband if 4733 is not available.

ASTERISK-27066 #close

Change-Id: Id185b11e84afd9191a2f269e8443019047765e91

8 years agores/res_pjsip_t38 ensure t38 requests get rejected quickly
Torrey Searle [Thu, 22 Jun 2017 12:47:54 +0000 (14:47 +0200)] 
res/res_pjsip_t38  ensure t38 requests get rejected quickly

arm the t38 webhook always, so we can correctly reject a
T38 negotiation request when t38 is disabled on a channel

Change-Id: Ib1ffe35aee145d4e0fe61dd012580be11aae079d

8 years agores_pjsip_mwi.c: Eliminate RAII_VAR in contact delete observer
Richard Mudgett [Wed, 21 Jun 2017 22:57:11 +0000 (17:57 -0500)] 
res_pjsip_mwi.c: Eliminate RAII_VAR in contact delete observer

Change-Id: I0bc97c6608de1d1a4228826b3b3be43f162f05f3

8 years agores_pjsip_mwi: update unsolicited MWI subscriptions on updating contact
Alexei Gradinari [Fri, 16 Jun 2017 23:08:30 +0000 (19:08 -0400)] 
res_pjsip_mwi: update unsolicited MWI subscriptions on updating contact

Do not need to unsubscribe/subscribe on creating the ednpoint's contact.
The modified function create_mwi_subscriptions_for_endpoint adds
the subscription only if it does not exist.

The subscriptions aren't added for active contacts
which are retrieved on startup from realtime
if mwi_disable_initial_unsolicited=yes.
Because the mwi_contact_added is not called.
So the subscriptions also should be created on updating contact.

ASTERISK-26230 #close

Change-Id: I47e265af9296ca09aa42a316fdacac104148cee4

8 years agoMerge "core_local: local channel data not being properly unref'ed and unlocked" into 13
Jenkins2 [Wed, 21 Jun 2017 23:06:44 +0000 (18:06 -0500)] 
Merge "core_local: local channel data not being properly unref'ed and unlocked" into 13

8 years agoMerge "bridge: stuck channel(s) after failed attended transfer" into 13
Joshua Colp [Wed, 21 Jun 2017 22:36:54 +0000 (17:36 -0500)] 
Merge "bridge: stuck channel(s) after failed attended transfer" into 13

8 years agocore_local: local channel data not being properly unref'ed and unlocked
Kevin Harwell [Tue, 20 Jun 2017 20:41:14 +0000 (15:41 -0500)] 
core_local: local channel data not being properly unref'ed and unlocked

In an earlier version of Asterisk a local channel [un]lock all functions were
added in order to keep a crash from occurring when a channel hung up too early
during an attended transfer. Unfortunately, when a transfer failure occurs and
depending on the timing, the local channels sometime do not get properly
unlocked and deref'ed after being locked and ref'ed. This happens because the
underlying local channel structure gets NULLed out before unlocking.

This patch reworks those [un]lock functions and makes sure the values that get
locked and ref'ed later get unlocked and deref'ed.

ASTERISK-27074 #close

Change-Id: Ice96653e29bd9d6674ed5f95feb6b448ab148b09

8 years agobridge: stuck channel(s) after failed attended transfer
Kevin Harwell [Tue, 20 Jun 2017 21:01:48 +0000 (16:01 -0500)] 
bridge: stuck channel(s) after failed attended transfer

If an attended transfer failed it was possible for some of the channels
involved to get "stuck" because Asterisk was not hanging up the transfer target.

This patch ensures Asterisk hangs up the transfer target when an attended
transfer failure occurs.

ASTERISK-27075 #close

Change-Id: I98a6ecd92d3461ab98c36f0d9451d23adaf3e5f9

8 years agoMerge "res_corosync: Change thread stack size" into 13
Jenkins2 [Tue, 20 Jun 2017 23:12:14 +0000 (18:12 -0500)] 
Merge "res_corosync: Change thread stack size" into 13

8 years agoMerge "cdr: fix mistake spelling of a word for Unanswered." into 13
Jenkins2 [Tue, 20 Jun 2017 14:15:58 +0000 (09:15 -0500)] 
Merge "cdr: fix mistake spelling of a word for Unanswered." into 13

8 years agoMerge "res_pjsip_mwi: unsubscribe unsolicited MWI on deleting endpoint last contact...
Jenkins2 [Tue, 20 Jun 2017 10:45:51 +0000 (05:45 -0500)] 
Merge "res_pjsip_mwi: unsubscribe unsolicited MWI on deleting endpoint last contact" into 13

8 years agocdr: fix mistake spelling of a word for Unanswered.
Rodrigo Ramírez Norambuena [Mon, 19 Jun 2017 16:28:18 +0000 (12:28 -0400)] 
cdr: fix mistake spelling of a word for Unanswered.

Change-Id: I7a610bef369924523a445c7e849ee88cc45dc5df

8 years agoapp_voicemail: IMAP connection control
Alexei Gradinari [Mon, 19 Jun 2017 22:21:29 +0000 (18:21 -0400)] 
app_voicemail: IMAP connection control

A new global option "imap_poll_logout" was added to specify whether need to
disconnect from the IMAP server after polling of mailboxes.

ASTERISK-27068 #close

Closing IMAP connection after loading mailbox from voicemail.conf

ASTERISK-24052 #close

Change-Id: Ib7558ba04516240a32b65f42e9be64372a0ae12a

8 years agoMerge "res_stasis: Plug reference leak on stolen channels" into 13
Jenkins2 [Mon, 19 Jun 2017 16:38:02 +0000 (11:38 -0500)] 
Merge "res_stasis:  Plug reference leak on stolen channels" into 13

8 years agoMerge "app_voicemail: IMAP logout on reload/unload" into 13
George Joseph [Mon, 19 Jun 2017 14:19:38 +0000 (09:19 -0500)] 
Merge "app_voicemail: IMAP logout on reload/unload" into 13

8 years agoMerge "res_pjsip: New endpoint option "notify_early_inuse_ringing"" into 13
Jenkins2 [Mon, 19 Jun 2017 13:48:09 +0000 (08:48 -0500)] 
Merge "res_pjsip: New endpoint option "notify_early_inuse_ringing"" into 13

8 years agores_pjsip_mwi: unsubscribe unsolicited MWI on deleting endpoint last contact
Alexei Gradinari [Mon, 12 Jun 2017 21:17:38 +0000 (17:17 -0400)] 
res_pjsip_mwi: unsubscribe unsolicited MWI on deleting endpoint last contact

If the endpoint's last contact is deleted unsolicited MWI has to be
unsubscribed.

ASTERISK-27051 #close

Change-Id: I33e174e0b9dba0998927d16d6d100fda5c7254e0

8 years agoMerge "formats/format_g729: Fix typo in comment" into 13
Jenkins2 [Fri, 16 Jun 2017 21:16:18 +0000 (16:16 -0500)] 
Merge "formats/format_g729: Fix typo in comment" into 13

8 years agoMerge "Core/PBX: Deadlock between dialplan execution and application unregistration...
Jenkins2 [Fri, 16 Jun 2017 21:05:39 +0000 (16:05 -0500)] 
Merge "Core/PBX: Deadlock between dialplan execution and application unregistration." into 13

8 years agores_stasis: Plug reference leak on stolen channels
George Joseph [Fri, 16 Jun 2017 14:31:04 +0000 (08:31 -0600)] 
res_stasis:  Plug reference leak on stolen channels

When a stasis channel is stolen by another app, the control
structure is unreffed but never unlinked from the app_controls
container.  This causes the channel reference to leak.

Added OBJ_UNLINK to the callback in channel_stolen_cb.

Also added some additional channel lifecycle debug messages to
channel.c.

ASTERISK-27059 #close
Repoorted-by: George Joseph
Change-Id: Ib820936cd49453f20156971785e7f4f182c56e14

8 years agoformats/format_g729: Fix typo in comment
Matthew Fredrickson [Fri, 16 Jun 2017 19:56:37 +0000 (14:56 -0500)] 
formats/format_g729: Fix typo in comment

There was a typo in a comment.  This commit is to fix the typo.

ASTERISK-27060 #close

Change-Id: Ic2699f8dbeaacd58ccb6ec3203e853e1babe3235

8 years agores_pjsip: New endpoint option "notify_early_inuse_ringing"
Alexei Gradinari [Mon, 12 Jun 2017 14:23:56 +0000 (10:23 -0400)] 
res_pjsip: New endpoint option "notify_early_inuse_ringing"

This option was added to control whether to notify dialog-info state
'early' or 'confirmed' on Ringing when already INUSE.
The value "yes" is useful for some SIP phones (Cisco SPA)
to be able to indicate and pick up ringing devices.

ASTERISK-26919 #close

Change-Id: Ie050bc30023543c7dfb4365c5be3ce58c738c711

8 years agoMerge "res_ari: Add "module loaded" check to ari stubs" into 13
Jenkins2 [Fri, 16 Jun 2017 15:57:43 +0000 (10:57 -0500)] 
Merge "res_ari:  Add "module loaded" check to ari stubs" into 13

8 years agoMerge "chan_pjsip: Fix PJSIP_MEDIA_OFFER dialplan function read." into 13
Jenkins2 [Fri, 16 Jun 2017 12:48:28 +0000 (07:48 -0500)] 
Merge "chan_pjsip: Fix PJSIP_MEDIA_OFFER dialplan function read." into 13

8 years agores_corosync: Change thread stack size
Jan Friesse [Thu, 30 Mar 2017 14:33:51 +0000 (16:33 +0200)] 
res_corosync: Change thread stack size

In Corosync 2.x libraries were changed to use LibQB IPC.
Sadly LibQB IPC doesn't support copy-free access to received buffer, so
Corosync libraries were rewritten to use stack as buffer. Mostly the
needed stack size is quite small, but for all *_dispatch functions, 1MiB
is needed.

Asterisk function ast_pthread_create_background set stack size for new
thread to much smaller AST_BACKGROUND_STACKSIZE (~500KiB).

This results in Asterisk crash when running with Corosync 2.x.

Patch solves this issue by creating it's own version of
ast_pthread_create_background which sets stack size to much higher value
(actually it's AST_BACKGROUND_STACKSIZE + 3MiB).

Another problem may appear when "corosync show members" netconsole
command is executed. It is also executed in thread and also has only
500KiB stack size. Sadly it calls corosync_cfg_get_node_addrs which
again needs at least 1MiB stack.

Solution is to use HAVE_COROSYNC_CFG_STATE_TRACK as a discriminator
between Corosync 1.x and 2.x. If 1.x is found, nothing changes. If 2.x
is found, NodeID is displayed instead of IP address.

ASTERISK-25370 #close
Reported by: mdu113

Change-Id: Id95b0d21ab6e708e7d74ad8786c587211676fa08

8 years agores_ari: Add "module loaded" check to ari stubs
George Joseph [Tue, 13 Jun 2017 16:33:34 +0000 (10:33 -0600)] 
res_ari:  Add "module loaded" check to ari stubs

The recent change to make the use of LOAD_DECLINE more consistent
caused res_ari to unload itself before declining if the ari.conf
file wasn't found.  The ari stubs though still tried to use the
configuration resulting in segfaults.

This patch creates a new CHECK_ARI_MODULE_LOADED macro which tests
to see if res_ari is actually loaded and causes the stubs to also
decline if it isn't.  The macro was then added to the mustache
template's "load_module" function.

ASTERISK-27026 #close
Reported-by: Ronald Raikes
Change-Id: I263d56efa628ee3c411bdcd16d49af6260c6c91d

8 years agoMerge "channel: Fix reference counting in ast_channel_suppress." into 13
Jenkins2 [Thu, 15 Jun 2017 21:18:26 +0000 (16:18 -0500)] 
Merge "channel: Fix reference counting in ast_channel_suppress." into 13