asterisk/asterisk.git
4 years agoMerge "res_rtp_asterisk: Add more ICE debugging"
Matt Jordan [Tue, 8 Sep 2015 21:33:29 +0000 (16:33 -0500)]
Merge "res_rtp_asterisk: Add more ICE debugging"

4 years agoMerge "Core/General: Add #ifdef needed on FreeBSD."
Joshua Colp [Tue, 8 Sep 2015 21:11:00 +0000 (16:11 -0500)]
Merge "Core/General: Add #ifdef needed on FreeBSD."

4 years agores_rtp_asterisk: Add more ICE debugging
David M. Lee [Fri, 4 Sep 2015 21:33:39 +0000 (16:33 -0500)]
res_rtp_asterisk: Add more ICE debugging

In working through a recent ICE negotiation bug, I found the debug
logging in res_rtp_asterisk to be lacking. This patch adds a number of
debug and warning statements that were helpful.

Change-Id: I950c6d8f13a41f14b3d6334b4cafe7d4e997be80

4 years agoMerge "res/res_pjsip: Purge contacts when an AoR is deleted"
Joshua Colp [Tue, 8 Sep 2015 19:03:42 +0000 (14:03 -0500)]
Merge "res/res_pjsip: Purge contacts when an AoR is deleted"

4 years agochan_ooh323: call ast_rtp_instance_stop on ooh323_destroy
Alexander Anikin [Mon, 7 Sep 2015 18:19:41 +0000 (22:19 +0400)]
chan_ooh323: call ast_rtp_instance_stop on ooh323_destroy

    Call ast_rtp_instance_stop on ooh323_destroy to free resources
    allocated by rtp instance

    ASTERISK-25299 #close
    Report by: Alexandr Dranchuk

Change-Id: I455096bd7da016b871afe90af86067c2c7c9f33f

4 years agores/res_pjsip: Purge contacts when an AoR is deleted
Matt Jordan [Mon, 7 Sep 2015 16:15:59 +0000 (11:15 -0500)]
res/res_pjsip: Purge contacts when an AoR is deleted

When an AoR is deleted by an external mechanism, such as through ARI, we
currently do not remove dynamic contacts that were created for that AoR as a
result of a received REGISTER request. As a result, re-creating the AoR will
cause the dynamic contact to be interpreted as a persistent contact, leading
to some rather strange state being created for the contacts/endpoints.

This patch adds a sorcery observer for the 'aor' object. When a delete is
issued on the underlying sorcery object, the observer is called, and all
contacts created and persisted in sorcery for that AoR are also removed. Note
that we don't want to perform this action when an AO2 object that is an AoR is
destroyed, as the AoR can still exist in the backing storage (and we would
thus be removing valid contacts from an AoR that still "exists".)

ASTERISK-25381 #close

Change-Id: I6697e51ef6b2858b5d63401f35dc378bb0f90328

4 years agoMerge "endpoint snapshot: avoid second cleanup on alloc failure"
Matt Jordan [Sat, 5 Sep 2015 23:48:26 +0000 (18:48 -0500)]
Merge "endpoint snapshot: avoid second cleanup on alloc failure"

4 years agoMerge "channels/pjsip/dialplan_functions: Add an option for extracting the SIP call-id"
Matt Jordan [Sat, 5 Sep 2015 23:43:50 +0000 (18:43 -0500)]
Merge "channels/pjsip/dialplan_functions: Add an option for extracting the SIP call-id"

4 years agoMerge "res_pjsip: Change default from user value."
Joshua Colp [Sat, 5 Sep 2015 20:56:58 +0000 (15:56 -0500)]
Merge "res_pjsip: Change default from user value."

4 years agoMerge "Fix when remote candidates exceed PJ_ICE_MAX_CAND"
Joshua Colp [Sat, 5 Sep 2015 20:42:37 +0000 (15:42 -0500)]
Merge "Fix when remote candidates exceed PJ_ICE_MAX_CAND"

4 years agochannels/pjsip/dialplan_functions: Add an option for extracting the SIP call-id
Matt Jordan [Sat, 5 Sep 2015 19:58:41 +0000 (14:58 -0500)]
channels/pjsip/dialplan_functions: Add an option for extracting the SIP call-id

This patch adds a new option to the CHANNEL function that allows for the
extraction of the SIP call-id. It is used in conjunction with the 'pjsip'
option, and will return the Call-ID of the INVITE request that established
the PJSIP channel.

ASTERISK-25352

Change-Id: I278d1f8bcfe3a53c5aa1dadebc14e92b0abd476a

4 years agoFix when remote candidates exceed PJ_ICE_MAX_CAND
David M. Lee [Fri, 4 Sep 2015 21:06:39 +0000 (16:06 -0500)]
Fix when remote candidates exceed PJ_ICE_MAX_CAND

We were passing the wrong count into pj_ice_sess_create_check_list(),
causing the create to fail if we ever received more than PJ_ICE_MAX_CAND
candidates.

Change-Id: I0303d8e1ecb20a8de9fe629a3209d216c4028378

4 years agores_pjsip: Change default from user value.
Mark Michelson [Fri, 4 Sep 2015 19:40:38 +0000 (14:40 -0500)]
res_pjsip: Change default from user value.

When Asterisk sends an outbound SIP request, if there is no direct
reason to place a specific value for the username in the From header,
Asterisk would generate a UUID. For example, this would happen when
sending outbound OPTIONS requests when qualifying or when sending
outbound INVITE requests when originating (if no explicit caller ID were
provided). The issue is that some SIP providers reject these sorts of
requests with a "Name too long" error response.

This patch aims to fix this by changing the default outbound username in
From headers to "asterisk". This value can be overridden by changing the
default_from_user option in the global options if desired.

ASTERISK-25377 #close
Reported by Mark Michelson

Change-Id: I6a4d34a56ff73ff4f661b0075aeba5461b7f3190

4 years agoendpoint snapshot: avoid second cleanup on alloc failure
Scott Griepentrog [Fri, 4 Sep 2015 14:26:46 +0000 (09:26 -0500)]
endpoint snapshot: avoid second cleanup on alloc failure

In ast_endpoint_snapshot_create(), a failure to init the
string fields results in two attempts to ao2_cleanup the
same pointer.  Removed RAII_VAR to eliminate problem.

ASTERISK-25375 #close
Reported by: Scott Griepentrog

Change-Id: If4d9dfb1bbe3836b623642ec690b6d49b25e8979

4 years agores/pjsip: Mark WSS transport as secure
Martin Tomec [Fri, 4 Sep 2015 10:33:47 +0000 (12:33 +0200)]
res/pjsip: Mark WSS transport as secure

Pjsip is refusing to use unsecure transport with "sips" in url.
WSS should be considered as secure transport.

