]> git.ipfire.org Git - thirdparty/asterisk.git/log
thirdparty/asterisk.git
10 years agochan_pjsip: Don't change formats when frame of unsupported format is received. 03/903/3
Joshua Colp [Thu, 16 Jul 2015 14:46:14 +0000 (11:46 -0300)] 
chan_pjsip: Don't change formats when frame of unsupported format is received.

Receipt of an RTP packet currently causes the formats on an PJSIP channel to
change to the format of the RTP packet. In some off-nominal cases it's possible
for this to be a format that has not been configured or negotiated. This change
makes it so only formats explicitly configured on the endpoint are allowed.

ASTERISK-25258 #close

Change-Id: If93d641fb6418a285928839300d7854cab8c1020

10 years agoMerge "apps/app_dictate: Fix typo in attribution" into 13
Joshua Colp [Wed, 15 Jul 2015 15:48:40 +0000 (10:48 -0500)] 
Merge "apps/app_dictate: Fix typo in attribution" into 13

10 years agoMerge "ARI: Fixed unload mode for unload module." into 13
Mark Michelson [Wed, 15 Jul 2015 15:44:08 +0000 (10:44 -0500)] 
Merge "ARI: Fixed unload mode for unload module." into 13

10 years agoapps/app_dictate: Fix typo in attribution 95/895/1
Matt Jordan [Wed, 15 Jul 2015 15:31:51 +0000 (10:31 -0500)] 
apps/app_dictate: Fix typo in attribution

Last time I checked, it's "Sangoma", not "Samgoma". Thanks to Brian
(GameGamer43) for pointing that out.

Change-Id: I43d7b196f6d7a2b2517b84915e3a8dfbc2894106

10 years agoARI: Fixed unload mode for unload module. 92/892/1
Benjamin Ford [Wed, 15 Jul 2015 15:28:00 +0000 (10:28 -0500)] 
ARI: Fixed unload mode for unload module.

Changed the unload mode to AST_FORCE_SOFT from AST_FORCE_FIRM,
which would unload a module even if it was in use.

* Changed unload mode to proper mode

ASTERISK-25173

Change-Id: If2402487b5bce05d9770f25f65f5c8e292ad5533

10 years agoMerge "res_pjsip_session.c: Fix crash on call disconnect." into 13
Matt Jordan [Wed, 15 Jul 2015 03:17:45 +0000 (22:17 -0500)] 
Merge "res_pjsip_session.c: Fix crash on call disconnect." into 13

10 years agores/res_sorcery_astdb: Add a debugging message for when retrieval by ID fails 52/852/3
Matt Jordan [Wed, 8 Jul 2015 21:38:24 +0000 (16:38 -0500)] 
res/res_sorcery_astdb: Add a debugging message for when retrieval by ID fails

Having a debug message tell us that we attempted to look up an item but
failed is nice in circumstances when it isn't clear if the wizard was
queried correctly or not.

Change-Id: I2600c3bbea87f252196358f62e73f4c7da8632f7

10 years agores/res_pjsip_outbound_registration: Fix WARNING message 51/851/3
Matt Jordan [Wed, 8 Jul 2015 21:37:56 +0000 (16:37 -0500)] 
res/res_pjsip_outbound_registration: Fix WARNING message

Newlines are nice.

Change-Id: Icf0d915db02882e47cd9077ed9009f5d44140d42

10 years agores_pjsip/configuration: Fix a variety of default value problems 50/850/3
Matt Jordan [Wed, 8 Jul 2015 21:35:36 +0000 (16:35 -0500)] 
res_pjsip/configuration: Fix a variety of default value problems

This patch fixes some bad default value handling in the following
settings:

* The 'message_context' and 'accountcode' settings are not mandatory. As
  such, we can allow their stringfield values to be empty.
* The 'media_encryption' setting applies a default value of 'none' to
  the setting, which it then can't parse or understand. Since the value
  is documented to be 'no', this will now apply that as the default
  value.

Change-Id: Ib9be7f97a7a5b9bc7aee868edf5acf38774cff83

10 years agomain/sorcery: Provide log messages when a wizard does not support an operation 49/849/3
Matt Jordan [Wed, 8 Jul 2015 21:32:25 +0000 (16:32 -0500)] 
main/sorcery: Provide log messages when a wizard does not support an operation

If a sorcery wizard does not support one of the 'optional' CRUD
operations (namely the CUD), log a WARNING message so we are aware of
why the operation failed. This also removes an assert in this case, as
the CUD operation may have been triggered by an external system, in
which case it is not a programming error but a configuration error.

Change-Id: Ifecd9df946d9deaa86235257b49c6e5e24423b53

10 years agores_pjsip_session.c: Fix crash on call disconnect. 89/889/1
Richard Mudgett [Fri, 10 Jul 2015 23:17:52 +0000 (18:17 -0500)] 
res_pjsip_session.c: Fix crash on call disconnect.

The crash fix for ASTERISK-25183 backported some code from master to try
to make sure that a BYE response is processed by the same serializer used
by the BYE request.  The identified race condition causing that backport
was the BYE request code had not finished processing after sending the BYE
before the BYE response came in for processing under a different thread.
Unfortunately, there is still a race condition.  Now the race condition is
between destroying the call session's serializer in
ast_taskprocessor_unreference() and using ast_taskprocessor_get() to get a
reference to the serializer for a BYE response.  Even worse, the new race
condition is a design limitation of the taskprocessor implementation that
didn't matter in versions before v12.  Back then, taskprocessors were only
destroyed when a module unloaded.  Now res_pjsip can destroy them when a
call ends.

However, as noted on the ASTERISK-25183 commit,
session_inv_on_state_changed() is disassociating the dialog from the
session when the invite dialog state becomes PJSIP_INV_STATE_DISCONNECTED.
This is a tad too soon because our BYE request transaction has not
completed yet.

* Split session_end() that is called by session_inv_on_state_changed() to
hold off session destruction until the BYE transaction timeout occurs or a
failed initial INVITE transaction timeout occurs in
session_inv_on_tsx_state_changed().

ASTERISK-25201 #close
Reported by: Matt Jordan

Change-Id: Iaf8dc8485fd8392a2a3ee4ad3b7f7f04a0dcc961

10 years agoARI: Added new functionality to reload a single module. 58/858/3
Benjamin Ford [Tue, 14 Jul 2015 18:12:32 +0000 (13:12 -0500)] 
ARI: Added new functionality to reload a single module.

An http request can be sent to reload an Asterisk module. If the
module can not be reloaded or is not already loaded, an error
response will be returned.

The command "curl -v -u user:pass -X PUT 'http://localhost:8088
/ari/asterisk/modules/{moduleName}'" (or something similar, based
on configuration) can be run in the terminal to access this new
functionality.

For more information, see:
https://wiki.asterisk.org/wiki.display/~bford/Asterisk+ARI+Resource

* Added new ARI functionality
* Asterisk modules can be reloaded through http requests

ASTERISK-25173

Change-Id: I289188bcae182b2083bdbd9ebfffd50b62f58ae1

