]> git.ipfire.org Git - thirdparty/asterisk.git/log
thirdparty/asterisk.git
8 years agoMerge "chan_vpb: Fix a gcc 7 out-of-bounds complaint" into 15
Joshua Colp [Wed, 11 Oct 2017 21:38:51 +0000 (16:38 -0500)] 
Merge "chan_vpb:  Fix a gcc 7 out-of-bounds complaint" into 15

8 years agoMerge "app_originate: Set ORIGINATE_STATUS correctly on failure" into 15
Jenkins2 [Wed, 11 Oct 2017 20:42:16 +0000 (15:42 -0500)] 
Merge "app_originate: Set ORIGINATE_STATUS correctly on failure" into 15

8 years agoMerge "app_queue.c: clear moh field in init_queue" into 15
Jenkins2 [Wed, 11 Oct 2017 19:43:55 +0000 (14:43 -0500)] 
Merge "app_queue.c: clear moh field in init_queue" into 15

8 years agoMerge "cdr.c: Eliminated simple RAII_VAR usages." into 15
Jenkins2 [Wed, 11 Oct 2017 17:09:59 +0000 (12:09 -0500)] 
Merge "cdr.c: Eliminated simple RAII_VAR usages." into 15

8 years agochan_vpb: Fix a gcc 7 out-of-bounds complaint
George Joseph [Wed, 11 Oct 2017 12:03:41 +0000 (06:03 -0600)] 
chan_vpb:  Fix a gcc 7 out-of-bounds complaint

chan_vpb was trying to use sizeof(*p->play_dtmf), where
p->play_dtmf is defined as char[16], to get the length of the array
but since p->play_dtmf is an actual array, sizeof(*p->play_dtmf)
returns the size of the first array element, which is 1.  gcc7
validly complains because the context in which it's used could
cause an out-of-bounds condition.

Change-Id: If9c4bfdb6b02fa72d39e0c09bf88900663c000ba

8 years agoMerge "res_pjsip_registrar.c: Update remove_existing AOR contact handling." into 15
Jenkins2 [Wed, 11 Oct 2017 11:42:29 +0000 (06:42 -0500)] 
Merge "res_pjsip_registrar.c: Update remove_existing AOR contact handling." into 15

8 years agoapp_originate: Set ORIGINATE_STATUS correctly on failure
Sean Bright [Tue, 10 Oct 2017 17:01:05 +0000 (13:01 -0400)] 
app_originate: Set ORIGINATE_STATUS correctly on failure

We were ignoring the return value from ast_pbx_outgoing_exten() and
ast_pbx_outgoing_app() which could fail before setting the reason code.
This resulted in failures being reported as success.

ASTERISK-25266 #close
Reported by: Allen Ford

Change-Id: Idf16237b7e41b527d2c69c865829128686beeb3b

8 years agocontrib/thirdparty/sip_to_pjsip: add additional flag mappings
Torrey Searle [Tue, 3 Oct 2017 20:16:49 +0000 (22:16 +0200)] 
contrib/thirdparty/sip_to_pjsip: add additional flag mappings

add mappings for udptl redundancy, rtptimeout, and debug flags

Change-Id: Ie73cf5c83c05dee01eb9624ede76c1a30225d73a

8 years agocdr.c: Eliminated simple RAII_VAR usages.
Richard Mudgett [Mon, 2 Oct 2017 21:46:19 +0000 (16:46 -0500)] 
cdr.c: Eliminated simple RAII_VAR usages.

Change-Id: I150505db307249a962987e7b941bdd369bb91f35

8 years agoMerge "res_pjproject: Fix cleanup of buildopts vector." into 15
Jenkins2 [Tue, 10 Oct 2017 13:30:37 +0000 (08:30 -0500)] 
Merge "res_pjproject: Fix cleanup of buildopts vector." into 15

8 years agoMerge "tcptls: Do not re-bind to wildcard on client creation." into 15
Jenkins2 [Tue, 10 Oct 2017 12:50:28 +0000 (07:50 -0500)] 
Merge "tcptls: Do not re-bind to wildcard on client creation." into 15

8 years agores_pjproject: Fix cleanup of buildopts vector.
Corey Farrell [Tue, 10 Oct 2017 03:51:03 +0000 (23:51 -0400)] 
res_pjproject: Fix cleanup of buildopts vector.

ASTERISK-27306

Change-Id: I3bed0edf3f55b1d4adcbabb25ec14f11dc766c72

8 years agoMerge "res_pjsip: Fix issues that prevented shutdown of modules." into 15
Jenkins2 [Tue, 10 Oct 2017 01:19:20 +0000 (20:19 -0500)] 
Merge "res_pjsip: Fix issues that prevented shutdown of modules." into 15

8 years agoMerge "cdr.c: Replace redundant check with an ast_assert()" into 15
Jenkins2 [Tue, 10 Oct 2017 00:48:32 +0000 (19:48 -0500)] 
Merge "cdr.c: Replace redundant check with an ast_assert()" into 15

8 years agoMerge "cdr.h: Fix doxygen comments." into 15
Joshua Colp [Tue, 10 Oct 2017 00:08:09 +0000 (19:08 -0500)] 
Merge "cdr.h: Fix doxygen comments." into 15

8 years agoMerge "cdr.c: Use current ao2 flag names" into 15
Jenkins2 [Mon, 9 Oct 2017 23:15:28 +0000 (18:15 -0500)] 
Merge "cdr.c: Use current ao2 flag names" into 15