ASTERISK-24602 #comment Partially fixed by setting WSS as secure

Change-Id: Iddac406c6deba6240c41a603b8859dfefe1a5353

4 years agoCore/General: Add #ifdef needed on FreeBSD.
Guido Falsi [Tue, 1 Sep 2015 15:16:55 +0000 (17:16 +0200)]
Core/General: Add #ifdef needed on FreeBSD.

pthread_attr_init() defaults to PTHREAD_EXPLICIT_SCHED on FreeBSD
too.

ASTERISK-25310 #close
Reported by: Guido Falsi

Change-Id: Iae6befac9028b5b9795f86986a4a08a1ae6ab7c4

4 years agores_pjsip: Fix contact refleak on stateful responses.
Mark Michelson [Wed, 2 Sep 2015 22:26:14 +0000 (17:26 -0500)]
res_pjsip: Fix contact refleak on stateful responses.

When sending a stateful response, creation of the transaction can fail,
most commonly because we are trying to create a transaction from a
retransmitted request. When creation of the transaction fails, we end up
leaking a reference to a contact that was bumped when the response was
created.

This patch adds the missing deref and fixes the reference leak.

Change-Id: I2f97ad512aeb1b17e87ca29ae0abacb4d6395f07

4 years agopbx: Fix crash when issuing "core show hints" with long pattern match.
Joshua Colp [Wed, 2 Sep 2015 17:41:10 +0000 (14:41 -0300)]
pbx: Fix crash when issuing "core show hints" with long pattern match.

When issuing the "core show hints" CLI command a combination of both
the hint extension and context is created. This uses a fixed size
buffer expecting that the extension will not exceed maximum extension
length. When the extension is actually a pattern match this constraint
does not hold true, and the extension may exceed the maximum extension
length. In this case extra characters are written past the end of the
fixed size buffer.

This change makes it so the construction of the combined hint extension
and context can not exceed the size of the buffer.

ASTERISK-25367 #close

Change-Id: Idfa1b95d0d4dc38e675be7c1de8900b3f981f499

4 years agores_pjsip_pubsub: re-re-fix persistent subscription storage.
Mark Michelson [Tue, 1 Sep 2015 14:05:34 +0000 (09:05 -0500)]
res_pjsip_pubsub: re-re-fix persistent subscription storage.

A recent change to res_pjsip_pubsub switched to using pjsip_msg_print as
a means of writing an appropriate packet to persistent storage. While
this partially solved the issue, it had its own problems.
pjsip_msg_print will always add a Content-Length header to the message
it prints. Frequent restarts of Asterisk can result in persistent
subscriptions being written with five or more Content-Length headers. In
addition, sometimes some apparent corruption of individual headers could
be seen.

This aims to fix the problem by not running a parsed message through an
interpreter but rather by taking the raw message and saving it. The
logic for what to save is going to be different depending on whether a
SUBSCRIBE was received from the wire or if it was pulled from
persistence. When receiving a packet from the wire, when using a
streaming transport, the rdata->pkt_info.packet may contain multiple SIP
messages or fragments. However, the rdata->msg_info.msg_buf will always
contain the current SIP message to be processed. When pulling from
persistence, though, the rdata->msg_info.msg_buf will be NULL since no
transport actually handled the packet. However, since we know that we
will always ever pull one SIP message from persistence, we are free to
save directly from rdata->pkt_info.packet instead.

ASTERISK-25365 #close
Reported by Mark Michelson

Change-Id: I33153b10d0b4dc8e3801aaaee2f48173b867855b

4 years agoMerge "taskprocessor: Fix race condition between unreferencing and finding."
Matt Jordan [Sat, 29 Aug 2015 17:31:58 +0000 (12:31 -0500)]
Merge "taskprocessor: Fix race condition between unreferencing and finding."

4 years agoMerge "res_pjsip_sdp_rtp: Fix multiple keepalive scheduled items."
Matt Jordan [Sat, 29 Aug 2015 17:30:59 +0000 (12:30 -0500)]
Merge "res_pjsip_sdp_rtp: Fix multiple keepalive scheduled items."

4 years agotaskprocessor: Fix race condition between unreferencing and finding.
Joshua Colp [Sat, 29 Aug 2015 15:36:35 +0000 (12:36 -0300)]
taskprocessor: Fix race condition between unreferencing and finding.

When unreferencing a taskprocessor its reference count is checked
to determine if it should be unlinked from the taskprocessors
container and its listener shut down. In between the time when the
reference count is checked and unlinking it is possible for
another thread to jump in, find it, and get a reference to it. If
the thread then uses the taskprocessor it may find that it is not
in the state it expects.

This change locks the taskprocessors container during almost the
entire unreference operation to ensure that any other thread which
may attempt to find the taskprocessor has to wait.

ASTERISK-25295

Change-Id: Icb842db82fe1cf238da55df92e95938a4419377c

4 years agores_pjsip_sdp_rtp: Fix multiple keepalive scheduled items.
Joshua Colp [Sat, 29 Aug 2015 01:22:45 +0000 (22:22 -0300)]
res_pjsip_sdp_rtp: Fix multiple keepalive scheduled items.

The keepalive support in res_pjsip_sdp_rtp currently assumes
that a stream will only be negotiated once. This is false.
If the stream is replaced and later added back it can be
negotiated again causing multiple keepalive scheduled items
to exist. This change explicitly deletes the existing
keepalive scheduled item before adding the new one.

The res_pjsip_sdp_rtp module also does not stop RTP
keepalives or timeout timer if the stream has been
replaced. This change adds a callback to the session media
interface to allow a media stream to be stopped without
the resources being destroyed. This allows the scheduled
items and RTP to be stopped when the stream no longer
exists.

ASTERISK-25356 #close

Change-Id: Ibe6a7cc0927c87326fd5f1c0d4ad889dbfbea1de

4 years agosched: ast_sched_del may return prematurely due to spurious wakeup
Joshua Colp [Sat, 29 Aug 2015 00:57:14 +0000 (21:57 -0300)]
sched: ast_sched_del may return prematurely due to spurious wakeup

When deleting a scheduled item if the item in question is currently
executing the ast_sched_del function waits until it has completed.
This is accomplished using ast_cond_wait. Unfortunately the
ast_cond_wait function can suffer from spurious wakeups so the
predicate needs to be checked after it returns to make sure it has
really woken up as a result of being signaled.

This change adds a loop around the ast_cond_wait to make sure that
it only exits when the executing task has really completed.

ASTERISK-25355 #close

Change-Id: I51198270eb0b637c956c61aa409f46283432be61

4 years agores_pjsip_session: Don't invoke session supplements twice for BYE requests.
Joshua Colp [Thu, 27 Aug 2015 17:26:09 +0000 (14:26 -0300)]
res_pjsip_session: Don't invoke session supplements twice for BYE requests.

