Commit Graph

29883 Commits

Author SHA1 Message Date
Corey Farrell
baf331f4bc 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
2017-10-06 13:38:51 -05:00
Daniel Tryba
ba37dd65d3 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
2017-10-05 07:46:44 -05:00
Jenkins2
88e8c22b02 Merge "app_queue.c: Fix announcements when announce-to-first-user not enabled." into 15 2017-10-04 15:00:07 -05:00
krells
2e1424363a 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
2017-10-04 10:02:47 -05:00
Jenkins2
c47a8c22e7 Merge "heap.c: No need to calloc heap pointer array." into 15 2017-10-03 20:36:59 -05:00
Jenkins2
af288f5eff Merge "logger: Bring back ability to turn debug on by source file" into 15 2017-10-03 10:09:01 -05:00
Richard Mudgett
3344fe4ff9 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
2017-09-28 18:48:09 -05:00
Richard Mudgett
ade7253c9d heap.c: No need to calloc heap pointer array.
Change-Id: I5ae2f316229f336eb90d99c7af7ed07a33097e68
2017-09-28 15:49:34 -05:00
Jenkins2
b4e511c41b Merge "pjsip_message_filter: Fix regression causing bad contact address" into 15 2017-09-28 13:26:54 -05:00
Jenkins2
d610cd59e6 Merge "res_stasis: Add 'video_sfu' as a requested bridge type." into 15 2017-09-28 12:36:47 -05:00
Jenkins2
88372c7844 Merge "res_pjsip_session: outgoing call did not offer all configured codecs" into 15 2017-09-28 12:32:49 -05:00
George Joseph
d7e47c88b2 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
2017-09-28 12:18:47 -05:00
Joshua Colp
3480e285b1 Merge "pjproject: Patch to correct STUN FINGERPRINT usage" into 15 2017-09-28 08:07:15 -05:00
Jenkins2
c9b3b89ed6 Merge "res_rtp_asterisk.c: Fix bridge_p2p_rtp_write() reentrancy potential." into 15 2017-09-28 06:49:30 -05:00
Joshua Colp
17629e5e19 Merge "res_rtp_asterisk: Trim trailing byte off of SDES packet" into 15 2017-09-28 06:23:22 -05:00
Joshua Colp
ce08a5b3f6 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
2017-09-28 10:33:00 +00:00
Richard Mudgett
7192cacfea 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
2017-09-27 11:25:35 -05:00
George Joseph
ab15481553 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
2017-09-26 11:46:53 -05:00
Richard Mudgett
1eb84bdb8a 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
2017-09-26 11:19:03 -05:00
Sean Bright
a3583cabbd 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
2017-09-26 11:58:28 -04:00
Joshua Colp
4e4520854a Merge "webrtc: Allow 'webrtc' to be set on endpoints without dtls_ca_file" into 15 2017-09-26 07:29:20 -05:00
Joshua Colp
63c9f838ad Merge "channel.c: Fix invalid reference in conditionaled out code." into 15 2017-09-26 07:06:09 -05:00
Jenkins2
0220915cb2 Merge "app_queue: Only do announcement logic between ringing cycles" into 15 2017-09-26 06:28:04 -05:00
Jenkins2
629e9bb6a0 Merge "res_pjsip_session: Reduce (and improve) SDP renegotiation." into 15 2017-09-25 14:19:01 -05:00
Sean Bright
a89f14f2d6 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
2017-09-25 13:11:32 -05:00
Sean Bright
c96317c138 pjproject: Patch to correct STUN FINGERPRINT usage
Change-Id: I0e453253dff1388b0186b36c754457c1d0d12db6
2017-09-25 13:10:10 -05:00
Joshua Colp
cb5c935591 Merge "build: A few gcc 7 error fixes" into 15 2017-09-25 12:45:03 -05:00
Kevin Harwell
3d658e3be4 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
2017-09-25 12:34:23 -05:00
Joshua Colp
132faf9922 Merge "res_pjsip_session: Don't end session when receiving a 500 on a reinvite" into 15 2017-09-25 12:23:58 -05:00
Richard Mudgett
1728e439e8 channel.c: Fix invalid reference in conditionaled out code.
ASTERISK-27289

Change-Id: I7a415948116493050614d9f4fa91ffbe0c21ec4c
2017-09-25 10:59:34 -05:00
Joshua Colp
126ebc9706 Merge "app_stream_echo: Don't echo declined streams" into 15 2017-09-25 07:48:33 -05:00
George Joseph
1fad858934 build: A few gcc 7 error fixes
Change-Id: I7b5300fbf1af7d88d47129db13ad6dbdc9b553ec
2017-09-25 07:31:38 -05:00
Joshua Colp
3c37ef567d Merge "res_pjsip: Use ast_sip_is_content_type() where appropriate" into 15 2017-09-25 07:28:48 -05:00
StefanEng86
d0d4b139fc 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
2017-09-25 07:02:28 -05:00
Sean Bright
f353df0326 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
2017-09-23 13:32:26 -04:00
Joshua Colp
d80b7e1604 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
2017-09-22 22:53:35 +00:00
Kevin Harwell
08440df3e3 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
2017-09-22 15:49:27 -05:00
Joshua Colp
fc2d3e7e81 Merge "res_pjsip_session/BUNDLE: Handle no audio codecs on endpoint" into 15 2017-09-22 15:36:07 -05:00
Joshua Colp
c96a5ffa6e Merge "res_pjsip_session: Change some asserts to warning/debug messages" into 15 2017-09-22 11:09:40 -05:00
Sean Bright
9eefce503d res_pjsip: Use ast_sip_is_content_type() where appropriate
Change-Id: If3ab0d73d79ac4623308bd48508af2bfd554937d
2017-09-22 10:05:15 -05:00
George Joseph
962865d4ee 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
2017-09-22 06:02:09 -06:00
Joshua Colp
919f744fa8 Merge "res_config_pgsql: Fix removed support to previous for versions PostgreSQL 9.1" into 15 2017-09-22 05:49:30 -05:00
George Joseph
4df07df040 Merge "res_rtp_asterisk.c: Fix bundled SSRC handling." into 15 2017-09-22 05:39:15 -05:00
Joshua Colp
1fd68fb253 Merge "bridge: Change participant SFU streams when source streams change." into 15 2017-09-21 14:59:52 -05:00
Joshua Colp
95cb45cfc8 Merge "AST-2017-008: Improve RTP and RTCP packet processing." into 15 2017-09-21 14:47:59 -05:00
Joshua Colp
00c625a858 Merge "res_pjsip_session: Check for removed stream state." into 15 2017-09-21 12:30:06 -05:00
Joshua Colp
693c06f8a3 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
2017-09-21 17:18:25 +00:00
Jenkins2
037f85d5ab Merge "res_srtp: lower log level of auth failures" into 15 2017-09-21 11:58:41 -05:00
Joshua Colp
c8f8f46195 Merge "chan_sip: Expose read-only access to the full SIP INVITE Request-URI" into 15 2017-09-21 11:40:17 -05:00
Rodrigo Ramírez Norambuena
365003a444 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
2017-09-21 11:26:57 -05:00