]> git.ipfire.org Git - thirdparty/asterisk.git/log
thirdparty/asterisk.git
8 years agotest_config: Fix failure and segfault when config_hook is run twice.
Corey Farrell [Mon, 23 Oct 2017 17:42:37 +0000 (13:42 -0400)] 
test_config: Fix failure and segfault when config_hook is run twice.

On second run the config_hook test was unexpectedly failing to load
test_config.conf because it was still unmodified since the last load.
This is fixed by not passing CONFIG_FLAG_FILEUNCHANGED for the initial
loads, only using it when we are tested that a reload of unmodified
files do not initiate the hook.

ASTERISK-25960

Change-Id: Ifd679509a23ed163e5cc647490bf7df4ae3cd856

8 years agoMerge "bridge_softmix: Reduce topology cloning and improve renegotiation." into 15
Joshua Colp [Mon, 23 Oct 2017 15:23:03 +0000 (10:23 -0500)] 
Merge "bridge_softmix: Reduce topology cloning and improve renegotiation." into 15

8 years agoapp_agent_pool.c: Fix online documentation typo.
Richard Mudgett [Mon, 23 Oct 2017 12:53:48 +0000 (07:53 -0500)] 
app_agent_pool.c: Fix online documentation typo.

Change-Id: Ib0bc95fd0ec288c78c313823254d7a84ebfc4429

8 years agores_pjsip_pubsub: Prevent unload except during shutdown.
Corey Farrell [Wed, 18 Oct 2017 18:41:25 +0000 (14:41 -0400)] 
res_pjsip_pubsub: Prevent unload except during shutdown.

Prevent unload of the module as certain pjsip initialization functions
cannot be reversed.  This required a reorder of the module_load so that
the non-reversable pjsip functions are not called until all potential
errors have been ruled out.

ASTERISK-24483

Change-Id: Iee900f20bdd6ee1bfe23efdec0d87765eadce8a7

8 years agoMerge "chan_sip: Fix output of 'sip set debug off'." into 15
Jenkins2 [Thu, 19 Oct 2017 13:00:37 +0000 (08:00 -0500)] 
Merge "chan_sip: Fix output of 'sip set debug off'." into 15

8 years agores_pjsip_refer: Prevent unload except during shutdown.
Corey Farrell [Wed, 18 Oct 2017 18:37:57 +0000 (14:37 -0400)] 
res_pjsip_refer: Prevent unload except during shutdown.

Prevent unload of the module as certain pjsip initialization functions
cannot be reversed.

ASTERISK-24483

Change-Id: I94597ec8b8491f5af9c57bf66dbc3b078fe2d49d

8 years agochan_sip: Fix output of 'sip set debug off'.
Corey Farrell [Wed, 18 Oct 2017 17:04:29 +0000 (13:04 -0400)] 
chan_sip: Fix output of 'sip set debug off'.

When sip.conf contains 'sipdebug=yes' it is impossible to disable it
using CLI 'sip set debug off'.  This corrects the output of that CLI
command to instruct the user to turn sipdebug off in the configuration
file.

ASTERISK-23462 #close

Change-Id: I1cceade9caa9578e1b060feb832e3495ef5ad318

8 years agores_srtp: Add support for libsrtp2 with AES-GCM.
Alexander Traud [Wed, 18 Oct 2017 08:30:25 +0000 (10:30 +0200)] 
res_srtp: Add support for libsrtp2 with AES-GCM.

Beside allowing AES-GCM again, this adds AES-192 again.

ASTERISK-27356

Change-Id: Ia97a435faf26300335d9552fa676b5d17e5f7233

8 years agoMerge "res_corosync: Fix linking issue with Corosync 2.x" into 15
Jenkins2 [Tue, 17 Oct 2017 16:45:10 +0000 (11:45 -0500)] 
Merge "res_corosync: Fix linking issue with Corosync 2.x" into 15

8 years agoMerge "cdr.c: Rename the Party A CDR container." into 15
Joshua Colp [Tue, 17 Oct 2017 16:06:36 +0000 (11:06 -0500)] 
Merge "cdr.c: Rename the Party A CDR container." into 15

8 years agoMerge "cdr.c: Add container to key off of Party B channel names." into 15
Joshua Colp [Tue, 17 Oct 2017 16:05:56 +0000 (11:05 -0500)] 
Merge "cdr.c: Add container to key off of Party B channel names." into 15