8 years agoMerge "cdr.c: Replace inlined code with ao2_t_replace()" into 15
Jenkins2 [Mon, 9 Oct 2017 21:59:59 +0000 (16:59 -0500)] 
Merge "cdr.c: Replace inlined code with ao2_t_replace()" into 15

8 years agoMerge "res_config_sqlite: Don't enable SQLite CDRs when running 'make samples'" into 15
Joshua Colp [Mon, 9 Oct 2017 21:43:40 +0000 (16:43 -0500)] 
Merge "res_config_sqlite: Don't enable SQLite CDRs when running 'make samples'" into 15

8 years agoMerge "res_pjsip_session: Fix format_cap leak." into 15
Jenkins2 [Mon, 9 Oct 2017 21:33:38 +0000 (16:33 -0500)] 
Merge "res_pjsip_session: Fix format_cap leak." into 15

8 years agoMerge "res_pjsip: Fix leak of persistent endpoint references." into 15
Jenkins2 [Mon, 9 Oct 2017 20:24:53 +0000 (15:24 -0500)] 
Merge "res_pjsip: Fix leak of persistent endpoint references." into 15

8 years agocdr.c: Replace redundant check with an ast_assert()
Richard Mudgett [Tue, 3 Oct 2017 21:09:58 +0000 (16:09 -0500)] 
cdr.c: Replace redundant check with an ast_assert()

The only caller of cdr_object_fn_table.process_party_b() explicitly does
the check before calling.

Change-Id: Ib0c53cdf5048227842846e0df9d2c19117c45618

8 years agocdr.c: Replace inlined code with ao2_t_replace()
Richard Mudgett [Mon, 2 Oct 2017 22:41:12 +0000 (17:41 -0500)] 
cdr.c: Replace inlined code with ao2_t_replace()

Change-Id: I9f424f5282ca7d833592f958d95f1b2bafb549b0

8 years agocdr.c: Use current ao2 flag names
Richard Mudgett [Fri, 29 Sep 2017 17:07:14 +0000 (12:07 -0500)] 
cdr.c: Use current ao2 flag names

Change-Id: Ib59d7d2f2a4a822754628f2c48a308d6791a6e6e

8 years agocdr.h: Fix doxygen comments.
Richard Mudgett [Fri, 29 Sep 2017 17:31:18 +0000 (12:31 -0500)] 
cdr.h: Fix doxygen comments.

* Also some misc formatting in cdr.c.

Change-Id: Ied89a28802a662c37c43326a1aafdce596e0df4a

8 years agores_pjsip_registrar.c: Update remove_existing AOR contact handling.
Richard Mudgett [Wed, 20 Sep 2017 23:36:15 +0000 (18:36 -0500)] 
res_pjsip_registrar.c: Update remove_existing AOR contact handling.

When "rewrite_contact" is enabled, the "max_contacts" count option can
block re-registrations because the source port from the endpoint can be
random.  When the re-registration is blocked, the endpoint may give up
re-registering and require manual intervention.

* The "remove_existing" option now allows a registration to succeed by
displacing any existing contacts that now exceed the "max_contacts" count.
Any removed contacts are the next to expire.  The behaviour change is
beneficial when "rewrite_contact" is enabled and "max_contacts" is greater
than one.  The removed contact is likely the old contact created by
"rewrite_contact" that the device is refreshing.

ASTERISK-27192

Change-Id: I64c107a10b70db1697d17136051ae6bf22b5314b

8 years agoMerge "res_sdp_translator_pjmedia: Fix test unregistration." into 15
Joshua Colp [Mon, 9 Oct 2017 17:01:59 +0000 (12:01 -0500)] 
Merge "res_sdp_translator_pjmedia: Fix test unregistration." into 15

8 years agores_config_sqlite: Don't enable SQLite CDRs when running 'make samples'
Sean Bright [Mon, 9 Oct 2017 13:15:54 +0000 (09:15 -0400)] 
res_config_sqlite: Don't enable SQLite CDRs when running 'make samples'

Change-Id: I65a5190b2732b2246d67472db70dd37db64ddad4

8 years agores/res_ari.c Fix: Memory leaks in ARI when using Content-Type: application/json
hajekd [Sun, 8 Oct 2017 19:05:56 +0000 (21:05 +0200)] 
res/res_ari.c Fix: Memory leaks in ARI when using Content-Type: application/json

ASTERISK-27305
Reported by: David Hajek
Tested by: David Hajek

Change-Id: Ife3e289062e6cf7d0e7d342dbf79ed96feff441e

8 years agotcptls: Do not re-bind to wildcard on client creation.
Alexander Traud [Sun, 8 Oct 2017 14:11:10 +0000 (16:11 +0200)] 
tcptls: Do not re-bind to wildcard on client creation.

Since ASTERISK-26922, this issue affected only those chan_sip which were
* enabled for dual-stack (bindaddr=::), and
* enabled for TCP (tcpenable=yes) and/or TLS (tlsenable=yes), and
* tried to register and/or invite a IPv4-only service,
* via TCP and/or TLS.
Now, ast_tcptls_client_create does not re-bind to [::] anymore.

ASTERISK-27324 #close

Change-Id: I4b242837bdeb1ec7130dc82505c6180a946fd9b5

8 years agores_pjsip_session: Fix format_cap leak.
Corey Farrell [Sat, 7 Oct 2017 20:47:53 +0000 (16:47 -0400)] 
res_pjsip_session: Fix format_cap leak.

ASTERISK-27306

Change-Id: I2c8d3fc148f9f53715c958314e1146f9611741f3