10 years agoARI: Added new functionality to unload a single module. 08/808/5
Benjamin Ford [Tue, 14 Jul 2015 13:55:14 +0000 (08:55 -0500)] 
ARI: Added new functionality to unload a single module.

An http request can be sent to unload an Asterisk module. If the
module can not be unloaded or is already unloaded, an error response
will be returned.

The command "curl -v -u user:pass -X DELETE 'http://localhost:8088
/ari/asterisk/modules/{moduleName}'" (or something similar, depending
on configuration) can be run in the terminal to access this new
functionality.

For more information, see:
https://wiki.asterisk.org/wiki.display/~bford/Asterisk+ARI+Resource

* Added new ARI functionality
* Asterisk modules can be unloaded through http requests

ASTERISK-25173

Change-Id: I535a95f5676deb02651522761ecbdc0b00b5ac57

10 years agoARI: Added new functionality to load a single module. 07/807/8
Benjamin Ford [Mon, 13 Jul 2015 21:00:19 +0000 (16:00 -0500)] 
ARI: Added new functionality to load a single module.

An http request can be sent to load an Asterisk module. If the
module can not be loaded or is loaded already, an error response
will be returned.

The command curl -v -u user:pass -X POST 'http://localhost:8088/ari
/asterisk/modules/{moduleName}'" (or something similar, depending on
configuration) can be run in the terminal to access this new
functionality.

For more information, see:
https://wiki.asterisk.org/wiki.display/~bford/Asterisk+ARI+Resource

* Added new ARI functionality
* Asterisk modules can be loaded through http requests

ASTERISK-25173

Change-Id: I9e05d5b8c5c666ecfef341504f9edc1aa84fda33

10 years agoMerge "ARI: Added new functionality to get information on a single module." into 13
Mark Michelson [Mon, 13 Jul 2015 20:15:44 +0000 (15:15 -0500)] 
Merge "ARI: Added new functionality to get information on a single module." into 13

10 years agoMerge "bridge.c: Fixed race condition during attended transfer" into 13
Mark Michelson [Mon, 13 Jul 2015 19:51:22 +0000 (14:51 -0500)] 
Merge "bridge.c: Fixed race condition during attended transfer" into 13

10 years agoARI: Added new functionality to get information on a single module. 90/790/10
Benjamin Ford [Mon, 13 Jul 2015 15:54:51 +0000 (10:54 -0500)] 
ARI: Added new functionality to get information on a single module.

An http request can be sent to retrieve information on a single
module, including the resource name, description, use count, status,
and support level.

The command "curl -v -u user:pass -X GET 'http://localhost:8088/ari
/asterisk/modules/{moduleName}'" (or something similar, depending on
configuration) can be run in the terminal to access this new
functionality.

For more information, see:
https://wiki.asterisk.org/wiki.display/~bford/Asterisk+ARI+Resource

* Added new ARI functionality
* Information on a single module can now be retrieved

ASTERISK-25173

Change-Id: Ibce5a94e70ecdf4e90329cf0ba66c33a62d37463

10 years agobridge.c: Fixed race condition during attended transfer 39/839/5
Kevin Harwell [Wed, 8 Jul 2015 19:56:10 +0000 (14:56 -0500)] 
bridge.c: Fixed race condition during attended transfer

During an attended transfer a thread is started that handles imparting the
bridge channel. From the start of the thread to when the bridge channel is
ready exists a gap that can potentially cause problems (for instance, the
channel being swapped is hung up before the replacement channel enters the
bridge thus stopping the transfer). This patch adds a condition that waits
for the impart thread to get to a point of acceptable readiness before
allowing the initiating thread to continue.

ASTERISK-24782
Reported by: John Bigelow

Change-Id: I08fe33a2560da924e676df55b181e46fca604577

10 years agoMerge "main/format_cap: Parse capabilities generated by ast_format_cap_get_names...
Matt Jordan [Mon, 13 Jul 2015 17:53:54 +0000 (12:53 -0500)] 
Merge "main/format_cap: Parse capabilities generated by ast_format_cap_get_names" into 13

10 years agomain/sorcery: Don't fail object set creation from JSON if field fails 48/848/3
Matt Jordan [Wed, 8 Jul 2015 21:28:13 +0000 (16:28 -0500)] 
main/sorcery: Don't fail object set creation from JSON if field fails

Some individual fields may fail their conversion due to their default
values being invalid for their custom handlers. In particular,
configuration values that depend on others being enabled (and thus have
an empty default value) are notorious for tripping this routine up. An
example of this are any of the DTLS options for endpoints. Any of the
DTLS options will fail to be applied (as DTLS is not enabled), causing
the entire object set to be aborted.

This patch makes it so that we log a debug message when skipping a
field, and rumble on anyway.

ASTERISK-25238

Change-Id: I0bea13de79f66bf9f9ae6ece0e94a2dc1c026a76

10 years agomain/format_cap: Parse capabilities generated by ast_format_cap_get_names 47/847/2
Matt Jordan [Wed, 8 Jul 2015 21:21:09 +0000 (16:21 -0500)] 
main/format_cap: Parse capabilities generated by ast_format_cap_get_names

We have a strange relationship between the parsing of format
capabilities from a string and their representation as a string. We
expect the format capabilities to be expressed as a string in the
following format:

allow = !all,ulaw,alaw
disallow = g722

While we would generate the string representation of those formats as:

allow = (ulaw|alaw)
disallow = (ulaw|alaw|g729...)

When the configuration framework needs to store values as a string, it
generates the format capabilities using the second representation; this
representation however cannot be parsed when the entry is rehydrated.
This patch fixes that by updating
ast_format_cap_update_by_allow_disallow to parse an entry as if it were
in the generated format if it has a leading '(' and a trailing ')'.

ASTERISK-25238

Change-Id: I904d43caf4cf45af06f6aee0c9e58556eb91d6ca

10 years agoMerge "tests/test_devicestate: Add additional tests for the device state API" into 13
Matt Jordan [Sat, 11 Jul 2015 16:44:13 +0000 (11:44 -0500)] 
Merge "tests/test_devicestate: Add additional tests for the device state API" into 13

10 years agoMerge "res/res_sorcery_memory_cache: Fix test registration issues" into 13
Matt Jordan [Sat, 11 Jul 2015 16:31:28 +0000 (11:31 -0500)] 
Merge "res/res_sorcery_memory_cache: Fix test registration issues" into 13

10 years agoMerge "tests/test_sorcery_memory_cache_thrash: Fix test loading problems" into 13
Matt Jordan [Sat, 11 Jul 2015 16:31:23 +0000 (11:31 -0500)] 
Merge "tests/test_sorcery_memory_cache_thrash: Fix test loading problems" into 13

10 years agotests/test_devicestate: Add additional tests for the device state API 70/870/1
Matt Jordan [Sat, 27 Jun 2015 22:53:37 +0000 (17:53 -0500)] 
tests/test_devicestate: Add additional tests for the device state API

This patch adds more tests that exercise the device state API. This includes:

* Tests that cover adding a device state provider, as well as deleting a
  device state provider. This also verifies that you cannot add an
  already added device state provider, and cannot delete an already
  deleted device state provider.
* A test that covers changing device state and receiving said updates
  from a device state subscriber. This also covers hitting both the
  device state cache as well as a custom device state provider.
* A test that covers converting device state to channel state and device
  state values to a string representation and back.
* A test that covers obtaining device state from an active channel and a
  channel driver that provides its own device state.

Change-Id: I2adca67ffb405cd8625a5d6df1e3f9b3d945c08d

10 years agomain/devicestate: Prevent duplicate registration of device state providers 84/784/2
Matt Jordan [Sat, 27 Jun 2015 22:51:43 +0000 (17:51 -0500)] 
main/devicestate: Prevent duplicate registration of device state providers

Currently, the device state provider API will allow you to register a
device state provider with the same case insensitive name more than
once. This could cause strange issues, as the duplicate device state
providers will not be queried when a device's state has to be polled.
This patch updates the API such that a device state provider with the
same name as one that has already registered will be rejected.

Change-Id: I4a418a12280b7b6e4960bd44f302e27cd036ceb2

10 years agores/res_sorcery_memory_cache: Fix test registration issues 69/869/1
Matt Jordan [Sat, 11 Jul 2015 03:25:00 +0000 (22:25 -0500)] 
res/res_sorcery_memory_cache: Fix test registration issues

Again, tests now need to not end with a newline. This patch makes it so
the tests can register again, unit tests will actually pass, and we can
stop wasting time trying to figure out why builds are failing when they
really aren't failing.

Change-Id: Ide519fbeba89f413c733446c5ff7b224fc4ce840

10 years agoMerge "ARI: Added new functionality to get all module information." into 13
Matt Jordan [Sat, 11 Jul 2015 02:46:38 +0000 (21:46 -0500)] 
Merge "ARI: Added new functionality to get all module information." into 13

10 years agotests/test_sorcery_memory_cache_thrash: Fix test loading problems 68/868/1
Matt Jordan [Sat, 11 Jul 2015 02:42:58 +0000 (21:42 -0500)] 
tests/test_sorcery_memory_cache_thrash: Fix test loading problems

Because unit tests now want descriptions to not end with a newline, the
sorcery memory cache thrash tests failed to register. This patch
corrects their descriptions.

Change-Id: Id004b1becfdeed8ee3c846f49beab76a5c0f68b6

10 years agoARI: Added new functionality to get all module information. 32/732/11
Benjamin Ford [Fri, 26 Jun 2015 15:57:15 +0000 (10:57 -0500)] 
ARI: Added new functionality to get all module information.

An http request can be sent to retrieve a list of all existing modules,
including the resource name, description, use count, status, and
support level.

The command "curl -v -u user:pass -X GET 'http://localhost:8088/ari/
asterisk/modules" (or something similar, depending on configuration)
can be run in the terminal to access this new functionality.

For more information, see:
https://wiki.asterisk.org/wiki.display/~bford/Asterisk+ARI+Resource

* Added new ARI functionality
* Information on modules can now be retrieved

Change-Id: I63cbbf0ec0c3544cc45ed2a588dceabe91c5e0b0

10 years agoMerge "bridge_native_rtp.c: Don't start native RTP bridging after attended transfer...
Matt Jordan [Fri, 10 Jul 2015 14:29:29 +0000 (09:29 -0500)] 
Merge "bridge_native_rtp.c: Don't start native RTP bridging after attended transfer." into 13

10 years agobridge_native_rtp.c: Don't start native RTP bridging after attended transfer. 55/855/2
Joshua Colp [Thu, 9 Jul 2015 14:18:11 +0000 (11:18 -0300)] 
bridge_native_rtp.c: Don't start native RTP bridging after attended transfer.

The bridge_native_rtp module adds a frame hook to channels which are in
a native RTP bridge. This frame hook is used to intercept when a hold
or unhold frame traverses the bridge so native RTP can be stopped or
started as appropriate. This is expected but exposes a specific bug
when attended transfers are involved.

Upon completion of an attended transfer an unhold frame is queued up
to take one of the channels involved off hold. After this is done
the channel is moved between bridges.

When the frame hook is involved in this case for the unhold it
releases the channel lock and acquires the bridge lock. This
allows the bridge core to step in and move the channel
(potentially changing the bridging techology) from another thread.
Once completed the bridge lock is released by the bridge core.
The frame hook is then able to acquire the bridge lock and
wrongfully starts native RTP again, despite the channel no longer
being in the bridge or needing to start native RTP. In fact at
this point the frame hook is no longer attached to the channel.

This change makes it so the native RTP bridge data is available to
the frame hook when it is invoked. Whether the frame hook has
been detached or not is stored on the native RTP bridge data and
is checked by the frame hook before starting or stopping native
RTP bridging. If the frame hook has been detached it does nothing.

ASTERISK-25240 #close

Change-Id: I13a73186a05f4e5a764f81e5cd0ccec1ed1891d2

10 years agores_sorcery_memory_cache: Backport to 13 54/854/1
Joshua Colp [Sat, 16 May 2015 22:02:50 +0000 (19:02 -0300)] 
res_sorcery_memory_cache: Backport to 13

Gerrit is complaining of conflicts when trying to create a patch series
of all of the cherry-picked master commits, so I have instead squashed
it all into one commit.

ASTERISK-25067 #close
Reported by: Matt Jordan

Change-Id: I6dda90343fae24a75dc5beec84980024e8d61eb9

10 years agores_rtp_asterisk: Ensure DTLS timeout timer is -1 if DTLS is not used. 10/810/1
Joshua Colp [Wed, 8 Jul 2015 09:21:16 +0000 (06:21 -0300)] 
res_rtp_asterisk: Ensure DTLS timeout timer is -1 if DTLS is not used.

This change fixes a bug where the DTLS timeout timer would be
initialized to 0 if DTLS was not used for an RTP session.

ASTERISK-25103

Change-Id: If8d26bb054f1d300838850da5b8db9044c2fe2ac

10 years agoMerge "res_pjsip_mwi.c: Use safer loop coding in mwi_subscription_mailboxes_str(...
Matt Jordan [Wed, 8 Jul 2015 01:38:42 +0000 (20:38 -0500)] 
Merge "res_pjsip_mwi.c: Use safer loop coding in mwi_subscription_mailboxes_str()." into 13

10 years agoMerge "res_pjsip_mwi.c: Fix MWI subscription memory corruption crash." into 13
Matt Jordan [Wed, 8 Jul 2015 01:38:12 +0000 (20:38 -0500)] 
Merge "res_pjsip_mwi.c: Fix MWI subscription memory corruption crash." into 13

10 years agoMerge "PJSIP XML, XPIDF: Fix buffer size overwrite memory corruption error." into 13
Joshua Colp [Tue, 7 Jul 2015 22:38:59 +0000 (17:38 -0500)] 
Merge "PJSIP XML, XPIDF: Fix buffer size overwrite memory corruption error." into 13