8 years agoMerge "contrib/script/sip_to_pjsip: implement 'all' for allow/disallow" into 15
Joshua Colp [Tue, 17 Oct 2017 14:38:52 +0000 (09:38 -0500)] 
Merge "contrib/script/sip_to_pjsip: implement 'all' for allow/disallow" into 15

8 years agoMerge "bridge_simple: Improve renegotiation success rate." into 15
Jenkins2 [Tue, 17 Oct 2017 13:37:25 +0000 (08:37 -0500)] 
Merge "bridge_simple: Improve renegotiation success rate." into 15

8 years agoMerge "chan_dahdi: wrap include file which is not present on BSD systems in #ifdef...
Joshua Colp [Tue, 17 Oct 2017 13:16:08 +0000 (08:16 -0500)] 
Merge "chan_dahdi: wrap include file which is not present on BSD systems in #ifdef" into 15

8 years agores_corosync: Fix linking issue with Corosync 2.x
Matt Jordan [Fri, 6 Oct 2017 15:51:17 +0000 (10:51 -0500)] 
res_corosync: Fix linking issue with Corosync 2.x

At some point in time in the history of Corosync (certainly within the
2.x branch), the corosync_cfg_state_track function was removed.
Unfortunately, the cfg library is only linked if this function is
present. Without the cfg library being linked to res_corosync, loading
of res_corosync will fail.

This patch makes it so that detecting corosync's core libraries,
determined by the COROSYNC external library checks, links both the cpg
and cfg libraries with res_corosync.

Change-Id: I674e9e1c8fea11c3bf81154aaa7c1fd43f945465

8 years agoMerge "res_pjsip_session: Rewrite o= with external_media_address." into 15
Jenkins2 [Tue, 17 Oct 2017 11:30:19 +0000 (06:30 -0500)] 
Merge "res_pjsip_session: Rewrite o= with external_media_address." into 15

8 years agobridge_softmix: Reduce topology cloning and improve renegotiation.
Joshua Colp [Sat, 14 Oct 2017 19:41:37 +0000 (19:41 +0000)] 
bridge_softmix: Reduce topology cloning and improve renegotiation.

As channels join and leave an SFU the bridge_softmix module
needs to renegotiate to add and remove their streams from
the other participants. Previously this was done by constructing
the ideal stream topology every time but in the case of leave
this was incomplete.

This change makes it so bridge_softmix keeps an ideal stream
topology for each channel and uses it when making changes. This
ensures that when we request a renegotiation we are always
certain that we are aiming for the best stream topology
possible. In the case of a channel leaving this ensures that
we try to have an existing participant fill their place if
a participant has a fixed limit on the maximum number of video
streams they allow.

ASTERISK-27354

Change-Id: I58070f421ddeadd2844a33b869b052630cf2e514

8 years agocdr.c: Rename the Party A CDR container.
Richard Mudgett [Fri, 6 Oct 2017 20:55:26 +0000 (15:55 -0500)] 
cdr.c: Rename the Party A CDR container.

* Rename the Party A CDR container from active_cdrs_by_channel to
active_cdrs_master.

* Renamed the support functions associated with active_cdrs_master
appropriately.

ASTERISK-27335

Change-Id: I6104bb3edc3a0b7243ce502e45e8832b0cff14f7

8 years agocdr.c: Add container to key off of Party B channel names.
Richard Mudgett [Mon, 2 Oct 2017 22:42:48 +0000 (17:42 -0500)] 
cdr.c: Add container to key off of Party B channel names.

The CDR performance gets worse the further it gets behind in processing
stasis messages.  One of the reasons is because of a n*m loop used when
processing Party B information.

* Added a new CDR container that is keyed to Party B so we don't need such
a large loop when processing Party B information.

NOTE: To reduce the size of the patch I deferred to another patch the
renaming of the Party A active_cdrs_by_channel container to
active_cdrs_master and renaming the container's hash and cmp functions
appropriately.

ASTERISK-27335

Change-Id: I0bf66e8868f8adaa4b5dcf9e682e34951c350249

8 years agocontrib/script/sip_to_pjsip: implement 'all' for allow/disallow
Torrey Searle [Wed, 11 Oct 2017 11:04:12 +0000 (13:04 +0200)] 
contrib/script/sip_to_pjsip: implement 'all' for allow/disallow

when 'all' is specified in an allow or disallow section, it should erase
all values from the inverse section in the default config. E.G.
allow=all should erase any deny values from default config &
vice-versa