8 years agores_pjsip: Fix leak of persistent endpoint references.
Corey Farrell [Thu, 5 Oct 2017 21:26:14 +0000 (17:26 -0400)] 
res_pjsip: Fix leak of persistent endpoint references.

Do not manually call sip_endpoint_apply_handler from load_all_endpoints.
This is not necessary and causes memory leaks.

Additionally reinitialize persistent->aors when we reuse a persistent
object with a new endpoint.

ASTERISK-27306

Change-Id: I59bbfc8da8a14d5f4af8c5bb1e71f8592ae823eb

8 years agoMerge "vector: multiple evaluation of elem in AST_VECTOR_ADD_SORTED." into 15
Jenkins2 [Fri, 6 Oct 2017 20:22:42 +0000 (15:22 -0500)] 
Merge "vector: multiple evaluation of elem in AST_VECTOR_ADD_SORTED." into 15

8 years agoMerge "main/strings: Fix uninitialized value." into 15
George Joseph [Fri, 6 Oct 2017 20:09:48 +0000 (15:09 -0500)] 
Merge "main/strings: Fix uninitialized value." into 15

8 years agoMerge "res_pjsip: Fix leak of fake_auth references." into 15
Jenkins2 [Fri, 6 Oct 2017 19:12:27 +0000 (14:12 -0500)] 
Merge "res_pjsip: Fix leak of fake_auth references." into 15

8 years agovector: multiple evaluation of elem in AST_VECTOR_ADD_SORTED.
Corey Farrell [Thu, 5 Oct 2017 22:59:06 +0000 (18:59 -0400)] 
vector: multiple evaluation of elem in AST_VECTOR_ADD_SORTED.

Use temporary variable to prevent multiple evaluations of elem argument.
This resolves a memory leak in res_pjproject startup.

ASTERISK-27317 #close

Change-Id: Ib960d7f5576f9e1a3c478ecb48995582a574e06d

8 years agores_sdp_translator_pjmedia: Fix test unregistration.
Corey Farrell [Fri, 6 Oct 2017 00:55:31 +0000 (20:55 -0400)] 
res_sdp_translator_pjmedia: Fix test unregistration.

ASTERISK-27306

Change-Id: Ib3ed47167cb697ab7bd0a56cab589893f491651b

8 years agores_pjsip: Fix leak of fake_auth references.
Corey Farrell [Thu, 5 Oct 2017 20:54:12 +0000 (16:54 -0400)] 
res_pjsip: Fix leak of fake_auth references.

pjsip_distributor leaks references to fake_auth when the default realm
has not changed.

ASTERISK-27306

Change-Id: I3fcf103b3680ad2d1d4610dcd6738eeaebf4d202

8 years agoapp_queue.c: clear moh field in init_queue
Nathan Bruning [Fri, 6 Oct 2017 07:39:42 +0000 (09:39 +0200)] 
app_queue.c: clear moh field in init_queue

ASTERISK-27301 #close

Change-Id: Ic31361f34e2de3b6470e68fc37205a7711082eba

8 years agomain/strings: Fix uninitialized value.
Corey Farrell [Fri, 6 Oct 2017 01:23:31 +0000 (21:23 -0400)] 
main/strings: Fix uninitialized value.

ast_strings_match uses sscanf and checks for non-zero return to verify a
token was parsed. This is incorrect as sscanf returns EOF (-1) for errors.

ASTERISK-27318 #close

Change-Id: Ifcece92605f58116eff24c5a0a3b0ee08b3c87b1

8 years agores_pjsip_caller_id chan_sip: Comply to RFC 3323 values for privacy
Daniel Tryba [Mon, 2 Oct 2017 12:48:41 +0000 (14:48 +0200)] 
res_pjsip_caller_id chan_sip: Comply to RFC 3323 values for privacy

Currently privacy requests are only granted if the Privacy header
value is exactly "id" (defined in RFC 3325). It ignores any other
possible value (or a combination there of). This patch reverses the
logic from testing for "id" to grant privacy, to testing for "none" and
granting privacy for any other value. "none" must not be used in
combination with any other value (RFC 3323 section 4.2).

ASTERISK-27284 #close

Change-Id: If438a21f31a962da32d7a33ff33bdeb1e776fe56

8 years agores_pjsip: Fix issues that prevented shutdown of modules.
Corey Farrell [Wed, 4 Oct 2017 15:46:44 +0000 (11:46 -0400)] 
res_pjsip: Fix issues that prevented shutdown of modules.

res_pjsip and res_pjsip_session had circular references, preventing both
modules from shutting down.
* Move session supplement registration to res_pjsip.
* Use create internal functions for use by pjsip_message_filter.c.

ASTERISK-27306

Change-Id: Ifbd5c19ec848010111afeab2436f9699da06ba6b

8 years agoMerge "app_queue.c: Fix announcements when announce-to-first-user not enabled." into 15
Jenkins2 [Wed, 4 Oct 2017 20:00:07 +0000 (15:00 -0500)] 
Merge "app_queue.c: Fix announcements when announce-to-first-user not enabled." into 15

8 years agores_calendar_icalendar: Filter out occurrences superceded by another VEVENT
krells [Thu, 28 Sep 2017 07:56:14 +0000 (09:56 +0200)] 
res_calendar_icalendar: Filter out occurrences superceded by another VEVENT

When we are loading the calendars, we call libical's
icalcomponent_foreach_recurrence method for each VEVENT component that
we have in our calendar.

That method has no knowledge concerning the existence of the other
VEVENT components and will feed our callback with all ocurrences
matching the requested time span.

The occurrences generated by icalcomponent_foreach_recurrence while
expanding a recurring VEVENT's RRULE and RDATE properties can be
superceded by an other VEVENT sharing the same UID.