When a BYE request is received the PJSIP invite session implementation
creates and sends a 200 OK response before we are aware of it. This
causes the INVITE session state callback to be called into and ultimately
the session supplements run on the BYE request. Once this response has
been sent the normal transaction state callback is invoked which
invokes the session supplements on the BYE request again. This can
be problematic in particular with res_pjsip_rfc3326 as it may
attempt to update the hangup cause code on the channel while it is
in the process of being hung up.

This change makes it so the session supplements are only invoked
once by the INVITE session state callback.

ASTERISK-25318 #close

Change-Id: I69c17df55ccbb61ef779ac38cc8c6b411376c19a

4 years agoMerge "res_pjsip: Add common ast_sip_get_host_ip API."
Joshua Colp [Thu, 27 Aug 2015 20:41:54 +0000 (15:41 -0500)]
Merge "res_pjsip: Add common ast_sip_get_host_ip API."

4 years agoMerge "Chaos: make hangup NULL tolerant"
Mark Michelson [Thu, 27 Aug 2015 19:53:45 +0000 (14:53 -0500)]
Merge "Chaos: make hangup NULL tolerant"

4 years agoChaos: handle failed allocation in get_media_encryption_type
Scott Griepentrog [Wed, 26 Aug 2015 20:26:00 +0000 (15:26 -0500)]
Chaos: handle failed allocation in get_media_encryption_type

If the ast_strndup() call fails to allocate a copy of the
transport string for parsing, fail gracefully.

ASTERISK-25323
Reported by: Scott Griepentrog

Change-Id: Ia4b905ce6d03da53fea526224455c1044b1a5a28

4 years agoChaos: make hangup NULL tolerant
Scott Griepentrog [Wed, 26 Aug 2015 19:25:42 +0000 (14:25 -0500)]
Chaos: make hangup NULL tolerant

In chan_pjsip_new, if allocation of the pvt
structure fails, ast_hangup is called.  But
it was written to assume pvt was valid, and
this change corrects that.

ASTERISK-25323
Reported by: Scott Griepentrog

Change-Id: I5f47860fe9cee4cd56abd3f79b108678ab72cc87

4 years agochan_sip: Allow call pickup to set the hangup cause.
Joshua Colp [Wed, 26 Aug 2015 10:40:32 +0000 (07:40 -0300)]
chan_sip: Allow call pickup to set the hangup cause.

The call pickup implementation in chan_sip currently sets the channel
hangup cause to "normal clearing" if call pickup is successfully
performed. This action overwrites the "answered elsewhere" hangup cause
set by the call pickup code and can result in the SIP device in
question showing a missed call when it should not.

This change sets the hangup cause to "normal clearing" as a
default initially but allows the call pickup to change it as
needed.

ASTERISK-25346 #close

Change-Id: I00ac2c269cee9e29586ee2c65e83c70e52a02cff

4 years agores_pjsip: Add common ast_sip_get_host_ip API.
Joshua Colp [Tue, 25 Aug 2015 12:17:34 +0000 (09:17 -0300)]
res_pjsip: Add common ast_sip_get_host_ip API.

Modules commonly used the pj_gethostip function for retrieving the
IP address of the host. This function does not cache the result and may
result in a DNS lookup occurring, or additional work. If the DNS
server is unreachable or network issues arise this can cause the
pj_gethostip function to block for a period of time.

This change adds an ast_sip_get_host_ip and ast_sip_get_host_ip_string
function which does the same thing but caches the host IP address at
module load time. This results in no additional work being done each
time the local host IP address is needed.

ASTERISK-25342 #close

Change-Id: I3205deb679b01fa5ac05a94b623bfd620a2abe1e

4 years agoMerge "res_pjsip_pubsub: On recreated notify fail deleted sub_tree is referenced"
Mark Michelson [Mon, 24 Aug 2015 22:16:48 +0000 (17:16 -0500)]
Merge "res_pjsip_pubsub: On recreated notify fail deleted sub_tree is referenced"

4 years agoMerge "bridge: Kick channel from bridge if hung up during action."
Mark Michelson [Mon, 24 Aug 2015 22:12:06 +0000 (17:12 -0500)]
Merge "bridge: Kick channel from bridge if hung up during action."

4 years agoMerge "res_pjsip/pjsip_configuration: Disregard empty auth values"
Joshua Colp [Mon, 24 Aug 2015 18:59:32 +0000 (13:59 -0500)]
Merge "res_pjsip/pjsip_configuration: Disregard empty auth values"

4 years agobridge: Kick channel from bridge if hung up during action.
Joshua Colp [Mon, 24 Aug 2015 11:21:37 +0000 (08:21 -0300)]
bridge: Kick channel from bridge if hung up during action.

When executing an action in a bridge it is possible for the
channel to be hung up without the bridge becoming aware of it.
This is most easily reproducible by hanging up when the bridge
is streaming DTMF due to a feature timeout. This change makes
it so after action execution the channel is checked to determine
if it has been hung up and if it has it is kicked from the bridge.

ASTERISK-25341 #close

Change-Id: I6dd8b0c3f5888da1c57afed9e8a802ae0a053062

4 years agores_pjsip_pubsub: On recreated notify fail deleted sub_tree is referenced
Joshua Colp [Mon, 24 Aug 2015 16:04:57 +0000 (13:04 -0300)]
res_pjsip_pubsub: On recreated notify fail deleted sub_tree is referenced

When recreating a subscription it is possible for a freed sub_tree
to be referenced when the initial NOTIFY fails to be created.

Change-Id: I681c215309aad01b21d611c2de47b3b0a6022788

4 years agores_pjsip/pjsip_configuration: Disregard empty auth values
Matt Jordan [Sun, 23 Aug 2015 23:26:50 +0000 (18:26 -0500)]
res_pjsip/pjsip_configuration: Disregard empty auth values

When an endpoint is backed by a non-static conf file backend (such as
the AstDB or Realtime), the 'auth' object may be returned as being an
empty string. Currently, res_pjsip will interpret that as being a valid
auth object, and will attempt to authenticate inbound requests. This
isn't desired; is an auth value is empty (which the name of an auth
object cannot be), we should instead interpret that as being an invalid
auth object and skip it.

ASTERISK-25339 #close

Change-Id: Ic32b0c6eb5575107d5164a8c40099e687cd722c7

4 years agoREADME*: Remove trailing whitespace
Rodrigo Ramírez Norambuena [Sat, 22 Aug 2015 04:37:23 +0000 (00:37 -0400)]
README*: Remove trailing whitespace

Change-Id: I18b7d75187548a9ed55b4f258d21aaaf29d08874