ASTERISK-27333 #close

Change-Id: I99219478fb98f08751d769daaee0b7795118a5a6

8 years agodeclare optional openssl dependencies in moduleinfo
Tzafrir Cohen [Tue, 10 Oct 2017 12:42:46 +0000 (15:42 +0300)] 
declare optional openssl dependencies in moduleinfo

Declare optional openssl dependencies in:
* res_rtp_asterisk.c
* tcptls.c

ASTERISK-27328 #close

Change-Id: I2636f1c05b8104b4fe6f36cce0ebd9a98b9c78ab

8 years agoMerge "cdr.c: Eliminated many calls to ao2_global_obj_ref()." into 15
Joshua Colp [Mon, 16 Oct 2017 10:44:27 +0000 (05:44 -0500)] 
Merge "cdr.c: Eliminated many calls to ao2_global_obj_ref()." into 15

8 years agoMerge "ast_bt_get_symbols: Prevent double-free." into 15
Joshua Colp [Sun, 15 Oct 2017 19:42:11 +0000 (14:42 -0500)] 
Merge "ast_bt_get_symbols: Prevent double-free." into 15

8 years agoMerge "tcptls: NULL-check the parameter of ast_ssl_teardown before accessing it....
Joshua Colp [Sun, 15 Oct 2017 19:10:32 +0000 (14:10 -0500)] 
Merge "tcptls: NULL-check the parameter of ast_ssl_teardown before accessing it." into 15

8 years agochan_dahdi: wrap include file which is not present on BSD systems in #ifdef
Guido Falsi [Sat, 14 Oct 2017 09:11:24 +0000 (11:11 +0200)] 
chan_dahdi: wrap include file which is not present on BSD systems in #ifdef

The sys/sysmacros.h include file does not exist in BSD systems and
is not required to build this module there.
Since an "#if defined(__NetBSD__) || defined(__FreeBSD__)" section
already exist I moved that include line inside it's #else branch.

ASTERISK-27343 #close

Change-Id: Ibfb64f4e9a0ce8b6eda7a7695cfe57916f175dc1

8 years agores_pjsip_session: Rewrite o= with external_media_address.
Alexander Traud [Fri, 13 Oct 2017 14:43:12 +0000 (16:43 +0200)] 
res_pjsip_session: Rewrite o= with external_media_address.

PJSIP allows a domain name as external_media_address. This allows chan_pjsip to
be used behind a NAT with changing IP addresses. The IP address of that domain
is resolved to the c= line already. This change sets also the o= line to that
domain.

ASTERISK-27341 #close

Change-Id: I690163b6e762042ec38b3995aa5c9bea909d8ec4

8 years agoMerge "cdr.c: Defer getting ao2_global_obj_ref() until needed." into 15
Jenkins2 [Fri, 13 Oct 2017 23:13:38 +0000 (18:13 -0500)] 
Merge "cdr.c: Defer getting ao2_global_obj_ref() until needed." into 15

8 years agoMerge "cdr.c: Set stringfields only if they are different." into 15
Jenkins2 [Fri, 13 Oct 2017 22:29:57 +0000 (17:29 -0500)] 
Merge "cdr.c: Set stringfields only if they are different." into 15

8 years agobridge_simple: Improve renegotiation success rate.
Joshua Colp [Thu, 12 Oct 2017 17:03:45 +0000 (17:03 +0000)] 
bridge_simple: Improve renegotiation success rate.

When making channels compatible the bridge_simple module
will renegotiate one to better match the other. Some
endpoints incorrectly terminate the call if this process
fails.

To better handle this scenario the audio streams present
on the new requested topology will include any existing
negotiated formats that happen to exist on the first
valid audio stream. This ensures formats are persent that
are known to be acceptable to the remote endpoint.

ASTERISK-27259

Change-Id: I8fc0cc03e8bcfd0be8302f13b9f32d8268977f43

8 years agoMerge "cdr.c: Fix setting dnid, callingsubaddr, and calledsubaddr" into 15
Jenkins2 [Fri, 13 Oct 2017 21:57:00 +0000 (16:57 -0500)] 
Merge "cdr.c: Fix setting dnid, callingsubaddr, and calledsubaddr" into 15

8 years agoAMI: Increase version number
Kevin Harwell [Fri, 13 Oct 2017 17:12:34 +0000 (12:12 -0500)] 
AMI: Increase version number