I use an external iterator (in libical terminology) to avoid messing
with the internal ones from the calling function, and search for
VEVENTS which could supersede the current occurrence.

The event which can invalidate this occurence needs to have:

- the same UID as our recurrent component (comp)
- a RECURRENCE-ID property, which represents the start time of this
  occurrence

If one component is found, just clean and return.

ASTERISK-27296 #close
Reported by: Benoît Dereck-Tricot

Change-Id: I8587ae3eaa765af7cb21eda3b6bf84e8a1c87af8

8 years agoMerge "heap.c: No need to calloc heap pointer array." into 15
Jenkins2 [Wed, 4 Oct 2017 01:36:59 +0000 (20:36 -0500)] 
Merge "heap.c: No need to calloc heap pointer array." into 15

8 years agoMerge "logger: Bring back ability to turn debug on by source file" into 15
Jenkins2 [Tue, 3 Oct 2017 15:09:01 +0000 (10:09 -0500)] 
Merge "logger:  Bring back ability to  turn debug on by source file" into 15

8 years agoapp_queue.c: Fix announcements when announce-to-first-user not enabled.
Richard Mudgett [Thu, 28 Sep 2017 22:37:15 +0000 (17:37 -0500)] 
app_queue.c: Fix announcements when announce-to-first-user not enabled.

The previous patch for ASTERISK-27216 made it so you wouldn't get any
position or periodic announcements unless you had announce-to-first-user
enabled.  The announce-to-first-user feature was added by ASTERISK_21782
as a result of the patch which introduced the redundant announcements that
ASTERISK-27216 removes.

* By noting that the makeannouncement variable is used to suppresses the
first user announcement, we set its initial value to the
announce-to-first-user enable setting.

ASTERISK-27216

Change-Id: Ieaeb7dbea8ae7073086b775fbafe0625b000b10a

8 years agoheap.c: No need to calloc heap pointer array.
Richard Mudgett [Thu, 21 Sep 2017 19:43:09 +0000 (14:43 -0500)] 
heap.c: No need to calloc heap pointer array.

Change-Id: I5ae2f316229f336eb90d99c7af7ed07a33097e68

8 years agoMerge "pjsip_message_filter: Fix regression causing bad contact address" into 15
Jenkins2 [Thu, 28 Sep 2017 18:26:54 +0000 (13:26 -0500)] 
Merge "pjsip_message_filter: Fix regression causing bad contact address" into 15

8 years agoMerge "res_stasis: Add 'video_sfu' as a requested bridge type." into 15
Jenkins2 [Thu, 28 Sep 2017 17:36:47 +0000 (12:36 -0500)] 
Merge "res_stasis: Add 'video_sfu' as a requested bridge type." into 15

8 years agoMerge "res_pjsip_session: outgoing call did not offer all configured codecs" into 15
Jenkins2 [Thu, 28 Sep 2017 17:32:49 +0000 (12:32 -0500)] 
Merge "res_pjsip_session: outgoing call did not offer all configured codecs" into 15

8 years agologger: Bring back ability to turn debug on by source file
George Joseph [Wed, 27 Sep 2017 18:45:21 +0000 (12:45 -0600)] 
logger:  Bring back ability to  turn debug on by source file

Somewhere along the way we lost the ability to debug individual
source files.  For modules, this wasn't a big deal but all the
source files in ./main are in the one "core" module so debugging
individual core capabilities was almost impossible.

* Added a test to DEBUG_ATLEAST that also checks __FILE__ instead
of just module name.  Any source file will work even if it's in
a module subdirectory.

Change-Id: Icc0af41837f3b1679dec7af21fa32cd1f7469f6e

8 years agoMerge "pjproject: Patch to correct STUN FINGERPRINT usage" into 15
Joshua Colp [Thu, 28 Sep 2017 13:07:15 +0000 (08:07 -0500)] 
Merge "pjproject: Patch to correct STUN FINGERPRINT usage" into 15

8 years agoMerge "res_rtp_asterisk.c: Fix bridge_p2p_rtp_write() reentrancy potential." into 15
Jenkins2 [Thu, 28 Sep 2017 11:49:30 +0000 (06:49 -0500)] 
Merge "res_rtp_asterisk.c: Fix bridge_p2p_rtp_write() reentrancy potential." into 15

8 years agoMerge "res_rtp_asterisk: Trim trailing byte off of SDES packet" into 15
Joshua Colp [Thu, 28 Sep 2017 11:23:22 +0000 (06:23 -0500)] 
Merge "res_rtp_asterisk: Trim trailing byte off of SDES packet" into 15

8 years agores_stasis: Add 'video_sfu' as a requested bridge type.
Joshua Colp [Thu, 28 Sep 2017 10:33:00 +0000 (10:33 +0000)] 
res_stasis: Add 'video_sfu' as a requested bridge type.

This change adds 'video_sfu' as a requested bridge type when
creating a bridge. By specifying this a mixing type bridge is
created that exchanges video in an SFU fashion.

Change-Id: I2ada47cf5f3fc176518b647c0b4aa39d55339606

8 years agores_pjsip_outbound_publish.c: Fix misplaced parenthesis.
Richard Mudgett [Wed, 27 Sep 2017 16:16:16 +0000 (11:16 -0500)] 
res_pjsip_outbound_publish.c: Fix misplaced parenthesis.

The pjsip_publishc_init() call was referenced with a misplaced
parentheses.  As a result, outbound publication messages went out with an
expiration of 1 second.

ASTERISK-27298