10 years agoMerge topic 'res_pjsip_mwi_cleanups' into 13
Joshua Colp [Tue, 7 Jul 2015 22:24:36 +0000 (17:24 -0500)] 
Merge topic 'res_pjsip_mwi_cleanups' into 13

* changes:
  res_pjsip_mwi.c: Eliminate a simple RAII_VAR.
  res_pjsip_mwi.c: Fix mid-line log message line breaks.

10 years agoMerge "PJSIP FAX: Fix T.38 automatic reject timer NULL channel pointer dereferences...
Joshua Colp [Tue, 7 Jul 2015 22:20:46 +0000 (17:20 -0500)] 
Merge "PJSIP FAX: Fix T.38 automatic reject timer NULL channel pointer dereferences." into 13

10 years agoMerge "res_pjsip_t38.c: Fix always false if test." into 13
Joshua Colp [Tue, 7 Jul 2015 22:12:18 +0000 (17:12 -0500)] 
Merge "res_pjsip_t38.c: Fix always false if test." into 13

10 years agoMerge "res_pjsip: Need to use the same serializer for a pjproject SIP transaction...
Joshua Colp [Tue, 7 Jul 2015 22:11:26 +0000 (17:11 -0500)] 
Merge "res_pjsip: Need to use the same serializer for a pjproject SIP transaction." into 13

10 years agoMerge "res/res_http_websocket: Don't send HTTP response fragmented." into 13
Joshua Colp [Tue, 7 Jul 2015 22:01:24 +0000 (17:01 -0500)] 
Merge "res/res_http_websocket: Don't send HTTP response fragmented." into 13

10 years agores_rtp_asterisk: Prevent simultaneous access to DTLS SSL context. 87/787/5
Joshua Colp [Wed, 1 Jul 2015 12:55:47 +0000 (09:55 -0300)] 
res_rtp_asterisk: Prevent simultaneous access to DTLS SSL context.

This change moves logic for setting up the DTLS SSL contexts to
when the SDP is done being processed instead of when ICE negotiation
completes. It also stops handshakes from being initiated when we
are acting as a server.

Manipulating the SSL context when ICE negotiation has completed
is problematic as the SSL context is not protected and if acting
as a client the remote side may have started DTLS negotiation
already.

The retransmission timeout timer code has also been split up
and simplified some. Both RTP and RTCP now have their own timers
and the points at which the timer is stopped and started is now
more specific. When a packet is sent the timer is started. When
a response is received but before it is processed the timer is
stopped. This provides a guarantee that the timeout is not
occurring while the response is processed.

ASTERISK-22805 #close
ASTERISK-24550 #close
ASTERISK-24651 #close
ASTERISK-24832 #close
ASTERISK-25103 #close
ASTERISK-25127 #close

Change-Id: Ib75ea2546f29d6efc3d2d37c58df6986c7bd9b91

10 years agores_pjsip_t38.c: Fix always false if test. 93/793/1
Richard Mudgett [Fri, 26 Jun 2015 21:10:26 +0000 (16:10 -0500)] 
res_pjsip_t38.c: Fix always false if test.

Calling t38_change_state() sets the t38 state so it makes little sense to
then check the state right after the call for something else.

* Made the code in t38_interpret_parameters() reject or exit T.38 mode as
intended but not implemented.

Change-Id: Ib281263a6ed44da9448132c4e6df1e183b8a3df2

10 years agores_pjsip_mwi.c: Use safer loop coding in mwi_subscription_mailboxes_str(). 97/797/1
Richard Mudgett [Tue, 30 Jun 2015 16:17:25 +0000 (11:17 -0500)] 
res_pjsip_mwi.c: Use safer loop coding in mwi_subscription_mailboxes_str().

Change-Id: I6f39d809a6d1b47b35bb32b298f5a12f35d6f907

10 years agores_pjsip_mwi.c: Eliminate a simple RAII_VAR. 96/796/1
Richard Mudgett [Tue, 30 Jun 2015 16:14:57 +0000 (11:14 -0500)] 
res_pjsip_mwi.c: Eliminate a simple RAII_VAR.

Change-Id: Ib1843f81e826a6c760c424c88eb70c350d9d61da

10 years agores_pjsip_mwi.c: Fix mid-line log message line breaks. 95/795/1
Richard Mudgett [Tue, 30 Jun 2015 16:11:19 +0000 (11:11 -0500)] 
res_pjsip_mwi.c: Fix mid-line log message line breaks.

* Add create_mwi_subscriptions_for_endpoint() doxygen comment.

Change-Id: I3c3f921f4ec749fb65b62d2f6fa0d4d1888b94e2

10 years agores_pjsip_mwi.c: Fix MWI subscription memory corruption crash. 03/803/1
Richard Mudgett [Fri, 26 Jun 2015 23:48:35 +0000 (18:48 -0500)] 
res_pjsip_mwi.c: Fix MWI subscription memory corruption crash.

MWI subscriptions can crash or corrupt memory when using the subscription
datastore to access the MWI subscription object because the datastore is
not holding a reference to the object.

* Give the subscription datastore a ref to the MWI subscription object.
It is unfortunate that the ref causes a circular ref chain that must be
explicitly broken to allow the memory to get released.  The loop is broken
when the subscription is shutdown and if the subscription setup fails.

ASTERISK-25168 #close
Reported by: Carl Fortin

Change-Id: Ice4fa823f138ff10a6c74d280699c41a82836d4f

10 years agoPJSIP XML, XPIDF: Fix buffer size overwrite memory corruption error. 02/802/1
Richard Mudgett [Thu, 2 Jul 2015 19:51:29 +0000 (14:51 -0500)] 
PJSIP XML, XPIDF: Fix buffer size overwrite memory corruption error.

When res_pjsip body generator modules were generating XML or XPIDF
response bodies, there was a chance that the generated body would be the
exact size of the supplied buffer.  Adding the nul string terminator would
then write beyond the end of the buffer and potentially corrupt memory.

* Fix MALLOC_DEBUG high fence violations caused by adding a nul string
terminator on the end of a buffer for XML or XPIDF response bodies.

* Made calls to pj_xml_print() safer if the XML prolog is requested.  Due
to a bug in pjproject, the return value could be -1 _or_
AST_PJSIP_XML_PROLOG_LEN if the supplied buffer is not large enough.

* Updated the doxygen comment of AST_PJSIP_XML_PROLOG_LEN to describe the
return value of pj_xml_print() when the supplied buffer is not large
enough.

ASTERISK-25168
Reported by: Carl Fortin

Change-Id: Id70e1d373a6a2b2bd9e678b5cbc5e55b308981de

10 years agoPJSIP FAX: Fix T.38 automatic reject timer NULL channel pointer dereferences. 01/801/1
Richard Mudgett [Fri, 26 Jun 2015 15:36:19 +0000 (10:36 -0500)] 
PJSIP FAX: Fix T.38 automatic reject timer NULL channel pointer dereferences.

When a caller calls a FAX number and then hangs up right after the call is
answered then the T.38 re-INVITE automatic reject timer may still be
running after the channel goes away.