4 years agochan_sip.c: Set preferred rx payload type mapping on incoming offers.
Richard Mudgett [Tue, 28 Jul 2015 18:47:31 +0000 (13:47 -0500)]
chan_sip.c: Set preferred rx payload type mapping on incoming offers.

ASTERISK-25166
Reported by: Kevin Harwell

ASTERISK-17410
Reported by: Boris Fox

Change-Id: I7f04d5c8bee1126fee5fe6afbc39e45104469f4e

4 years agores_pjsip_sdp_rtp.c: Set preferred rx payload type mapping on incoming offers.
Richard Mudgett [Fri, 24 Jul 2015 23:46:09 +0000 (18:46 -0500)]
res_pjsip_sdp_rtp.c: Set preferred rx payload type mapping on incoming offers.

ASTERISK-25166
Reported by: Kevin Harwell

ASTERISK-17410
Reported by: Boris Fox

Change-Id: I97ecebc1ab9b5654fb918bf1f4c98c956b852369

4 years agortp_engine.c: Get current or create a needed rx payload type mapping.
Richard Mudgett [Tue, 28 Jul 2015 00:19:25 +0000 (19:19 -0500)]
rtp_engine.c: Get current or create a needed rx payload type mapping.

* Make ast_rtp_codecs_payload_code() get the current mapping or create a
rx payload type mapping.

ASTERISK-25166
Reported by: Kevin Harwell

ASTERISK-17410
Reported by: Boris Fox

Change-Id: Ia4b2d45877a8f004f6ce3840e3d8afe533384e56

4 years agortp_engine.c: Extract rtp_codecs_payload_replace_rx().
Richard Mudgett [Tue, 28 Jul 2015 00:15:07 +0000 (19:15 -0500)]
rtp_engine.c: Extract rtp_codecs_payload_replace_rx().

ASTERISK-25166
Reported by: Kevin Harwell

ASTERISK-17410
Reported by: Boris Fox

Change-Id: I34e23bf5b084c8570f9c3e6ccd19b95fe85af239

4 years agortp_engine.c: Initial split of payload types into rx and tx mappings.
Richard Mudgett [Fri, 24 Jul 2015 00:24:04 +0000 (19:24 -0500)]
rtp_engine.c: Initial split of payload types into rx and tx mappings.

There are numerous problems with the current implementation of the RTP
payload type mapping in Asterisk.  It uses only one mapping structure to
associate payload types to codecs.  The single mapping is overkill if all
of the payload type values are well known values.  Dynamic payload type
mappings do not work as well with the single mapping because RFC3264
allows each side of the link to negotiate different dynamic mappings for
what they want to receive.  Not only could you have the same codec mapped
for sending and receiving on different payload types you could wind up
with the same payload type mapped to different codecs for each direction.

1) An independent payload type mapping is needed for sending and
receiving.

2) The receive mapping needs to keep track of previous mappings because of
the slack to when negotiation happens and current packets in flight using
the old mapping arrive.

3) The transmit mapping only needs to keep track of the current negotiated
values since we are sending the packets and know when the switchover takes
place.

* Needed to create ast_rtp_codecs_payload_code_tx() and make some callers
use the new function because ast_rtp_codecs_payload_code() was used for
mappings in both directions.

* Needed to create ast_rtp_codecs_payloads_xover() for cases where we need
to pass preferred codec mappings to the peer channel for early media
bridging or when we need to prefer the offered mapping that RFC3264 says
we SHOULD use.

* ast_rtp_codecs_payloads_xover() and ast_rtp_codecs_payload_code_tx() are
the only new public functions created.  All the others were only used for
the tx or rx mapping direction so the function doxygen now reflects which
direction the function operates.

* chan_mgcp.c: Removed call to ast_rtp_codecs_payloads_clear() as doing
that makes no sense when processing an incoming SDP.  We would be wiping
out any mappings that we set for the possible outgoing SDP we sent
earlier.

ASTERISK-25166
Reported by: Kevin Harwell

ASTERISK-17410
Reported by: Boris Fox

Change-Id: Iaf6c227bca68cb7c414cf2fd4108a8ac98bd45ac

4 years agoMerge "res_ari_events: Fix shutdown ref leak."
Mark Michelson [Wed, 19 Aug 2015 22:06:51 +0000 (17:06 -0500)]
Merge "res_ari_events: Fix shutdown ref leak."

4 years agoMerge "app_queue.c: Extract some functions for simpler code."
Mark Michelson [Wed, 19 Aug 2015 22:03:35 +0000 (17:03 -0500)]
Merge "app_queue.c: Extract some functions for simpler code."

4 years agoMerge "res_http_websocket.c: Add missing unref on an off nominal path."
Mark Michelson [Wed, 19 Aug 2015 21:56:35 +0000 (16:56 -0500)]
Merge "res_http_websocket.c: Add missing unref on an off nominal path."

4 years agoMerge "ari/ari_websockets.c: Fix ast_debug parameter type mismatch."
Mark Michelson [Wed, 19 Aug 2015 21:55:48 +0000 (16:55 -0500)]
Merge "ari/ari_websockets.c: Fix ast_debug parameter type mismatch."

4 years agoari/ari_websockets.c: Fix ast_debug parameter type mismatch.
Richard Mudgett [Wed, 19 Aug 2015 17:10:12 +0000 (12:10 -0500)]
ari/ari_websockets.c: Fix ast_debug parameter type mismatch.

This is a type mismatch fix of the debugging commit
c63316eec10e1990a88bf4712238d6deb375bfa9 made to find out why
a testsuite test was failing only on one of the continuous
integration build agents.

Change-Id: Iba34f6e87cec331f6ac80e4daff6476ea6f00a75

4 years agocontrib: script install_prereq should install sqlite3
Scott Griepentrog [Wed, 19 Aug 2015 15:30:12 +0000 (10:30 -0500)]
contrib: script install_prereq should install sqlite3

Asterisk needs the sqlite 3 library, which is package
sqlite-devel in CentOS. By adding this package to the
script, a problem with configure failing is resolved.

ASTERISK-25331 #close
Reported by: Kevin Harwell

Change-Id: I90efaf6a01914fea03f21e5cdbd91c348f44b0ec

4 years agoMerge "res_http_websocket.c: Fix some off nominal path cleanup."
Matt Jordan [Wed, 19 Aug 2015 13:42:56 +0000 (08:42 -0500)]
Merge "res_http_websocket.c: Fix some off nominal path cleanup."

4 years agoMerge "app_queue.c: Fix setting QUEUE_MEMBER 'paused' and 'ringinuse'."
Matt Jordan [Wed, 19 Aug 2015 13:40:39 +0000 (08:40 -0500)]
Merge "app_queue.c: Fix setting QUEUE_MEMBER 'paused' and 'ringinuse'."