Change-Id: I93622eabc8ee83e7a22e98c107f921284c605a08

8 years agopjsip_message_filter: Fix regression causing bad contact address
George Joseph [Tue, 26 Sep 2017 16:01:48 +0000 (10:01 -0600)] 
pjsip_message_filter: Fix regression causing bad contact address

The "res_pjsip:  Filter out non SIP(S) requests" commit moved the
filtering of messages to pjproject's PJSIP_MOD_PRIORITY_TRANSPORT_LAYER
in order to filter out incoming bad uri schemes as early as possible.
Since the change affected outgoing messages as well and the TRANSPORT
layer is the last to be run on outgoing messages, we were overwriting
the setting of external_signaling_address (which is set earlier by
res_pjsip_nat) with an internal address.

* pjsip_message_filter now registers itself as a pjproject module
twice.  Once in the TSX layer for the outgoing messages (as it was
originally), then a second time in the TRANSPORT layer for the
incoming messages to catch the invalid uri schemes.

ASTERISK-27295
Reported by: Sean Bright

Change-Id: I2c90190c43370f8a9d1c4693a19fd65840689c8c

8 years agores_rtp_asterisk.c: Fix bridge_p2p_rtp_write() reentrancy potential.
Richard Mudgett [Thu, 14 Sep 2017 02:31:52 +0000 (21:31 -0500)] 
res_rtp_asterisk.c: Fix bridge_p2p_rtp_write() reentrancy potential.

The bridge_p2p_rtp_write() has potential reentrancy problems.

* Accessing the bridged RTP members must be done with the instance1 lock
held.  The DTMF and asymmetric codec checks must be split to be done with
the correct RTP instance struct locked.  i.e., They must be done when
working on the appropriate side of the point to point bridge.

* Forcing the RTP mark bit was referencing the wrong side of the point to
point bridge.  The set mark bit is used everywhere else to set the mark
bit when sending not receiving.

The patches for ASTERISK_26745 and ASTERISK_27158 did not take into
account that not everything carried by RTP uses a codec.  The telephony
DTMF events are not exchanged with a codec.  As a result when
RFC2833/RFC4733 sent digits you would crash if "core set debug 1" is
enabled, the DTMF digits would always get passed to the core even though
the local native RTP bridge is active, and the DTMF digits would go out
using the wrong SSRC id.

* Add protection for non-format payload types like DTMF when updating the
lastrxformat and lasttxformat.  Also protect against non-format payload
types when checking for asymmetric codecs.

ASTERISK-27292

Change-Id: I6344ab7de21e26f84503c4d1fca1a41579364186

8 years agores_rtp_asterisk: Trim trailing byte off of SDES packet
Sean Bright [Tue, 26 Sep 2017 15:55:29 +0000 (11:55 -0400)] 
res_rtp_asterisk: Trim trailing byte off of SDES packet

This could have been fixed by subtracting 1 from the final value of
'len' but the way the packet was being constructed was confusing so I
took the opportunity to (I think) make it more clear.

We were sending 1 extra byte at the end of the SDES RTCP packet which
caused Chrome to complain (in its debug log):

    Too little data (1 byte) remaining in buffer to parse
    RTCP header (4 bytes).

We now send the correct number of bytes.

Change-Id: I9dcf087cdaf97da0374ae0acb7d379746a71e81b

8 years agoMerge "webrtc: Allow 'webrtc' to be set on endpoints without dtls_ca_file" into 15
Joshua Colp [Tue, 26 Sep 2017 12:29:20 +0000 (07:29 -0500)] 
Merge "webrtc: Allow 'webrtc' to be set on endpoints without dtls_ca_file" into 15

8 years agoMerge "channel.c: Fix invalid reference in conditionaled out code." into 15
Joshua Colp [Tue, 26 Sep 2017 12:06:09 +0000 (07:06 -0500)] 
Merge "channel.c: Fix invalid reference in conditionaled out code." into 15

8 years agoMerge "app_queue: Only do announcement logic between ringing cycles" into 15
Jenkins2 [Tue, 26 Sep 2017 11:28:04 +0000 (06:28 -0500)] 
Merge "app_queue: Only do announcement logic between ringing cycles" into 15

8 years agoMerge "res_pjsip_session: Reduce (and improve) SDP renegotiation." into 15
Jenkins2 [Mon, 25 Sep 2017 19:19:01 +0000 (14:19 -0500)] 
Merge "res_pjsip_session: Reduce (and improve) SDP renegotiation." into 15

8 years agowebrtc: Allow 'webrtc' to be set on endpoints without dtls_ca_file
Sean Bright [Mon, 25 Sep 2017 18:00:53 +0000 (14:00 -0400)] 
webrtc: Allow 'webrtc' to be set on endpoints without dtls_ca_file

If using a legitimate certificate from a trusted certificate authority,
you don't need to provide CA file.

Change-Id: I8623973b4209b44889243716d7880274caed8a6d

8 years agopjproject: Patch to correct STUN FINGERPRINT usage
Sean Bright [Mon, 25 Sep 2017 18:09:33 +0000 (14:09 -0400)] 
pjproject: Patch to correct STUN FINGERPRINT usage

Change-Id: I0e453253dff1388b0186b36c754457c1d0d12db6

8 years agoMerge "build: A few gcc 7 error fixes" into 15
Joshua Colp [Mon, 25 Sep 2017 17:45:03 +0000 (12:45 -0500)] 
Merge "build:  A few gcc 7 error fixes" into 15