* Added session NULL channel checks on the code paths that get executed by
t38_automatic_reject() to prevent a crash when the T.38 re-INVITE
automatic reject timer expires.

ASTERISK-25168
Reported by: Carl Fortin

Change-Id: I07b6cd23815aedce5044f8f32543779e2f7a2403

10 years agores_pjsip: Need to use the same serializer for a pjproject SIP transaction. 92/792/1
Richard Mudgett [Fri, 5 Jun 2015 20:37:33 +0000 (15:37 -0500)] 
res_pjsip: Need to use the same serializer for a pjproject SIP transaction.

All send/receive processing for a SIP transaction needs to be done under
the same threadpool serializer to prevent reentrancy problems inside
pjproject and res_pjsip.

* Add threadpool API call to get the current serializer associated with
the worker thread.

* Pick a serializer from a pool of default serializers if the caller of
res_pjsip.c:ast_sip_push_task() does not provide one.

This is a simple way to ensure that all outgoing SIP request messages are
processed under a serializer.  Otherwise, any place where a pushed task is
done that would result in an outgoing out-of-dialog request would need to
be modified to supply a serializer.  Serializers from the default
serializer pool are picked in a round robin sequence for simplicity.

A side effect is that the default serializer pool will limit the growth of
the thread pool from random tasks.  This is not necessarily a bad thing.

* Made pjsip_distributor.c save the thread's serializer name on the
outgoing request tdata struct so the response can be processed under the
same serializer.

This is a cherry-pick from master.

**** ASTERISK-25115 Change-Id: Iea71c16ce1132017b5791635e198b8c27973f40a

NOTE: session_inv_on_state_changed() is disassociating the dialog from the
session when the invite dialog becomes PJSIP_INV_STATE_DISCONNECTED.
Unfortunately this is a tad too soon because our BYE request transaction
has not completed yet.

ASTERISK-25183 #close
Reported by: Matt Jordan

Change-Id: I8bad0ae1daf18d75b8c9e55874244b7962df2d0a

10 years agoMerge "chan_sip: Fix early call pickup channel leak." into 13
Joshua Colp [Sun, 5 Jul 2015 00:09:51 +0000 (19:09 -0500)] 
Merge "chan_sip: Fix early call pickup channel leak." into 13

10 years agores/res_http_websocket: Don't send HTTP response fragmented. 79/779/1
Joshua Colp [Sat, 4 Jul 2015 23:22:01 +0000 (20:22 -0300)] 
res/res_http_websocket: Don't send HTTP response fragmented.

This change makes it so that when accepting a WebSocket
connection the HTTP response is sent as one packet instead of
fragmented. Browsers don't like it when you send it fragmented.

ASTERISK-25103

Change-Id: I9b82c4ec2949b0bce692ad0bf6f7cea9709e7f69

10 years agoMakefile: Remove coverage files on 'make clean' 77/777/1
Matt Jordan [Sat, 27 Jun 2015 23:47:19 +0000 (18:47 -0500)] 
Makefile: Remove coverage files on 'make clean'

This patch updates a variety of Makefiles in Asterisk's build system to
remove .gcda and .gcno files when 'make clean' is executed. These files
are generated when '--enable-coverage' is passed to the Asterisk
configure script.

Change-Id: Ib70b41eea2ee2908885bff02e80faf9f40c84602

10 years agoMerge "chan_vpb.cc: Fix compiler warning Jenkins found." into 13
Joshua Colp [Thu, 2 Jul 2015 14:47:48 +0000 (09:47 -0500)] 
Merge "chan_vpb.cc: Fix compiler warning Jenkins found." into 13

10 years agochan_sip: Fix early call pickup channel leak. 74/774/1
Walter Doekes [Thu, 2 Jul 2015 14:08:12 +0000 (16:08 +0200)] 
chan_sip: Fix early call pickup channel leak.

When handle_invite_replaces() was called, and either ast_bridge_impart()
failed or there was no bridge (because the channel we're picking up was
still ringing), chan_sip would leak a channel.

Thanks Matt and Corey for checking the bridge path.

ASTERISK-25226 #close

Change-Id: Ie736bb182170a73eef5bcef0ab0376f645c260c8

10 years agoMerge "sorcery/realtime: Add a bit of debug and warning messages for bad configs...
Matt Jordan [Thu, 2 Jul 2015 13:02:00 +0000 (08:02 -0500)] 
Merge "sorcery/realtime: Add a bit of debug and warning messages for bad configs" into 13

10 years agoMerge "res_timing: Don't close FD 0 when out of open files." into 13
Joshua Colp [Thu, 2 Jul 2015 12:53:35 +0000 (07:53 -0500)] 
Merge "res_timing: Don't close FD 0 when out of open files." into 13

10 years agoMerge "rtp_engine: Skip useless self-assignment in ast_rtp_engine_unload_format....
Joshua Colp [Thu, 2 Jul 2015 12:52:29 +0000 (07:52 -0500)] 
Merge "rtp_engine: Skip useless self-assignment in ast_rtp_engine_unload_format." into 13

10 years agoMerge "astfd: Fix buffer overflow in DEBUG_FD_LEAKS." into 13
Joshua Colp [Thu, 2 Jul 2015 12:51:43 +0000 (07:51 -0500)] 
Merge "astfd: Fix buffer overflow in DEBUG_FD_LEAKS." into 13

10 years agoMerge "chan_mgcp: Don't call close on fd -1." into 13
Joshua Colp [Thu, 2 Jul 2015 12:50:40 +0000 (07:50 -0500)] 
Merge "chan_mgcp: Don't call close on fd -1." into 13

10 years agochan_mgcp: Don't call close on fd -1. 69/769/1
Walter Doekes [Thu, 2 Jul 2015 11:19:34 +0000 (13:19 +0200)] 
chan_mgcp: Don't call close on fd -1.

ASTERISK-25220 #close

Change-Id: Ic48f3a82f51ada87f2fb0e016c9efe0ad56f1ee3

10 years agortp_engine: Skip useless self-assignment in ast_rtp_engine_unload_format. 66/766/1
Walter Doekes [Thu, 2 Jul 2015 11:10:59 +0000 (13:10 +0200)] 
rtp_engine: Skip useless self-assignment in ast_rtp_engine_unload_format.

When running valgrind on Asterisk, it complained about:

    ==32423== Source and destination overlap in memcpy(0x85a920, 0x85a920, 304)
    ==32423==    at 0x4C2F71C: memcpy@@GLIBC_2.14 (in /usr/lib/valgrind/...)
    ==32423==    by 0x55BA91: ast_rtp_engine_unload_format (rtp_engine.c:2292)
    ==32423==    by 0x4EEFB7: ast_format_attr_unreg_interface (format.c:1437)

The code in question is a struct assignment, which may be performed by
memcpy as a compiler optimization. It is changed to only copy the struct
contents if source and destination are different.

ASTERISK-25219 #close

Change-Id: I6d3546c326b03378ca8e9b8cefd41c16e0088b9a