4 years agores_ari_events: Fix shutdown ref leak.
Richard Mudgett [Tue, 18 Aug 2015 20:07:49 +0000 (15:07 -0500)]
res_ari_events: Fix shutdown ref leak.

ASTERISK-25308 #close
Reported by: Joshua Colp

Change-Id: I592785bf70ff4b63d00e535b482f40da8e82a082

4 years agores_http_websocket.c: Add missing unref on an off nominal path.
Richard Mudgett [Tue, 18 Aug 2015 19:24:17 +0000 (14:24 -0500)]
res_http_websocket.c: Add missing unref on an off nominal path.

Change-Id: I228df6adecd4cb450d03e09e9a38c86bb566e811

4 years agores_http_websocket.c: Fix some off nominal path cleanup.
Richard Mudgett [Tue, 18 Aug 2015 21:06:54 +0000 (16:06 -0500)]
res_http_websocket.c: Fix some off nominal path cleanup.

* Remove extraneous unlock on off-nominal path.
* Add missing HTTP error reply.

Change-Id: I1f402bfe448fba8696b507477cab5f060ccd9b2b

4 years agores_ari.c: Add missing off nominal unlock and remove a RAII_VAR().
Richard Mudgett [Tue, 18 Aug 2015 19:46:46 +0000 (14:46 -0500)]
res_ari.c: Add missing off nominal unlock and remove a RAII_VAR().

Change-Id: I0c5e7b34057f26dadb39489c4dac3015c52f5dbf

4 years agoapp_queue.c: Fix setting QUEUE_MEMBER 'paused' and 'ringinuse'.
Richard Mudgett [Fri, 14 Aug 2015 17:55:28 +0000 (12:55 -0500)]
app_queue.c: Fix setting QUEUE_MEMBER 'paused' and 'ringinuse'.

Setting the 'paused' and 'ringinuse' options on a queue member using the
dialplan function QUEUE_MEMBER did not behave the same way as the
equivalent dialplan applications or AMI actions.

* Made queue_function_mem_write() call the set_member_paused() and
set_member_value() for the 'paused' and 'ringinuse' options respectively.
A beneficial side effect is that the queue name is now optional and sets
the value in all queues the interface is a member.

* Update QUEUE_MEMBER XML documentation.

* Fix error checking in QUEUE_MEMBER() write.

ASTERISK-25215 #close
Reported by: Lorne Gaetz

Change-Id: I3a016be8dc94d63a9cc155295ff9c9afa5f707cb

4 years agoapp_queue.c: Extract some functions for simpler code.
Richard Mudgett [Mon, 17 Aug 2015 21:41:19 +0000 (16:41 -0500)]
app_queue.c: Extract some functions for simpler code.

* Extract set_queue_member_pause() from set_member_paused() for simpler
and more consistent code.

* Extract set_queue_member_ringinuse() from
set_member_ringinuse_help_members() for simpler code.

Change-Id: Iecc1f4119c63347341d7ea6b65f5fc4963706306

4 years agoapp_queue.c: Fix error checking in QUEUE_MEMBER() read.
Richard Mudgett [Mon, 17 Aug 2015 18:34:15 +0000 (13:34 -0500)]
app_queue.c: Fix error checking in QUEUE_MEMBER() read.

Change-Id: I7294e13d27875851c2f4ef6818adba507509d224

4 years agoCHAOS: prevent sorcery object with null id
Scott Griepentrog [Mon, 17 Aug 2015 16:00:53 +0000 (11:00 -0500)]
CHAOS: prevent sorcery object with null id

When allocating a sorcery object, fail if the
id value was not allocated.

ASTERISK-25323
Reported by: Scott Griepentrog

Change-Id: I152133fb7545a4efcf7a0080ada77332d038669e

4 years agores_pjsip_sdp_rtp: Restore removed NULL check.
Mark Michelson [Fri, 14 Aug 2015 20:46:05 +0000 (15:46 -0500)]
res_pjsip_sdp_rtp: Restore removed NULL check.

When sending an RTP keepalive, we need to be sure we're not dealing with
a NULL RTP instance. There had been a NULL check, but the commit that
added the rtp_timeout and rtp_hold_timeout options removed the NULL
check.

Change-Id: I2d7dcd5022697cfc6bf3d9e19245419078e79b64

4 years agoaudiohook.c: Simplify variable usage in audiohook_read_frame_both().
Richard Mudgett [Thu, 13 Aug 2015 17:30:00 +0000 (12:30 -0500)]
audiohook.c: Simplify variable usage in audiohook_read_frame_both().

Change-Id: I58bed58631a94295b267991c5b61a3a93c167f0c

4 years agoaudiohook.c: Fix MixMonitor crash when using the r() or t() options.
Richard Mudgett [Thu, 13 Aug 2015 17:22:14 +0000 (12:22 -0500)]
audiohook.c: Fix MixMonitor crash when using the r() or t() options.

The built frame format in audiohook_read_frame_both() is now set to a
signed linear format before the rx and tx frames are duplicated instead of
only for the mixed audio frame duplication.

ASTERISK-25322 #close
Reported by Sean Pimental

Change-Id: I86f85b5c48c49e4e2d3b770797b9d484250a1538

4 years agoMerge "chan_sip.c: wrong peer searched in sip_report_security_event"
Mark Michelson [Thu, 13 Aug 2015 21:11:47 +0000 (16:11 -0500)]
Merge "chan_sip.c: wrong peer searched in sip_report_security_event"

4 years agochan_sip.c: wrong peer searched in sip_report_security_event
Kevin Harwell [Wed, 12 Aug 2015 17:59:53 +0000 (12:59 -0500)]
chan_sip.c: wrong peer searched in sip_report_security_event

In chan_sip, after handling an incoming invite a security event is raised
describing authorization (success, failure, etc...). However, it was doing
a lookup of the peer by extension. This is fine for register messages, but
in the case of an invite it may search and find the wrong peer, or a non
existent one (for instance, in the case of call pickup). Also, if the peers
are configured through realtime this may cause an unnecessary database lookup
when caching is enabled.

This patch makes it so that sip_report_security_event searches by IP address
when looking for a peer instead of by extension after an invite is processed.

ASTERISK-25320 #close

Change-Id: I9b3f11549efb475b6561c64f0e6da1a481d98bc4

4 years agores_http_websocket: When shutting down a session don't close closed socket
Joshua Colp [Thu, 13 Aug 2015 10:26:51 +0000 (07:26 -0300)]
res_http_websocket: When shutting down a session don't close closed socket

Due to the use of ast_websocket_close in session termination it is
possible for the underlying socket to already be closed when the
session is terminated. This occurs when the close frame is attempted
to be written out but fails.

Change-Id: I7572583529a42a7dc911ea77a974d8307d5c0c8b