Bump the AMI patch number since the following new addition was made:

* Added a new CancelAtxfer action that cancels an attended transfer.

Change-Id: I9bac528791bd62ef0e99243903b6bc7a6c7ab182

8 years agoast_bt_get_symbols: Prevent double-free.
Corey Farrell [Fri, 13 Oct 2017 13:51:09 +0000 (09:51 -0400)] 
ast_bt_get_symbols: Prevent double-free.

It's possible for bfdobj to be created but syms not created.  If syms
was not allocated in the current loop iteration but was allocated in the
previous iteration it would crash.

ASTERISK-27340

Change-Id: I5b110c609f6dfe91339f782a99a431bca5837363

8 years agotcptls: NULL-check the parameter of ast_ssl_teardown before accessing it.
Alexander Traud [Fri, 13 Oct 2017 13:12:07 +0000 (15:12 +0200)] 
tcptls: NULL-check the parameter of ast_ssl_teardown before accessing it.

This avoids a crash on stopping a chan_sip which failed to start its TLS server.

ASTERISK-27339 #close

Change-Id: I327fc70db68eaaca5b50a15c7fd687fde79263d5

8 years agoMerge "features, manager : Add CancelAtxfer AMI action" into 15
Joshua Colp [Fri, 13 Oct 2017 12:53:29 +0000 (07:53 -0500)] 
Merge "features, manager : Add CancelAtxfer AMI action" into 15

8 years agocdr.c: Eliminated many calls to ao2_global_obj_ref().
Richard Mudgett [Fri, 29 Sep 2017 19:26:41 +0000 (14:26 -0500)] 
cdr.c: Eliminated many calls to ao2_global_obj_ref().

The CDR performance gets worse the further it gets behind in processing
stasis messages.  One of the reasons is we were getting the global config
to determine if we needed to log a debugging message.

* Many calls to ao2_global_obj_ref() were just so we could determine if
debug mode is enabled.  Made a global flag to check instead.

* Eliminated many RAII_VAR() usages associated with the remaining
ao2_global_obj_ref() calls.

* Added missing NULL checks for the returned ao2_global_obj_ref() value.

ASTERISK-27335

Change-Id: Iceaad93172862f610cad0188956634187bfcc7cd

8 years agocdr.c: Defer getting ao2_global_obj_ref() until needed.
Richard Mudgett [Fri, 6 Oct 2017 18:45:30 +0000 (13:45 -0500)] 
cdr.c: Defer getting ao2_global_obj_ref() until needed.

The CDR performance gets worse the further it gets behind in processing
stasis messages.  One of the reasons is we were getting the global config
even if we didn't need it.

* Most uses of the global config were only needed on off nominal code
paths so it makes sense to not get it until absolutely needed.

ASTERISK-27335

Change-Id: I00c63b7ec233e5bfffd5d976f05568613d3c2365

8 years agocdr.c: Set stringfields only if they are different.
Richard Mudgett [Thu, 5 Oct 2017 23:08:33 +0000 (18:08 -0500)] 
cdr.c: Set stringfields only if they are different.

The CDR performance gets worse the further it gets behind in processing
stasis messages.  One of the reasons is we were repeatedly setting string
fields to potentially the same string in base_process_party_a().  Setting
a string field involves allocating room for the new string out of a memory
pool which may have to allocate even more memory.

* Check to see if the string field is already set to the desired string.

ASTERISK-27335

Change-Id: I3ccb7e23f1488417e08cafe477755033eed65a7c

8 years agocdr.c: Fix setting dnid, callingsubaddr, and calledsubaddr
Richard Mudgett [Thu, 5 Oct 2017 23:03:11 +0000 (18:03 -0500)] 
cdr.c: Fix setting dnid, callingsubaddr, and calledsubaddr

The string comparisons for setting these CDR variables was inverted.  We
were repeatedly setting these CDR variables only if the channel snapshots
had the same value.

ASTERISK-27335

Change-Id: I9482073524411e7ea6c03805b16de200cb1669ea

8 years agofeatures, manager : Add CancelAtxfer AMI action
Thomas Sevestre [Fri, 25 Aug 2017 13:19:00 +0000 (13:19 +0000)] 
features, manager : Add CancelAtxfer AMI action

Add action to cancel feature attended transfer with AMI interface

ASTERISK-27215 #close

Change-Id: Iab8a81362b5a1757e2608f70b014ef863200cb42