10 years agoastfd: Fix buffer overflow in DEBUG_FD_LEAKS. 63/763/1
Walter Doekes [Thu, 2 Jul 2015 10:16:26 +0000 (12:16 +0200)] 
astfd: Fix buffer overflow in DEBUG_FD_LEAKS.

If DEBUG_FD_LEAKS was used and more file descriptors than the default of
1024 were available, some DEBUG_FD_LEAKS-patched functions would
overwrite memory past the fixed-size (1024) fdleaks buffer.

This change:
- adds bounds checks to __ast_fdleak_fopen and __ast_fdleak_pipe
- consistently uses ARRAY_LEN() instead of sizeof() or 1023 or 1024
- stores pointers to constants instead of copying the contents
- reorders the fdleaks struct for possibly tighter packing
- adds a tiny bit of documentation

ASTERISK-25212 #close

Change-Id: Iacb69e7701c0f0a113786bd946cea5b6335a85e5

10 years agores_timing: Don't close FD 0 when out of open files. 60/760/1
Walter Doekes [Thu, 2 Jul 2015 09:57:44 +0000 (11:57 +0200)] 
res_timing: Don't close FD 0 when out of open files.

This fixes so a failure to get a timer file descriptor does not cascade
to closing FD 0.

On error, both res_timing_kqueue and res_timing_timerfd would call the
destructor before setting the file handle. The file handle had been
initialized to 0, causing FD 0 to be closed. This in turn, resulted in
floods of "CLI>" messages and an unusable terminal.

ASTERISK-19277 #close
Reported by: Barry Chern

For the 13 branch, this was already fixed. This patch only ensures that
we do not attempt to close a negative file descriptor.

Change-Id: I147d7e33726c6e5a2751928d56561494f5800350

10 years agochan_vpb.cc: Fix compiler warning Jenkins found. 57/757/1
Richard Mudgett [Wed, 1 Jul 2015 22:25:31 +0000 (17:25 -0500)] 
chan_vpb.cc: Fix compiler warning Jenkins found.

Change-Id: I0ec7fd10d56d90d5a60b12b5a7d6807f265ac5e0

10 years agoChannel alert pipe: improve diagnostic error return 54/754/1
Scott Griepentrog [Wed, 1 Jul 2015 18:34:46 +0000 (13:34 -0500)] 
Channel alert pipe: improve diagnostic error return

When a frame is queued on a channel, any failure in
ast_channel_alert_write is logged along with errno.

This change improves the diagnostic message through
aligning the errno value with actual failure cases.

ASTERISK-25224
Reported by: Andrey Biglari

Change-Id: I1bf7b3337ad392789a9f02c650589cd065d20b5b

10 years agosorcery/realtime: Add a bit of debug and warning messages for bad configs 53/753/2
Matt Jordan [Wed, 1 Jul 2015 21:04:50 +0000 (16:04 -0500)] 
sorcery/realtime: Add a bit of debug and warning messages for bad configs

When a mapping does not exist between a sorcery.conf defined object and
a realtime mapping in extconf, currently, the user will receive a slew
of ERROR messages that don't really tell what is happening. Some ERROR
messages may even be misleading, as they occur after the sorcery API has
already given up on the attempt to load and create the sorcery object.

This patch adds a bit of debug and a useful WARNING message for when a
wizard's open callback fails for a particular object type. In the bad
configurations that resulted in this patch, this provided a 'root cause'
WARNING message that pointed in the right direction of the configuration
problem.

Change-Id: I1cc7344f2b015b8b9c85a7e6ebc8cb4753a8f80b

10 years agoMerge "res_sorcery_realtime: Fix leak of sorcery object type." into 13
Joshua Colp [Tue, 30 Jun 2015 12:32:03 +0000 (07:32 -0500)] 
Merge "res_sorcery_realtime: Fix leak of sorcery object type." into 13

10 years agoMerge "channel: Remove ignore of answer on non-outgoing channels." into 13
Matt Jordan [Tue, 30 Jun 2015 12:07:13 +0000 (07:07 -0500)] 
Merge "channel: Remove ignore of answer on non-outgoing channels." into 13

10 years agores_sorcery_realtime: Fix leak of sorcery object type. 45/745/2
Mark Michelson [Mon, 29 Jun 2015 17:45:02 +0000 (12:45 -0500)] 
res_sorcery_realtime: Fix leak of sorcery object type.

This prevents a leak of a sorcery object type when realtime sorcery
objects are retrieved by fields or when multiple objects are retrieved.

The extent of this leak is that sorcery object types would be leaked.
These are allocated whenever an object type is registered with sorcery,
meaning that on module shutdown, these objects would be leaked. This
could be problematic if many reloads were performed, but it is not as
severe as if every sorcery object retrieved from realtime were being
leaked.

ASTERISK-25165 #close
Reported by Corey Farrell

Change-Id: I625c3b50eee4576670b7eeb013c81ad043b4b4f8

10 years agoMerge "res_pjsip_nat: Adjust when contact should be rewritten." into 13
Matt Jordan [Mon, 29 Jun 2015 16:57:00 +0000 (11:57 -0500)] 
Merge "res_pjsip_nat: Adjust when contact should be rewritten." into 13

10 years agoMerge "res/res_corosync: Always decline module load, instead of failing" into 13
Matt Jordan [Mon, 29 Jun 2015 16:16:01 +0000 (11:16 -0500)] 
Merge "res/res_corosync: Always decline module load, instead of failing" into 13

10 years agores/res_corosync: Always decline module load, instead of failing 41/741/1
Matt Jordan [Sat, 27 Jun 2015 03:02:42 +0000 (22:02 -0500)] 
res/res_corosync: Always decline module load, instead of failing

Returns a 'failure' from the module load routine indicates to Asterisk
that it should abort loading completely. This is rarely - in fact,
really, never - a good option. Aborting load of Asterisk from a dynamic
module implies that the core, and the rest of the dynamic modules, don't
matter: we should abandon all processing.

res_corosync is really not that important.

This patch updates the module such that, if it fails to load, it
politely declines (emitting ERROR messages along the way), and allows
Asterisk to continue to function.

Note that this issue was keeping Asterisk unit tests from running on
certain build agents.

Change-Id: I252249e81fb9b1a68e0da873f54f47e21d648f0f

10 years agomain/pbx: Resolve case sensitivity regression in PBX hints 39/739/1
Matt Jordan [Sat, 27 Jun 2015 01:38:58 +0000 (20:38 -0500)] 
main/pbx: Resolve case sensitivity regression in PBX hints

When 8297136f was merged for ASTERISK-25040, a regression was introduced
surrounding the case sensitivity of device names within hints.
Previously, device names - such as 'sip/foo' - were compared in a case
insensitive fashion. Thus, 'sip/foo' was equivalent to 'SIP/foo'. After
that patch, only the case sensitive name would match, i.e., 'SIP/foo'.
As a result, some dialplan hints stopped working.

This patch re-introduces case insensitive matching for device names in
hints.

ASTERISK-25040

ASTERISK-25202 #close

Change-Id: If5046a7d14097e1e3c12b63092b9584bb1e9cb4c
(cherry picked from commit 96bbcf495a1da9e607d9b04a44b5c4f49e83cc03)