4 years agoMerge "res_http_websocket: Forcefully terminate on write errors."
Joshua Colp [Wed, 12 Aug 2015 18:43:16 +0000 (13:43 -0500)]
Merge "res_http_websocket: Forcefully terminate on write errors."

4 years agoMerge "chan_dahdi.c: Lock private struct for ast_write()."
Mark Michelson [Wed, 12 Aug 2015 18:37:32 +0000 (13:37 -0500)]
Merge "chan_dahdi.c: Lock private struct for ast_write()."

4 years agoMerge "chan_dahdi.c: Flush the DAHDI write buffer after starting DTMF."
Mark Michelson [Wed, 12 Aug 2015 18:37:14 +0000 (13:37 -0500)]
Merge "chan_dahdi.c: Flush the DAHDI write buffer after starting DTMF."

4 years agoMerge "chan_sip: Fix negotiation of iLBC 30."
Joshua Colp [Wed, 12 Aug 2015 18:36:08 +0000 (13:36 -0500)]
Merge "chan_sip: Fix negotiation of iLBC 30."

4 years agoMerge "res_pjsip.c: Fix crash from corrupt saved SUBSCRIBE message."
Mark Michelson [Wed, 12 Aug 2015 18:08:02 +0000 (13:08 -0500)]
Merge "res_pjsip.c: Fix crash from corrupt saved SUBSCRIBE message."

4 years agores_http_websocket: Forcefully terminate on write errors.
Joshua Colp [Tue, 11 Aug 2015 10:24:30 +0000 (07:24 -0300)]
res_http_websocket: Forcefully terminate on write errors.

The res_http_websocket module will currently attempt to close
the WebSocket connection if fatal cases occur, such as when
attempting to write out data and being unable to. When the
fatal cases occur the code attempts to write a WebSocket close
frame out to have the remote side close the connection. If
writing this fails then the connection is not terminated.

This change forcefully terminates the connection if the
WebSocket is to be closed but is unable to send the close frame.

ASTERISK-25312 #close

Change-Id: I10973086671cc192a76424060d9ec8e688602845

4 years agores/res_format_attr_silk: Expose format attributes to other modules
Matt Jordan [Sun, 9 Aug 2015 23:42:00 +0000 (18:42 -0500)]
res/res_format_attr_silk: Expose format attributes to other modules

This patch adds the .get callback to the format attribute module, such
that the Asterisk core or other third party modules can query for the
negotiated format attributes.

Change-Id: Ia24f55cf9b661d651ce89b4f4b023d921380f19c

4 years agochan_dahdi.c: Flush the DAHDI write buffer after starting DTMF.
Richard Mudgett [Mon, 10 Aug 2015 18:43:19 +0000 (13:43 -0500)]
chan_dahdi.c: Flush the DAHDI write buffer after starting DTMF.

Pressing DTMF digits on a phone to go out on a DAHDI channel can result in
the digit not being recognized or even heard by the peer.

Phone -> Asterisk -> DAHDI/channel

Turns out the DAHDI behavior with DTMF generation (and any other generated
tones) is exposed by the "buffers=" setting in chan_dahdi.conf.  When
Asterisk requests to start sending DTMF then DAHDI waits until its write
buffer is empty before generating any samples for the DTMF tones.  When
Asterisk subsequently requests DAHDI to stop sending DTMF then DAHDI
immediately stops generating the DTMF samples.  As a result, the more
samples there are in the DAHDI write buffer the shorter the time DTMF
actually gets sent on the wire.  If there are more samples in the write
buffer than the time DTMF is supposed to be sent then no DTMF gets sent on
the wire.  With the "buffers=12,half" setting and each buffer representing
20 ms of samples then the DAHDI write buffer is going to contain around
120 ms of samples.  For DTMF to be recognized by the peer the actual sent
DTMF duration needs to be a minimum of 40 ms.  Therefore, the intended
duration needs to be a minimum of 160 ms for the peer to receive the
minimum DTMF digit duration to recognize it.

A simple and effective solution to work around the DAHDI behavior is for
Asterisk to flush the DAHDI write buffer when sending DTMF so the full
duration of DTMF is actually sent on the wire.  When someone is going to
send DTMF they are not likely to be talking before sending the tones so
the flushed write samples are expected to just contain silence.

* Made dahdi_digit_begin() flush the DAHDI write buffer after requesting
to send a DTMF digit.

ASTERISK-25315 #close
Reported by John Hardin

Change-Id: Ib56262c708cb7858082156bfc70ebd0a220efa6a

4 years agochan_dahdi.c: Lock private struct for ast_write().
Richard Mudgett [Wed, 5 Aug 2015 19:21:50 +0000 (14:21 -0500)]
chan_dahdi.c: Lock private struct for ast_write().

There is a window of opportunity for DTMF to not go out if an audio frame
is in the process of being written to DAHDI while another thread starts
sending DTMF.  The thread sending the audio frame could be past the
currently dialing check before being preempted by another thread starting
a DTMF generation request.  When the thread sending the audio frame
resumes it will then cause DAHDI to stop the DTMF tone generation.  The
result is no DTMF goes out.

* Made dahdi_write() lock the private struct before writing to the DAHDI
file descriptor.

ASTERISK-25315
Reported by John Hardin

Change-Id: Ib4e0264cf63305ed5da701188447668e72ec9abb

4 years agores_pjsip.c: Fix crash from corrupt saved SUBSCRIBE message.
Richard Mudgett [Mon, 10 Aug 2015 23:23:02 +0000 (18:23 -0500)]
res_pjsip.c: Fix crash from corrupt saved SUBSCRIBE message.

If the saved SUBSCRIBE message is not parseable for whatever reason then
Asterisk could crash when libpjsip tries to parse the message and adds an
error message to the parse error list.

* Made ast_sip_create_rdata() initialize the parse error rdata list.  The
list is checked after parsing to see that it remains empty for the
function to return successful.

ASTERISK-25306
Reported by Mark Michelson

Change-Id: Ie0677f69f707503b1a37df18723bd59418085256

4 years agochan_sip: Fix negotiation of iLBC 30.
Alexander Traud [Mon, 10 Aug 2015 12:40:02 +0000 (14:40 +0200)]
chan_sip: Fix negotiation of iLBC 30.

iLBC 20 was advertised in a SIP/SDP negotiation. However, only iLBC 30 is
supported. Removes "a=fmtp:x mode=y" from SDP. Because of RFC 3952 section 5,
only iLBC 30 is negotiated now.

ASTERISK-25309 #close

Change-Id: I92d724600a183eec3114da0ac607b994b1a793da

4 years agomain/format: Add an API call for retrieving format attributes
Matt Jordan [Sun, 9 Aug 2015 22:56:48 +0000 (17:56 -0500)]
main/format: Add an API call for retrieving format attributes