8 years agores_pjsip_session: Prevent user=phone being added to anonimized URIs.
Daniel Tryba [Fri, 6 Oct 2017 09:55:38 +0000 (11:55 +0200)] 
res_pjsip_session: Prevent user=phone being added to anonimized URIs.

Move ast_sip_add_usereqphone to be called after anonymization of URIs,
to prevent the user_eq_phone adding "user=phone" to URIs containing a
username that is not a phonenumber (RFC3261 19.1.1). An extra call to
ast_sip_add_usereqphone on the saved version before anonymization is
added to add user=phone" to the PAI.

ASTERISK-27047 #close

Change-Id: Ie5644bc66341b86dc08b1f7442210de2e6acdec6

8 years agoMerge "sorcery: Use ao2_weakproxy to hold list of instances." into 15
Jenkins2 [Thu, 12 Oct 2017 15:44:11 +0000 (10:44 -0500)] 
Merge "sorcery: Use ao2_weakproxy to hold list of instances." into 15

8 years agoMerge "named_locks: Use ao2_weakproxy_find." into 15
Jenkins2 [Thu, 12 Oct 2017 15:19:44 +0000 (10:19 -0500)] 
Merge "named_locks: Use ao2_weakproxy_find." into 15

8 years agoMerge "astobj2: Add ao2_weakproxy_find function." into 15
Joshua Colp [Thu, 12 Oct 2017 14:37:40 +0000 (09:37 -0500)] 
Merge "astobj2: Add ao2_weakproxy_find function." into 15

8 years agoMerge "astobj2: Run weakproxy callbacks outside of lock." into 15
Jenkins2 [Thu, 12 Oct 2017 14:04:39 +0000 (09:04 -0500)] 
Merge "astobj2: Run weakproxy callbacks outside of lock." into 15

8 years agoMerge "cdr.c: Defer misc checks." into 15
Jenkins2 [Thu, 12 Oct 2017 13:02:29 +0000 (08:02 -0500)] 
Merge "cdr.c: Defer misc checks." into 15

8 years agoMerge "res_pjsip: Prevent "user=phone" being added multiple times to header" into 15
Jenkins2 [Thu, 12 Oct 2017 12:04:00 +0000 (07:04 -0500)] 
Merge "res_pjsip: Prevent "user=phone" being added multiple times to header" into 15

8 years agoMerge "cdr_mysql: avoid releasing a config string" into 15
Jenkins2 [Thu, 12 Oct 2017 00:45:43 +0000 (19:45 -0500)] 
Merge "cdr_mysql: avoid releasing a config string" into 15

8 years agoMerge "chan_vpb: Fix a gcc 7 out-of-bounds complaint" into 15
Joshua Colp [Wed, 11 Oct 2017 21:38:51 +0000 (16:38 -0500)] 
Merge "chan_vpb:  Fix a gcc 7 out-of-bounds complaint" into 15

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

8 years agores_pjsip: Prevent "user=phone" being added multiple times to header
Daniel Tryba [Fri, 6 Oct 2017 10:14:40 +0000 (12:14 +0200)] 
res_pjsip: Prevent "user=phone" being added multiple times to header

ast_sip_add_usereqphone adds "user=phone" to the header every time is is
called without checking whether the param already exists. Preventing
this by searching to string representation of header for "user=phone".

ASTERISK-26988 #close

Change-Id: Ib84383b07254de357dc6a98d91fc1d2c2c3719e6

8 years agocdr_mysql: avoid releasing a config string
Tzafrir Cohen [Tue, 10 Oct 2017 14:49:15 +0000 (17:49 +0300)] 
cdr_mysql: avoid releasing a config string

Fixes a memory corruption issue after a reload of cdr_mysql.

Issue was accidentally included in 747beb1ed159f89a3b58742e4257740b3d6d6bba .

ASTERISK-27270 #close

Change-Id: I90b6a9d18710c0f9009466370bd5f4bac5d5d12e

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

8 years agocdr.c: Defer misc checks.
Richard Mudgett [Thu, 5 Oct 2017 23:12:04 +0000 (18:12 -0500)] 
cdr.c: Defer misc checks.

Try to defer some checks until needed in case there is an early exit.

Change-Id: Ibc6b34c38a4f60ad4f9b67984b7d070a07257064

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

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

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

Change-Id: If9c4bfdb6b02fa72d39e0c09bf88900663c000ba