8 years agores_pjsip_session: outgoing call did not offer all configured codecs
Kevin Harwell [Mon, 25 Sep 2017 17:30:56 +0000 (12:30 -0500)] 
res_pjsip_session: outgoing call did not offer all configured codecs

For some scenarios when an outgoing call was made only a subset of the
configured codecs were offered. If the codecs being offered happened to
not have a codec supported by the phone then the call would fail.

For instance Alice and Bob both are configured in Asterisk for g722 and ulaw(
allow=!all,g722,ulaw). Alice's endpoint however only supports g722 while Bob's
only supports ulaw. When Alice calls Bob, Alice negotiates g722 fine with
Asterisk. But when Asterisk sends the outgoing offer to Bob it only contains
g722 and not both g722 and ulaw, so the call ends.

This patch makes it so all the audio codecs configured on the endpoint always
get sent, and not just a subset. However priority is given to those codecs that
are compatible with the "other side".

ASTERISK-27259 #close

Change-Id: Iffabc373bd94cd1dc700925dcfe406e12918c696

8 years agoMerge "res_pjsip_session: Don't end session when receiving a 500 on a reinvite" into 15
Joshua Colp [Mon, 25 Sep 2017 17:23:58 +0000 (12:23 -0500)] 
Merge "res_pjsip_session: Don't end session when receiving a 500 on a reinvite" into 15

8 years agochannel.c: Fix invalid reference in conditionaled out code.
Richard Mudgett [Mon, 25 Sep 2017 15:59:17 +0000 (10:59 -0500)] 
channel.c: Fix invalid reference in conditionaled out code.

ASTERISK-27289

Change-Id: I7a415948116493050614d9f4fa91ffbe0c21ec4c

8 years agoMerge "app_stream_echo: Don't echo declined streams" into 15
Joshua Colp [Mon, 25 Sep 2017 12:48:33 +0000 (07:48 -0500)] 
Merge "app_stream_echo: Don't echo declined streams" into 15

8 years agobuild: A few gcc 7 error fixes
George Joseph [Mon, 25 Sep 2017 12:25:06 +0000 (06:25 -0600)] 
build:  A few gcc 7 error fixes

Change-Id: I7b5300fbf1af7d88d47129db13ad6dbdc9b553ec

8 years agoMerge "res_pjsip: Use ast_sip_is_content_type() where appropriate" into 15
Joshua Colp [Mon, 25 Sep 2017 12:28:48 +0000 (07:28 -0500)] 
Merge "res_pjsip: Use ast_sip_is_content_type() where appropriate" into 15

8 years agoapp_queue: Only do announcement logic between ringing cycles
StefanEng86 [Fri, 15 Sep 2017 07:59:59 +0000 (09:59 +0200)] 
app_queue: Only do announcement logic between ringing cycles

This patch reverts the change by patch 2263 from old reviewboard.
Note that reverting that 2263-patch still preserves the behaviour that
the commit log of the 2263-patch claimed to add. The reason for this is:

The function wait_for_answer is only called from try_calling which
in turn is only called from the main for loop in queue_exec, and
earlier in that loop we already check the things that's removed by
this patch. There's no need to check those things twice each loop
iteration, and I think the proper place to check it is before each
ringing cycle. By checking it in wait_for_answer, you allow the issue
explained in the jira - that the head caller hears announcements while
the agents' sip phones are actively ringing.

Reported-by: Stefan Engström
Tested-by: Stefan Engström
ASTERISK-27216 #close

Change-Id: Ic4290dc75256f9743900c6762ee1bb915f672db0

8 years agoapp_stream_echo: Don't echo declined streams
Sean Bright [Sat, 23 Sep 2017 17:32:26 +0000 (13:32 -0400)] 
app_stream_echo: Don't echo declined streams

Discovered while experimenting with Cyber Mega Phone 2K Ultimate Dynamic
Edition after accepting the audio request but declining the video one.

Change-Id: Iaa86d41fccfbc1b559a30ccf740d78a3b5f8a98c

8 years agores_pjsip_session: Reduce (and improve) SDP renegotiation.
Joshua Colp [Fri, 22 Sep 2017 22:49:21 +0000 (22:49 +0000)] 
res_pjsip_session: Reduce (and improve) SDP renegotiation.

When pruning a request to change the topology of a channel be
more intelligent about the resulting topology that is actually
used for SDP renegotiation.

In a case where a stream has not already been negotiated we
don't need to renegotiate and offer a declined stream. This can
occur if something in Asterisk (such as ConfBridge) requests
to add video to a PJSIP channel that has no video codecs configured.
In this case since the stream did not already exist we can safely
remove the stream from the requested topology, resulting in no
renegotiation occurring.

In a case where a renegotiation is requested with a codec that is
not supported we can reuse the formats of the existing stream if
it exists to ensure that the stream continues to flow, instead of
removing it.

Change-Id: I636540798d55922377318fe619c510fb6ed125fb

8 years agores_pjsip_session: Don't end session when receiving a 500 on a reinvite
Kevin Harwell [Fri, 22 Sep 2017 20:29:24 +0000 (15:29 -0500)] 
res_pjsip_session: Don't end session when receiving a 500 on a reinvite

During a reinvite, if a remote endpoint error occurs and it returns a 500 the
session would end. This patch makes it so the session is not terminated, but
continues as it was.

The reason for this is because some endpoints may send non session terminating
"server errors" like a failed codec negotiation. So in this case instead of
ending the call it can hopefully continue. In the case of a real server error
the session is already "doomed", will be known soon enough and appropriately
ended by Asterisk later.

Change-Id: Ifeedae86b8cb44b92d52c79046522ec5f0aff1d5