10 years agores_pjsip_nat: Adjust when contact should be rewritten. 36/736/1
Mark Michelson [Fri, 26 Jun 2015 21:12:33 +0000 (16:12 -0500)] 
res_pjsip_nat: Adjust when contact should be rewritten.

A previous change made the contact only get rewritten if the dialog's
route set was not marked frozen. Unfortunately, while the intent of this
is correct, the dialog's route set actually gets marked as frozen
earlier than expected, especially for UAS dialogs.

Instead, the idea is that the contact needs to not be rewritten if there
is a pre-existing route set on the dialog. This is now accomplished by
checking the dialog's route set list instead of checking if the route
set is frozen.

Doing this causes some broken tests to begin passing again.

ASTERISK-25196
Reported by Mark Michelson

Change-Id: I525ab251fd40a52ede327a52a2810a56deb0529e

10 years agores_pjsip_outbound_registration.c: Add a serializer shutdown group. 91/691/4
Richard Mudgett [Fri, 19 Jun 2015 23:27:24 +0000 (18:27 -0500)] 
res_pjsip_outbound_registration.c: Add a serializer shutdown group.

The client_state objects contain a serializer used to send the outbound
REGISTER messages.  Once all those message transactions are complete then
the module can shutdown.

ASTERISK-24907 #close
Reported by: Kevin Harwell

Change-Id: Ibb2fe558f98190f2a06da830e0fadfa25516f547

10 years agoMerge "threadpool, res_pjsip: Add serializer group shutdown API calls." into 13
Matt Jordan [Fri, 26 Jun 2015 18:35:07 +0000 (13:35 -0500)] 
Merge "threadpool, res_pjsip: Add serializer group shutdown API calls." into 13

10 years agoMerge "res_pjsip_outbound_registration.c: Fix handle_client_state_destruction() refs...
Matt Jordan [Fri, 26 Jun 2015 18:35:01 +0000 (13:35 -0500)] 
Merge "res_pjsip_outbound_registration.c: Fix handle_client_state_destruction() refs" into 13

10 years agoMerge "res_pjsip_outbound_registration.c: Use ast_sorcery_object_unregister() API...
Matt Jordan [Fri, 26 Jun 2015 18:34:38 +0000 (13:34 -0500)] 
Merge "res_pjsip_outbound_registration.c: Use ast_sorcery_object_unregister() API" into 13

10 years agoMerge "res_pjsip_refer: Prevent sending duplicate headers." into 13
Matt Jordan [Fri, 26 Jun 2015 16:27:00 +0000 (11:27 -0500)] 
Merge "res_pjsip_refer: Prevent sending duplicate headers." into 13

10 years agoMerge "sorcery: Add ast_sorcery_object_unregister() API call." into 13
Matt Jordan [Fri, 26 Jun 2015 16:26:06 +0000 (11:26 -0500)] 
Merge "sorcery: Add ast_sorcery_object_unregister() API call." into 13

10 years agoMerge "res_pjsip_outbound_registration.c: Reorder load_module() and unload_module...
Matt Jordan [Fri, 26 Jun 2015 16:25:38 +0000 (11:25 -0500)] 
Merge "res_pjsip_outbound_registration.c: Reorder load_module() and unload_module()." into 13

10 years agores_pjsip_refer: Prevent sending duplicate headers. 30/730/1
Mark Michelson [Fri, 26 Jun 2015 15:41:05 +0000 (10:41 -0500)] 
res_pjsip_refer: Prevent sending duplicate headers.

res_pjsip_refer will attempt to add Referred-By or Replaces headers to
outbound INVITEs at times. If the INVITE gets challenged for
authentication, then we will resend the INVITE. Prior to this patch, the
Referred-By or Replaces header would be re-added to the outbound INVITE,
resulting in duplicated headers.

ASTERISK-25204 #close
Reported by Mark Michelson

Change-Id: I59fb5c08b4d253c0dba9ee3d3950b5025358222d

10 years agoMerge "AMI: Add Linkedid to the standard channel snapshot AMI event headers." into 13
Matt Jordan [Fri, 26 Jun 2015 15:59:04 +0000 (10:59 -0500)] 
Merge "AMI: Add Linkedid to the standard channel snapshot AMI event headers." into 13

10 years agores_pjsip_nat: Rewrite route set when required. 23/723/2
Mark Michelson [Tue, 23 Jun 2015 22:43:31 +0000 (17:43 -0500)] 
res_pjsip_nat: Rewrite route set when required.

When performing some provider testing, the rewrite_contact option was
interfering with proper construction of a route set when sending an ACK
after receiving a 200 OK response to an INVITE.

The initial INVITE was sent to address sip:foo. The 200 OK had a Contact
header with URI sip:bar. In addition, the 200 OK had Record-Route
headers for sip:baz and sip:foo, in that order. Since the Record-Route
headers had the lr parameter, the result should have been:

* Set R-URI of the ACK to sip:bar.
* Add Route headers for sip:foo and sip:baz, in that order.

However, the rewrite_contact option resulted in our rewriting the
Contact header on the 200 OK to sip:foo. The result was:

* R-URI remained sip:foo.
* We added Route headers for sip:foo and sip:baz, in that order.

The result was that sip:bar was not indicated in the ACK at all, so the
far end never received our ACK. The call eventually dropped.

The intention of rewrite_contact is to rewrite the most immediate
destination of our SIP request to be the same address on which we
received a request or response. In the case of processing a SIP response
with Record-Route headers, this means that instead of rewriting the
Contact header, we should instead rewrite the bottom-most Record-Route
header. In the case of processing a SIP request with Record-Route
headers, this means we rewrite the top-most Record-route header.
Like when we rewrite the Contact header, we also ensure to update
the dialog's route set if it exists.

ASTERISK-25196 #close
Reported by Mark Michelson

Change-Id: I9702157c3603a2d0bd8a8215ac27564d366b666f

10 years agothreadpool, res_pjsip: Add serializer group shutdown API calls. 90/690/3
Richard Mudgett [Fri, 19 Jun 2015 21:16:17 +0000 (16:16 -0500)] 
threadpool, res_pjsip: Add serializer group shutdown API calls.

A module trying to unload needs to wait for all serializers it creates and
uses to complete processing before unloading.

ASTERISK-24907
Reported by: Kevin Harwell

Change-Id: I8c80b90f2f82754e8dbb02ddf3c9121e5e966059

10 years agores_pjsip_outbound_registration.c: Fix handle_client_state_destruction() refs 89/689/3
Richard Mudgett [Tue, 16 Jun 2015 20:06:22 +0000 (15:06 -0500)] 
res_pjsip_outbound_registration.c: Fix handle_client_state_destruction() refs

* handle_client_state_destruction() must always be passed a ref to
client_state because it will always unref client_state.
handle_registration_response() was not passing a client_state ref.