Some codecs that may be a third party library to Asterisk need to have
knowledge of the format attributes that were negotiated. Unfortunately,
when the great format migration of Asterisk 13 occurred, that ability
was lost.

This patch adds an API call, ast_format_attribute_get, to the core
format API, along with updates to the unit test to check the new API
call. A new callback is also now available for format attribute modules,
such that they can provide the format attribute values they manage.

Note that the API returns a void *. This is done as the format attribute
modules themselves may store format attributes in any particular manner
they like. Care should be taken by consumers of the API to check the
return value before casting and dereferencing. Consumers will obviously
need to have a priori knowledge of the type of the format attribute as
well.

Change-Id: Ieec76883dfb46ecd7aff3dc81a52c81f4dc1b9e3

4 years agoMerge "Replace htobe64 with htonll"
Joshua Colp [Mon, 10 Aug 2015 16:39:10 +0000 (11:39 -0500)]
Merge "Replace htobe64 with htonll"

4 years agoMerge "Replaces clock_gettime() with ast_tsnow()"
Joshua Colp [Mon, 10 Aug 2015 16:27:12 +0000 (11:27 -0500)]
Merge "Replaces clock_gettime() with ast_tsnow()"

4 years agoMerge "rtp_engine.c: Fix performance issue with several channel drivers that use...
Matt Jordan [Sat, 8 Aug 2015 13:07:12 +0000 (08:07 -0500)]
Merge "rtp_engine.c: Fix performance issue with several channel drivers that use RTP."

4 years agoReplace htobe64 with htonll
David M. Lee [Sat, 8 Aug 2015 03:11:03 +0000 (22:11 -0500)]
Replace htobe64 with htonll

We don't have a compatability function to fill in a missing htobe64; but
we already have one for the identical htonll.

Change-Id: Ic0a95db1c5b0041e14e6b127432fb533b97e4cac

4 years agoReplaces clock_gettime() with ast_tsnow()
David M. Lee [Fri, 24 Jul 2015 22:04:35 +0000 (17:04 -0500)]
Replaces clock_gettime() with ast_tsnow()

clock_gettime() is, unfortunately, not portable. But I did like that
over our usual `ts.tv_nsec = tv.tv_usec * 1000` copy/paste code we
usually do when we want a timespec and all we have is ast_tvnow().

This patch adds ast_tsnow(), which mimics ast_tvnow(), but returns a
timespec. If clock_gettime() is available, it will use that. Otherwise
ast_tsnow() falls back to using ast_tvnow().

Change-Id: Ibb1ee67ccf4826b9b76d5a5eb62e90b29b6c456e

4 years agoARI: Retrieve existing log channels
Scott Emidy [Fri, 7 Aug 2015 19:20:29 +0000 (14:20 -0500)]
ARI: Retrieve existing log channels

An http request can be sent to get the existing Asterisk logs.

The command "curl -v -u user:pass -X GET 'http://localhost:8088
/ari/asterisk/logging'" can be run in the terminal to access the
newly implemented functionality.

* Retrieve all existing log channels

ASTERISK-25252

Change-Id: I7bb08b93e3b938c991f3f56cc5d188654768a808

4 years agoARI: Creating log channels
Scott Emidy [Fri, 7 Aug 2015 16:14:06 +0000 (11:14 -0500)]
ARI: Creating log channels

An http request can be sent to create a log channel
in Asterisk.

The command "curl -v -u user:pass -X POST
'http://localhost:088/ari/asterisk/logging/mylog?
configuration=notice,warning'" can be run in the terminal
to access the newly implemented functionality for ARI.

* Ability to create log channels using ARI

ASTERISK-25252

Change-Id: I9a20e5c75716dfbb6b62fd3474faf55be20bd782

4 years agoMerge "ARI: Deleting log channels"
Joshua Colp [Fri, 7 Aug 2015 15:41:11 +0000 (10:41 -0500)]
Merge "ARI: Deleting log channels"

4 years agoMerge "res_pjsip: Ensure sanitized XML is NULL terminated."
Joshua Colp [Fri, 7 Aug 2015 15:23:49 +0000 (10:23 -0500)]
Merge "res_pjsip: Ensure sanitized XML is NULL terminated."

4 years agoMerge "res_pjsip_pubsub: More accurately persist packet."
Joshua Colp [Fri, 7 Aug 2015 10:17:13 +0000 (05:17 -0500)]
Merge "res_pjsip_pubsub: More accurately persist packet."

4 years agoMerge "res_rtp_asterisk.c: Fix off-nominal crash potential."
Joshua Colp [Fri, 7 Aug 2015 10:18:05 +0000 (05:18 -0500)]
Merge "res_rtp_asterisk.c: Fix off-nominal crash potential."

4 years agoARI: Deleting log channels
Scott Emidy [Thu, 6 Aug 2015 20:18:04 +0000 (15:18 -0500)]
ARI: Deleting log channels

An http request can be sent to delete a log channel
in Asterisk.

The command "curl -v -u user:pass -X DELETE 'http://localhost:8088
/ari/asterisk/logging/mylog'" can be run in the terminal
to access the newly implemented functionally for ARI.

* Able to delete log channels using ARI

ASTERISK-25252

Change-Id: Id6eeb54ebcc511595f0418d586ff55914bc3aae6

4 years agores_pjsip_pubsub: More accurately persist packet.
Mark Michelson [Thu, 6 Aug 2015 17:48:07 +0000 (12:48 -0500)]
res_pjsip_pubsub: More accurately persist packet.

The pjsip_rx_data structure has a pkt_info.packet field on it that is
the packet that was read from the transport. For datagram transports,
the packet read from the transport will correspond to the SIP message
that arrived. For streamed transports, however, it is possible to read
multiple SIP messages in one packet.

In a recent case, Asterisk crashed on a system where TCP was being used.
This is because at some point, a read from the TCP socket resulted in a
200 OK response as well as an incoming SUBSCRIBE request being stored in
rdata->pkt_info.packet. When the SUBSCRIBE was processed, the
combination 200 OK and SUBSCRIBE was saved in persistent storage. Later,
a restart of Asterisk resulted in the crash because the persistent
subscription recreation code ended up building the 200 OK response
instead of a SUBSCRIBE request, and we attempted to access
request-specific data.

The fix here is to use the pjsip_msg_print() function in order to
persist SUBSCRIBE requests. This way, rather than using the raw socket
data, we use the parsed SIP message that PJSIP has given us. If we
receive multiple SIP messages from a single read, we will be sure only
to save off the relevant SIP message. There also is a safeguard put in
place to make sure that if we do end up reconstructing a SIP response,
it will not cause a crash.

ASTERISK-25306 #close
Reported by Mark Michelson

Change-Id: I4bf16f7b76a2541d10b55de82bcd14c6e542afb2