8 years agoMerge "res_pjsip_session/BUNDLE: Handle no audio codecs on endpoint" into 15
Joshua Colp [Fri, 22 Sep 2017 20:36:07 +0000 (15:36 -0500)] 
Merge "res_pjsip_session/BUNDLE:  Handle no audio codecs on endpoint" into 15

8 years agoMerge "res_pjsip_session: Change some asserts to warning/debug messages" into 15
Joshua Colp [Fri, 22 Sep 2017 16:09:40 +0000 (11:09 -0500)] 
Merge "res_pjsip_session:  Change some asserts to warning/debug messages" into 15

8 years agores_pjsip: Use ast_sip_is_content_type() where appropriate
Sean Bright [Fri, 22 Sep 2017 15:02:11 +0000 (11:02 -0400)] 
res_pjsip: Use ast_sip_is_content_type() where appropriate

Change-Id: If3ab0d73d79ac4623308bd48508af2bfd554937d

8 years agores_pjsip_session/BUNDLE: Handle no audio codecs on endpoint
George Joseph [Thu, 21 Sep 2017 14:47:11 +0000 (08:47 -0600)] 
res_pjsip_session/BUNDLE:  Handle no audio codecs on endpoint

When an INVITE came in with both audio and video streams but there
were no audio codecs defined for the endpoint, we weren't declining
the audio stream.  Since it's usually the first/transport stream,
when the video stream was processed and tried to use the transport,
it was empty and caused a crash.  We now decline the the stream if
there are no matching codecs so when the video stream is processed,
it's now the first/transport stream and processes normally.

Change-Id: Ic854eda54c95031e66b076ecfae3041d34daa692

8 years agoMerge "res_config_pgsql: Fix removed support to previous for versions PostgreSQL...
Joshua Colp [Fri, 22 Sep 2017 10:49:30 +0000 (05:49 -0500)] 
Merge "res_config_pgsql: Fix removed support to previous for versions PostgreSQL 9.1" into 15

8 years agoMerge "res_rtp_asterisk.c: Fix bundled SSRC handling." into 15
George Joseph [Fri, 22 Sep 2017 10:39:15 +0000 (05:39 -0500)] 
Merge "res_rtp_asterisk.c: Fix bundled SSRC handling." into 15

8 years agoMerge "bridge: Change participant SFU streams when source streams change." into 15
Joshua Colp [Thu, 21 Sep 2017 19:59:52 +0000 (14:59 -0500)] 
Merge "bridge: Change participant SFU streams when source streams change." into 15

8 years agoMerge "AST-2017-008: Improve RTP and RTCP packet processing." into 15
Joshua Colp [Thu, 21 Sep 2017 19:47:59 +0000 (14:47 -0500)] 
Merge "AST-2017-008: Improve RTP and RTCP packet processing." into 15

8 years agoMerge "res_pjsip_session: Check for removed stream state." into 15
Joshua Colp [Thu, 21 Sep 2017 17:30:06 +0000 (12:30 -0500)] 
Merge "res_pjsip_session: Check for removed stream state." into 15

8 years agobridge: Change participant SFU streams when source streams change.
Joshua Colp [Sat, 16 Sep 2017 14:19:59 +0000 (11:19 -0300)] 
bridge: Change participant SFU streams when source streams change.

Some endpoints do not like a stream being reused for a new
media stream. The frame/jitterbuffer can rely on underlying
attributes of the media stream in order to order the packets.
When a new stream takes its place without any notice the
buffer can get confused and the media ends up getting dropped.

This change uses the SSRC change to determine that a new source
is reusing an existing stream and then bridge_softmix renegotiates
each participant such that they see a new media stream. This
causes the frame/jitterbuffer to start fresh and work as expected.

ASTERISK-27277

Change-Id: I30ccbdba16ca073d7f31e0e59ab778c153afae07

8 years agoMerge "res_srtp: lower log level of auth failures" into 15
Jenkins2 [Thu, 21 Sep 2017 16:58:41 +0000 (11:58 -0500)] 
Merge "res_srtp: lower log level of auth failures" into 15

8 years agoMerge "chan_sip: Expose read-only access to the full SIP INVITE Request-URI" into 15
Joshua Colp [Thu, 21 Sep 2017 16:40:17 +0000 (11:40 -0500)] 
Merge "chan_sip: Expose read-only access to the full SIP INVITE Request-URI" into 15

8 years agores_config_pgsql: Fix removed support to previous for versions PostgreSQL 9.1
Rodrigo Ramírez Norambuena [Tue, 19 Sep 2017 10:22:50 +0000 (07:22 -0300)] 
res_config_pgsql: Fix removed support to previous for versions PostgreSQL 9.1

In PostgreSQL 9.1 the backslash are string literals and not the escape
of characters.

In previous issue ASTERISK_26057 was fixed the use of escape LIKE but the
support for old version of Postgresql than 9.1 was dropped. The sentence
before make was "ESCAPE '\'" but in version before than 9.1  need it to be
as follow "ESCAPE '\\'".

ASTERISK-27283

Change-Id: I96d9ee1ed7693ab17503cb36a9cd72847165f949

8 years agoMerge "bridge : Fix one-way direct-media when early bridging with native_rtp" into 15
Jenkins2 [Thu, 21 Sep 2017 15:45:03 +0000 (10:45 -0500)] 
Merge "bridge : Fix one-way direct-media when early bridging with native_rtp" into 15

8 years agores_pjsip_session: Change some asserts to warning/debug messages
George Joseph [Wed, 20 Sep 2017 15:45:16 +0000 (09:45 -0600)] 
res_pjsip_session:  Change some asserts to warning/debug messages