* Made the final un-REGISTER message get sent normally using the pjproject
register control structure in handle_client_state_destruction().  The
previous code attempted to short circuit the response handling for the
module to unload.  That doesn't work for a couple reasons.  One,
pjsip_regc_send() may call the registered callback before it returns and
unbalance the client_state ref count.  Two, the registered callback
handles any authentication for the un-REGISTER message.

* Made the distinction between internal registration state and external
registration status with sip_outbound_registration_status_str().  This is
necessary to avoid altering documented AMI messages with internal
changes.

* Removed references to client_state->client outside of the serializer
thread.  When handle_client_state_destruction() destroys the pjproject
register control structure that memory is freed and cannot be referenced
anymore.  These accesses were to provide information for debug and
off-nominal warning messages.

* In sip_outbound_registration_timer_cb() you should not access entry->id
after unrefing client_state because the passed in entry is normally
pointing to the timer entry in the client_state object.

ASTERISK-24907
Reported by: Kevin Harwell

Change-Id: Ia7b446d8644b6b4550ef5bea49527671de65183f

10 years agores_pjsip_outbound_registration.c: Use ast_sorcery_object_unregister() API 88/688/3
Richard Mudgett [Mon, 15 Jun 2015 20:28:41 +0000 (15:28 -0500)] 
res_pjsip_outbound_registration.c: Use ast_sorcery_object_unregister() API

The sorcery pjsip 'registration' config object needs to be destroyed on
module unload.  Otherwise, a reload of res_pjsip could try to use
callbacks for a previously unloaded instance of the module provided by
ast_sorcery_object_register() or one of the variants.  Also, if
res_pjsip_outbound_registration were subsequently reloaded, the sorcery
config field objects would be registered in sorcery twice.

ASTERISK-24907
Reported by: Kevin Harwell

Change-Id: I304fad13dece2604af48353f6c6d9d5c7b064697

10 years agochannel: Remove ignore of answer on non-outgoing channels. 25/725/1
Joshua Colp [Thu, 25 Jun 2015 11:42:46 +0000 (08:42 -0300)] 
channel: Remove ignore of answer on non-outgoing channels.

Due to the way that channels can now be moved around inside of
Asterisk it is possible for the outgoing flag of a channel to get
cleared before it has been answered. This results in the bridge
not receiving notification that the outgoing leg has been answered.

This most easily exhibits itself with DTMF based blond transfers.
Since the answer of the outgoing leg is ignored the other party
continues to receive both a locally generated ringing and the
media stream of the outgoing leg upon its answer. This results
in no media being heard.

This change removes the ignore of the answer and allows it
to pass through.

ASTERISK-25171 #close

Change-Id: I82aedcec4f89f34a2e5472086dfc9a6c775bca8e

10 years agosorcery: Add ast_sorcery_object_unregister() API call. 87/687/3
Richard Mudgett [Mon, 15 Jun 2015 20:28:00 +0000 (15:28 -0500)] 
sorcery: Add ast_sorcery_object_unregister() API call.

Find and unlink the specified sorcery object type to complement
ast_sorcery_object_register().  Without this function you cannot
completely unload individual modules that use sorcery for configuration.

ASTERISK-24907
Reported by: Kevin Harwell

Change-Id: I1c04634fe9a90921bf676725c7d6bb2aeaab1c88

10 years agores_pjsip_outbound_registration.c: Reorder load_module() and unload_module(). 86/686/3
Richard Mudgett [Mon, 15 Jun 2015 18:38:58 +0000 (13:38 -0500)] 
res_pjsip_outbound_registration.c: Reorder load_module() and unload_module().

It is best if the loading code creates and initializes the module's
infrastructure before letting the system know of its existence.  The
unloading code needs to reverse the actions of the loading code and in the
reverse order.

ASTERISK-24907
Reported by: Kevin Harwell

Change-Id: I5d151383e9787b5b60aa5e1627b10f040acdded4

10 years agoAMI: Add Linkedid to the standard channel snapshot AMI event headers. 00/700/2
Richard Mudgett [Tue, 23 Jun 2015 19:34:29 +0000 (14:34 -0500)] 
AMI: Add Linkedid to the standard channel snapshot AMI event headers.

* The AMI version is bumped to 2.8.0.

ASTERISK-25189 #close
Reported by: John Hardin

Change-Id: I2b1778c3fdc1dca0ed55db4e3a639eddfb16c2ac

10 years agoMerge "res_pjsip_mwi: Set up unsolicited MWI upon registration." into 13
Mark Michelson [Thu, 25 Jun 2015 14:52:04 +0000 (09:52 -0500)] 
Merge "res_pjsip_mwi: Set up unsolicited MWI upon registration." into 13

10 years agoMerge "test.c: Add unit test registration checks for summary and description." into 13
Joshua Colp [Thu, 25 Jun 2015 09:51:37 +0000 (04:51 -0500)] 
Merge "test.c: Add unit test registration checks for summary and description." into 13

10 years agoMerge "Unit tests: Fix unit test description strings." into 13
Joshua Colp [Thu, 25 Jun 2015 09:50:22 +0000 (04:50 -0500)] 
Merge "Unit tests: Fix unit test description strings." into 13

10 years agotest.c: Add unit test registration checks for summary and description. 15/715/1
Richard Mudgett [Wed, 24 Jun 2015 19:30:15 +0000 (14:30 -0500)] 
test.c: Add unit test registration checks for summary and description.

Added checks when a unit test is registered to see that the summary and
description strings do not end with a new-line '\n' for consistency.

The check generates a warning message and will cause the
/main/test/registrations unit test to fail.

* Updated struct ast_test_info member doxygen comments.

Change-Id: I295909b6bc013ed9b6882e85c05287082497534d

10 years agoUnit tests: Fix unit test description strings. 14/714/1
Richard Mudgett [Wed, 24 Jun 2015 19:39:01 +0000 (14:39 -0500)] 
Unit tests: Fix unit test description strings.

Analyzing the code shows that the unit test summary and description
strings should not end with a new-line character.  Where these strings are
used in the code a new-line is provided for output.

Change-Id: I129284f5e7ca93d82532334076da4c462d3d9fba

10 years agoMerge "app_dial: Hold reference to calling channel formats when dialing outbound...
Matt Jordan [Wed, 24 Jun 2015 22:07:00 +0000 (17:07 -0500)] 
Merge "app_dial: Hold reference to calling channel formats when dialing outbound." into 13

10 years agoapp_dial: Hold reference to calling channel formats when dialing outbound. 02/702/2
Joshua Colp [Tue, 23 Jun 2015 16:21:41 +0000 (13:21 -0300)] 
app_dial: Hold reference to calling channel formats when dialing outbound.

Currently when requesting a channel the native formats of the
calling channel are provided to the core for usage when dialing
the outbound channel. This occurs without holding the channel lock
or keeping a reference to the formats. This is problematic as
the channel driver may end up changing the formats during this time.
In the case of chan_sip this happens when an SDP negotiation
completes.

This change makes it so app_dial keeps a reference to the native
formats of the calling channel which guarantees that they will
remain valid for the period of time needed.

ASTERISK-25172 #close

Change-Id: I2f0a67bd0d5d14c3bdbaae552b4b1613a283f0db