8 years agosorcery: Use ao2_weakproxy to hold list of instances.
Corey Farrell [Tue, 10 Oct 2017 02:00:45 +0000 (22:00 -0400)] 
sorcery: Use ao2_weakproxy to hold list of instances.

Store weak proxy objects in instances container.

Change-Id: I5a150a4e13cee319d46b5a4654f95a4623a978f8

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

8 years agonamed_locks: Use ao2_weakproxy_find.
Corey Farrell [Tue, 10 Oct 2017 02:55:44 +0000 (22:55 -0400)] 
named_locks: Use ao2_weakproxy_find.

Change-Id: I0ce8a1b7101b6caac6a19f83a89f00eaba1e9d9c

8 years agoastobj2: Add ao2_weakproxy_find function.
Corey Farrell [Mon, 9 Oct 2017 22:51:05 +0000 (18:51 -0400)] 
astobj2: Add ao2_weakproxy_find function.

This function finds a weak proxy in an ao2_container and returns the
real object associated with it.

Change-Id: I9da822049747275f5961b5c0a7f14e87157d65d8

8 years agoastobj2: Run weakproxy callbacks outside of lock.
Corey Farrell [Tue, 10 Oct 2017 20:09:14 +0000 (16:09 -0400)] 
astobj2: Run weakproxy callbacks outside of lock.

Copy the list of weakproxy callbacks to temporary memory so they can be
run without holding the weakproxy lock.

Change-Id: Ib167622a8a0f873fd73938f7611b2a5914308047

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

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

ASTERISK-25266 #close
Reported by: Allen Ford

Change-Id: Idf16237b7e41b527d2c69c865829128686beeb3b

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

add mappings for udptl redundancy, rtptimeout, and debug flags

Change-Id: Ie73cf5c83c05dee01eb9624ede76c1a30225d73a

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

Change-Id: I150505db307249a962987e7b941bdd369bb91f35

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

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

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

ASTERISK-27306

Change-Id: I3bed0edf3f55b1d4adcbabb25ec14f11dc766c72

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

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

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

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

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

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

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

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

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

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

Change-Id: Ib0c53cdf5048227842846e0df9d2c19117c45618

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

Change-Id: I9f424f5282ca7d833592f958d95f1b2bafb549b0

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

Change-Id: Ib59d7d2f2a4a822754628f2c48a308d6791a6e6e

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

* Also some misc formatting in cdr.c.

Change-Id: Ied89a28802a662c37c43326a1aafdce596e0df4a

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

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

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

ASTERISK-27192

Change-Id: I64c107a10b70db1697d17136051ae6bf22b5314b

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

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

Change-Id: I65a5190b2732b2246d67472db70dd37db64ddad4

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

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

Change-Id: Ife3e289062e6cf7d0e7d342dbf79ed96feff441e

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

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

ASTERISK-27324 #close

Change-Id: I4b242837bdeb1ec7130dc82505c6180a946fd9b5

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

ASTERISK-27306

Change-Id: I2c8d3fc148f9f53715c958314e1146f9611741f3

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

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

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

ASTERISK-27306

Change-Id: I59bbfc8da8a14d5f4af8c5bb1e71f8592ae823eb

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

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

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

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

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

ASTERISK-27317 #close

Change-Id: Ib960d7f5576f9e1a3c478ecb48995582a574e06d

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

ASTERISK-27306

Change-Id: Ib3ed47167cb697ab7bd0a56cab589893f491651b

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

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

ASTERISK-27306

Change-Id: I3fcf103b3680ad2d1d4610dcd6738eeaebf4d202

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

ASTERISK-27301 #close

Change-Id: Ic31361f34e2de3b6470e68fc37205a7711082eba

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

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

ASTERISK-27318 #close

Change-Id: Ifcece92605f58116eff24c5a0a3b0ee08b3c87b1

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

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

ASTERISK-27284 #close

Change-Id: If438a21f31a962da32d7a33ff33bdeb1e776fe56

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

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

ASTERISK-27306

Change-Id: Ifbd5c19ec848010111afeab2436f9699da06ba6b

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

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

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

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

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

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

The event which can invalidate this occurence needs to have:

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

If one component is found, just clean and return.

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

Change-Id: I8587ae3eaa765af7cb21eda3b6bf84e8a1c87af8

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

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

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

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

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

ASTERISK-27216

Change-Id: Ieaeb7dbea8ae7073086b775fbafe0625b000b10a