There was an issue reported where an SDP received on a 183 Session
Progress message caused a crash because the pending streams had
already been processed when the OK was received.  In that case the
pending topology was legitimately NULL.  There was an assert for an
incorrect number of streams in the topology but not one for
topology being NULL.  In any case, if you're not in dev-mode the
asserts don't do anything and since the scenario is legit, the
asserts weren't appropriate anyway.

* Changed several asserts to warning or debug messages and return
codes as appropriate.

ASTERISK-27264
Reported by: Daniel Heckl

Change-Id: I58daaa9d2938fa980857ab3ec41925ab5ff9c848

8 years agoMerge "chan_pjsip: Ignore AST_CONTROL_STREAM_TOPOLOGY_CHANGED for now" into 15
Joshua Colp [Wed, 20 Sep 2017 20:32:40 +0000 (15:32 -0500)] 
Merge "chan_pjsip: Ignore AST_CONTROL_STREAM_TOPOLOGY_CHANGED for now" into 15

8 years agores_pjsip_session: Check for removed stream state.
Ben Ford [Fri, 15 Sep 2017 14:43:21 +0000 (09:43 -0500)] 
res_pjsip_session: Check for removed stream state.

When a sip session is refreshed, the stream topology is looped
through, checking each stream for compatible formats. This would
cause a crash if the stream state was AST_STREAM_STATE_REMOVED,
since the formats would never be set for this stream, causing
a NULL value to be returned from ast_stream_get_formats. This
commit adds a check for streams with removed states.

Also removed a stray semicolon.

Change-Id: Ic86f8b65a4a26a60885b28b8b1a0b22e1b471d42

8 years agochan_pjsip: Ignore AST_CONTROL_STREAM_TOPOLOGY_CHANGED for now
George Joseph [Tue, 19 Sep 2017 10:44:28 +0000 (04:44 -0600)] 
chan_pjsip: Ignore AST_CONTROL_STREAM_TOPOLOGY_CHANGED for now

chan_pjsip_indicate was missing a case for the recently added
AST_CONTROL_STREAM_TOPOLOGY_CHANGED condition and was returning an
error and causing the call to be hung up instead of just ignoring
it.

ASTERISK-27260
Reported by: Daniel Heckl

Change-Id: I4fecbb00a0b8a853da85155065c1a6bddf235e80

8 years agobridge : Fix one-way direct-media when early bridging with native_rtp
Jean Aunis [Thu, 7 Sep 2017 09:41:09 +0000 (11:41 +0200)] 
bridge : Fix one-way direct-media when early bridging with native_rtp

When two channels were early bridged in a native_rtp bridge, the RTP description
on one side was not updated when the other side answered.
This patch forbids non-answered channels to enter a native_rtp bridge, and
triggers a bridge reconfiguration when an ANSWER frame is received.

ASTERISK-27257

Change-Id: If1aaee1b4ed9658a1aa91ab715ee0a6413b878df

8 years agores_srtp: lower log level of auth failures
Alexander Traud [Mon, 18 Sep 2017 14:51:15 +0000 (16:51 +0200)] 
res_srtp: lower log level of auth failures

Previously, sRTP authentication failures were reported on log level WARNING.
When such failures happen, each RT(C)P packet is affected, spamming the log.
Now, those failures are reported at log level VERBOSE 2. Furthermore, the
amount is further reduced (previously all two seconds, now all three seconds).
Additionally, the new log entry informs whether media (RTP) or statistics (RTCP)
are affected.

ASTERISK-16898 #close

Change-Id: I6c98d46b711f56e08655abeb01c951ab8e8d7fa0

8 years agoMerge "res_pjsip_pubsub: Check for Content-Type header in rx_notify_request" into 15
Jenkins2 [Wed, 20 Sep 2017 13:10:42 +0000 (08:10 -0500)] 
Merge "res_pjsip_pubsub:  Check for Content-Type header in rx_notify_request" into 15

8 years agochan_sip: Expose read-only access to the full SIP INVITE Request-URI
David J. Pryke [Tue, 19 Sep 2017 14:34:01 +0000 (10:34 -0400)] 
chan_sip: Expose read-only access to the full SIP INVITE Request-URI

Provide a way to get the contents of the the Request URI from the initial SIP
INVITE in dial plan function call. (In this case "${CHANNEL(ruri)}")

ASTERISK-27278
Reported by: David J. Pryke
Tested by: David J. Pryke

Change-Id: I1dd4d6988eed1b6c98a9701e0e833a15ef0dac3e

8 years agoMerge "res_calendar: Plug memory leak and micro-optimization" into 15
Jenkins2 [Wed, 20 Sep 2017 11:59:04 +0000 (06:59 -0500)] 
Merge "res_calendar: Plug memory leak and micro-optimization" into 15

8 years agores_rtp_asterisk.c: Fix bundled SSRC handling.
Richard Mudgett [Tue, 19 Sep 2017 19:28:37 +0000 (14:28 -0500)] 
res_rtp_asterisk.c: Fix bundled SSRC handling.

Assertions in the v15+ AST-2017-008 patches found that we were not
handling the case if the incoming SDP did not specify the required SSRC
attributes for bundled to work.

* Be strict on matching SSRC for bundled instances including the parent
instance.  If the SSRC doesn't match then discard the packet.  Bundled has
to tell us in the SDP signaling what SSRC to expect.  Otherwise, we will
not know how to find the bundled instance structure.

Change-Id: I152830bbff71c662408909042068fada39e617f9