4 years agoMerge "rtp_engine.c: Must protect mime_types_len with mime_types_lock."
Joshua Colp [Thu, 6 Aug 2015 17:25:07 +0000 (12:25 -0500)]
Merge "rtp_engine.c: Must protect mime_types_len with mime_types_lock."

4 years agoMerge "res_pjsip_sdp_rtp.c: Fixup some whitespace."
Joshua Colp [Thu, 6 Aug 2015 16:53:20 +0000 (11:53 -0500)]
Merge "res_pjsip_sdp_rtp.c: Fixup some whitespace."

4 years agores_pjsip: Ensure sanitized XML is NULL terminated.
Joshua Colp [Tue, 4 Aug 2015 21:12:59 +0000 (18:12 -0300)]
res_pjsip: Ensure sanitized XML is NULL terminated.

The ast_sip_sanitize_xml function is used to sanitize
a string for placement into XML. This is done by examining
an input string and then appending values to an output
buffer. The function used by its implementation, strncat,
has specific behavior that was not taken into account.
If the size of the input string exceeded the available
output buffer size it was possible for the sanitization
function to write past the output buffer itself causing
a crash. The crash would either occur because it was
writing into memory it shouldn't be or because the resulting
string was not NULL terminated.

This change keeps count of how much remaining space is
available in the output buffer for text and only allows
strncat to use that amount.

Since this was exposed by the res_pjsip_pidf_digium_body_supplement
module attempting to send a large message the maximum allowed
message size has also been increased in it.

A unit test has also been added which confirms that the
ast_sip_sanitize_xml function is providing NULL terminated
output even when the input length exceeds the output
buffer size.

ASTERISK-25304 #close

Change-Id: I743dd9809d3e13d722df1b0509dfe34621398302

4 years agoMerge "res_pjsip_sdp_rtp.c: Fix processing wrong SDP media list."
Joshua Colp [Thu, 6 Aug 2015 09:52:49 +0000 (04:52 -0500)]
Merge "res_pjsip_sdp_rtp.c: Fix processing wrong SDP media list."

4 years agoMerge "res_http_websocket: Debug write lengths."
Joshua Colp [Thu, 6 Aug 2015 09:52:10 +0000 (04:52 -0500)]
Merge "res_http_websocket: Debug write lengths."

4 years agores_rtp_asterisk: Don't leak temporary key when enabling PFS.
Joshua Colp [Wed, 5 Aug 2015 10:23:21 +0000 (07:23 -0300)]
res_rtp_asterisk: Don't leak temporary key when enabling PFS.

A change recently went in which enabled perfect forward secrecy for
DTLS in res_rtp_asterisk. This was accomplished two different ways
depending on the availability of a feature in OpenSSL. The fallback
method created a temporary instance of a key but did not free it.
This change fixes that.

ASTERISK-25265

Change-Id: Iadc031b67a91410bbefb17ffb4218d615d051396

4 years agores_http_websocket: Debug write lengths.
Mark Michelson [Tue, 4 Aug 2015 14:47:34 +0000 (09:47 -0500)]
res_http_websocket: Debug write lengths.

Commit 39cc28f6ea2140ad6d561fd4c9e9a66f065cecee attempted to fix a
test failure observed on 32 bit test agents by ensuring that a cast from
a 32 bit unsigned integer to a 64 bit unsigned integer was happening in
a predictable place. As it turns out, this did not cause test runs to
succeed.

This commit adds several redundant debug messages that print the payload
lengths of websocket frames. The idea here is that this commit will not
cause tests to succeed for the faulty test agent, but we might deduce
where the fault lies more easily this way by observing at what point the
expected value (537) changes to some ungangly huge number.

If you are wondering why something like this is being committed to the
branch, keep in mind that in commit
39cc28f6ea2140ad6d561fd4c9e9a66f065cecee I noted that the observed test
failures only happen when automated tests are run. Attempts to run the
tests by hand manually on the test agent result in the tests passing.

Change-Id: I14a65c19d8af40dadcdbd52348de3b0016e1ae8d

4 years agoMerge "res_http_websocket: Avoid passing strlen() to ast_websocket_write()."
Matt Jordan [Mon, 3 Aug 2015 16:52:01 +0000 (11:52 -0500)]
Merge "res_http_websocket: Avoid passing strlen() to ast_websocket_write()."

4 years agoMerge "res/res_rtp_asterisk: Add ECDH support"
Matt Jordan [Mon, 3 Aug 2015 16:49:43 +0000 (11:49 -0500)]
Merge "res/res_rtp_asterisk: Add ECDH support"

4 years agores_http_websocket: Avoid passing strlen() to ast_websocket_write().
Mark Michelson [Mon, 3 Aug 2015 16:06:07 +0000 (11:06 -0500)]
res_http_websocket: Avoid passing strlen() to ast_websocket_write().

We have seen a rash of test failures on a 32-bit build agent. Commit
48698a5e21d7307f61b5fb2bd39fd593bc1423ca solved an obvious problem where
we were not encoding a 64-bit value correctly over the wire. This
commit, however, did not solve the test failures.

In the failing tests, ARI is attempting to send a 537 byte text frame
over a websocket. When sending a frame this small, 16 bits are all that
is required in order to encode the payload length on the websocket
frame. However, ast_websocket_write() thinks that the payload length is
greater than 65535 and therefore writes out a 64 bit payload length.
Inspecting this payload length, the lower 32 bits are exactly what we
would expect it to be, 537 in hex. The upper 32 bits, are junk values
that are not expected to be there.

In the failure, we are passing the result of strlen() to a function that
expects a uint64_t parameter to be passed in. strlen() returns a size_t,
which on this 32-bit machine is 32 bits wide. Normally, passing a 32-bit
unsigned value to somewhere where a 64-bit unsigned value is expected
would cause no problems. In fact, in manual runs of failing tests, this
works just fine. However, ast_websocket_write() uses the Asterisk
optional API, which means that rather than a simple function call, there
are a series of macros that are used for its declaration and
implementation. These macros may be causing some sort of error to occur
when converting from a 32 bit quantity to a 64 bit quantity.

This commit changes the logic by making existing ast_websocket_write()
calls use ast_websocket_write_string() instead. Within
ast_websocket_write_string(), the 64-bit converted strlen is saved in a
local variable, and that variable is passed to ast_websocket_write()
instead.

Note that this commit message is full of speculation rather than
certainty. This is because the observed test failures, while always
present in automated test runs, never occur when tests are manually
attempted on the same test agent. The idea behind this commit is to fix
a theoretical issue by performing changes that should, at the least,
cause no harm. If it turns out that this change does not fix the failing
tests, then this commit should be reverted.

Change-Id: I4458dd87d785ca322b89c152b223a540a3d23e67