]> git.ipfire.org Git - thirdparty/asterisk.git/log
thirdparty/asterisk.git
6 years agodoc: Add "master-only" flag back to the CHANGES and UPGRADE files
George Joseph [Mon, 29 Jul 2019 16:10:28 +0000 (10:10 -0600)] 
doc:  Add "master-only" flag back to the CHANGES and UPGRADE files

In order to run the documentation scripts the flags needs to be
added back to the staging files.

Change-Id: Ia10a153c50c970cfa1e85815208dfaddb3f2ccd4

6 years agoPrepare Asterisk 17 Branch
George Joseph [Fri, 26 Jul 2019 18:06:57 +0000 (12:06 -0600)] 
Prepare Asterisk 17 Branch

Change-Id: Idb79a69646d2511e7bf1573b9b0322cc22ea54e8

6 years agoMerge "contrib/scripts: Make spandspflow2pcap.py Python 2.7+/3.3+ compatible"
George Joseph [Fri, 26 Jul 2019 17:03:04 +0000 (12:03 -0500)] 
Merge "contrib/scripts: Make spandspflow2pcap.py Python 2.7+/3.3+ compatible"

6 years agoMerge "CI: Don't enable non-core modules in Certified branches"
George Joseph [Fri, 26 Jul 2019 14:47:18 +0000 (09:47 -0500)] 
Merge "CI:  Don't enable non-core modules in Certified branches"

6 years agoCI: Don't enable non-core modules in Certified branches
George Joseph [Wed, 24 Jul 2019 20:15:27 +0000 (14:15 -0600)] 
CI:  Don't enable non-core modules in Certified branches

We don't support non-core modules for Certified releases but we
were enabling them for CI builds which was causing lots of test
failures.  Now we don't.

Change-Id: I0b3254c08a2479f3d39151690350cce5ce5ad766

6 years agores_config_sqlite3: Only join threads that we started
Sean Bright [Tue, 23 Jul 2019 17:58:31 +0000 (13:58 -0400)] 
res_config_sqlite3: Only join threads that we started

ASTERISK-28477 #close
Reported by: Dennis

ASTERISK-28478 #close
Reported by: Dennis

Change-Id: I77347ad46a86dc5b35ed68270cee56acefb4f475

6 years agoMerge "openr2(6/6): Set hangup cause"
Friendly Automation [Wed, 24 Jul 2019 00:32:57 +0000 (19:32 -0500)] 
Merge "openr2(6/6): Set hangup cause"

6 years agoMerge "openr2(5/6): added cli command -- mfcr2 destroy link <index>"
George Joseph [Tue, 23 Jul 2019 23:43:00 +0000 (18:43 -0500)] 
Merge "openr2(5/6): added cli command -- mfcr2 destroy link <index>"

6 years agoMerge "openr2(4/6): added new cli command -- mfcr2 show links"
George Joseph [Tue, 23 Jul 2019 22:28:59 +0000 (17:28 -0500)] 
Merge "openr2(4/6): added new cli command -- mfcr2 show links"

6 years agoMerge "openr2(3/6): Convert r2links to standard Asterisk AST_LIST*"
Friendly Automation [Tue, 23 Jul 2019 20:26:30 +0000 (15:26 -0500)] 
Merge "openr2(3/6): Convert r2links to standard Asterisk AST_LIST*"

6 years agoMerge "openr2(2/6): Stop polling channels when DAHDI returns -ENODEV (e.g: plug-out)"
George Joseph [Tue, 23 Jul 2019 19:26:00 +0000 (14:26 -0500)] 
Merge "openr2(2/6): Stop polling channels when DAHDI returns -ENODEV (e.g: plug-out)"

6 years agoMerge "openr2(1/6): bugfix in configuration saving"
George Joseph [Tue, 23 Jul 2019 18:02:42 +0000 (13:02 -0500)] 
Merge "openr2(1/6): bugfix in configuration saving"

6 years agoMerge "chan_pjsip: Transmit REFER waits for the REFER result setting TRANSFERSTATUS"
George Joseph [Tue, 23 Jul 2019 14:18:42 +0000 (09:18 -0500)] 
Merge "chan_pjsip:  Transmit REFER waits for the REFER result setting TRANSFERSTATUS"

6 years agoopenr2(6/6): Set hangup cause
Leonid Fainshtein [Sun, 12 May 2019 18:29:40 +0000 (21:29 +0300)] 
openr2(6/6): Set hangup cause

Change-Id: I94dc38920e6e77cc73062648f62fdd613d0d1452
Signed-off-by: Oron Peled <oron.peled@xorcom.com>
6 years agoopenr2(5/6): added cli command -- mfcr2 destroy link <index>
Tzafrir Cohen [Mon, 22 Apr 2019 19:14:32 +0000 (22:14 +0300)] 
openr2(5/6): added cli command -- mfcr2 destroy link <index>

Change-Id: I452d6a853bcd8c6e194455b19e5e017713e9c0fe
Signed-off-by: Oron Peled <oron.peled@xorcom.com>
6 years agoopenr2(4/6): added new cli command -- mfcr2 show links
Tzafrir Cohen [Mon, 22 Apr 2019 15:27:23 +0000 (18:27 +0300)] 
openr2(4/6): added new cli command -- mfcr2 show links

* This command show the MFC/R2 links

Change-Id: I213822e1b7ef9c05bd89a2ba62df8e0856ce9f84
Signed-off-by: Oron Peled <oron.peled@xorcom.com>
6 years agoopenr2(3/6): Convert r2links to standard Asterisk AST_LIST*
Tzafrir Cohen [Mon, 22 Apr 2019 12:27:52 +0000 (15:27 +0300)] 
openr2(3/6): Convert r2links to standard Asterisk AST_LIST*

Change-Id: Ibcb2401515a58782a1488c0b9efbed201c3f3a17
Signed-off-by: Oron Peled <oron.peled@xorcom.com>
6 years agoopenr2(2/6): Stop polling channels when DAHDI returns -ENODEV (e.g: plug-out)
Tzafrir Cohen [Mon, 22 Apr 2019 12:33:16 +0000 (15:33 +0300)] 
openr2(2/6): Stop polling channels when DAHDI returns -ENODEV (e.g: plug-out)

Otherwise, OpenR2 threads go crazy and consume almost all CPU resources

Change-Id: I10a41f617613fe7399c5bdced5c64a2751173f28
Signed-off-by: Oron Peled <oron.peled@xorcom.com>
6 years agoopenr2(1/6): bugfix in configuration saving
Tzafrir Cohen [Mon, 22 Apr 2019 15:02:23 +0000 (18:02 +0300)] 
openr2(1/6): bugfix in configuration saving

Details:
  - The memcpy() call copied part of "dahdi_conf" and not "dahdi_conf.mfcr2"
  - As a result, the memcmp() in dahdi_r2_get_link() always fails
  - This cause dahdi_r2_get_link() to create new link for every channel
    (instead of a new link for every ~30 channels)
  - With the fix, far less links are generated -- so we use far less threads

Change-Id: I7259dd6272f5e46e8a6c7f5bf3e8c2ec01b8c132
Signed-off-by: Oron Peled <oron.peled@xorcom.com>
6 years agocontrib/scripts: Make spandspflow2pcap.py Python 2.7+/3.3+ compatible
Walter Doekes [Mon, 22 Jul 2019 15:43:48 +0000 (17:43 +0200)] 
contrib/scripts: Make spandspflow2pcap.py Python 2.7+/3.3+ compatible

Change-Id: Ica182a891743017ff3cda16de3d95335fffd9a91

6 years agoCI: Add cleanWs to cleanup steps in jenkinsfiles
George Joseph [Fri, 19 Jul 2019 16:20:38 +0000 (10:20 -0600)] 
CI: Add cleanWs to cleanup steps in jenkinsfiles

We're at the point where there are enough Jenkins jobs for
Asterisk branches than even cleaned checkouts of Asterisk
will add up to more disk space than is available on the
in-memory workspace mount.  Since we archive all relevent
artifacts anyway, there's no need to keep the workspace
around after the job finishes, whether it succeeds or fails.

Change-Id: I1cd3b73ebb045a987df0f62526d152a510210c39

6 years agoMerge "CI: Add install-headers to the install make targets"
George Joseph [Fri, 19 Jul 2019 16:04:50 +0000 (11:04 -0500)] 
Merge "CI:  Add install-headers to the install make targets"

6 years agoMerge "README.md: Update year"
George Joseph [Fri, 19 Jul 2019 14:48:27 +0000 (09:48 -0500)] 
Merge "README.md: Update year"

6 years agoMerge "sched: Don't allow ast_sched_del to deadlock ast_sched_runq from same thread"
George Joseph [Fri, 19 Jul 2019 13:46:21 +0000 (08:46 -0500)] 
Merge "sched: Don't allow ast_sched_del to deadlock ast_sched_runq from same thread"

6 years agoCI: Add install-headers to the install make targets
George Joseph [Fri, 19 Jul 2019 13:38:39 +0000 (07:38 -0600)] 
CI:  Add install-headers to the install make targets

The testsuite actually needs the headers installed to run
it's self_test.

Change-Id: Ice41d331131b876ad4a9c056085fe6aac34b32b2

6 years agoMerge "Build: Separate header install/uninstall"
George Joseph [Fri, 19 Jul 2019 12:54:28 +0000 (07:54 -0500)] 
Merge "Build: Separate header install/uninstall"

6 years agoMerge "manager: Log AMI actions"
Joshua Colp [Fri, 19 Jul 2019 12:42:07 +0000 (07:42 -0500)] 
Merge "manager: Log AMI actions"

6 years agosched: Don't allow ast_sched_del to deadlock ast_sched_runq from same thread
Walter Doekes [Wed, 17 Jul 2019 13:06:12 +0000 (15:06 +0200)] 
sched: Don't allow ast_sched_del to deadlock ast_sched_runq from same thread

When fixing ASTERISK~24212, a change was done so a scheduled callback could not
be removed while it was running. The caller of ast_sched_del would have to wait.

However, when the caller of ast_sched_del is the callback itself (however wrong
this might be), this new check would cause a deadlock: it would wait forever
for itself.

This changeset introduces an additional check: if ast_sched_del is called
by the callback itself, it is immediately rejected (along with an ERROR log and
a backtrace). Additionally, the AST_SCHED_DEL_UNREF macro is adjusted so the
after-ast_sched_del-refcall function is only run if ast_sched_del returned
success.

This should fix the following spurious race condition found in chan_sip:
- thread 1: schedule sip_poke_peer_now (using AST_SCHED_REPLACE)
- thread 2: run sip_poke_peer_now
- thread 2: blank out sched-ID (too soon!)
- thread 1: set sched-ID (too late!)
- thread 2: try to delete the currently running sched-ID

After this fix, an ERROR would be logged, but no deadlocks (in do_monitor) nor
excess calls to sip_unref_peer(peer) (causing double frees of rtp_instances and
other madness) should occur.

(Thanks Richard Mudgett for reviewing/improving this "scary" change.)

Note that this change does not fix the observed race condition: unlocked
access to peer->pokeexpire (and potentially other scheduled items in chan_sip),
causing AST_SCHED_DEL_UNREF to look at a changing id. But it will make the
deadlock go away. And in the observed case, it will not have adverse affects
(like memory leaks) because the scheduled item is removed through a different
path.

ASTERISK-28282

Change-Id: Ic26777fa0732725e6ca7010df17af77a012aa856

6 years agoBuild: Separate header install/uninstall
George Joseph [Tue, 16 Jul 2019 12:55:49 +0000 (06:55 -0600)] 
Build: Separate header install/uninstall

Asterisk headers are no longer installed and uninstalled
automatically when performing a "make install" or a
"make uninstall".  To install/uninstall the headers, use
"make install-headers" and "make uninstall-headers".
The headers also continue to be uninstalled when performing a
"make uninstall-all".

Also corrects an issue where /usr/include/asterisk.h was never
being removed at all.

Change-Id: Ia7399f3a0203a4825fc4a9f43b9034dae9a2b643

6 years agomanager: Log AMI actions
Kevin Harwell [Tue, 9 Jul 2019 19:42:51 +0000 (14:42 -0500)] 
manager: Log AMI actions

When manager debugging is turned on, this patch makes it so incoming AMI actions
are now also logged.

Change-Id: I8047524510e7ac97d99482b2448f8e368f29cd47

6 years agores_rtp_asterisk: Move where DTLS MTU variable is defined.
Joshua Colp [Sun, 14 Jul 2019 18:26:41 +0000 (15:26 -0300)] 
res_rtp_asterisk: Move where DTLS MTU variable is defined.

The DTLS MTU variable is not dependent on pjproject and should
not exist in its block.

Change-Id: I7e97d64dc192f2ac81bfe2b72b8229d321c7d026

6 years agoMerge "app_voicemail: Remove dependency on the stasis cache"
Kevin Harwell [Fri, 12 Jul 2019 14:21:15 +0000 (09:21 -0500)] 
Merge "app_voicemail: Remove dependency on the stasis cache"

6 years agoMerge "MWI: Update modules that subscribe to MWI to use new API calls"
Kevin Harwell [Fri, 12 Jul 2019 14:19:18 +0000 (09:19 -0500)] 
Merge "MWI: Update modules that subscribe to MWI to use new API calls"

6 years agoMerge "mwi: Update the MWI core to use stasis_state API"
Kevin Harwell [Fri, 12 Jul 2019 14:18:15 +0000 (09:18 -0500)] 
Merge "mwi: Update the MWI core to use stasis_state API"

6 years agoMerge "stasis_state: Make unsubscribes NULL tolerant"
Kevin Harwell [Fri, 12 Jul 2019 14:17:55 +0000 (09:17 -0500)] 
Merge "stasis_state: Make unsubscribes NULL tolerant"

6 years agoMerge "chan_sip: Handle invalid SDP answer to T.38 re-invite"
Friendly Automation [Thu, 11 Jul 2019 21:35:03 +0000 (16:35 -0500)] 
Merge "chan_sip: Handle invalid SDP answer to T.38 re-invite"

6 years agores_pjsip_messaging: Check for body in in-dialog message
George Joseph [Wed, 12 Jun 2019 18:03:04 +0000 (12:03 -0600)] 
res_pjsip_messaging:  Check for body in in-dialog message

We now check that a body exists and it has a length > 0 before
attempting to process it.

ASTERISK-28447
Reported-by: Gil Richard
Change-Id: Ic469544b22ab848734636588d4c93426cc6f4b1f

6 years agochan_sip: Handle invalid SDP answer to T.38 re-invite
Francesco Castellano [Fri, 28 Jun 2019 16:15:31 +0000 (18:15 +0200)] 
chan_sip: Handle invalid SDP answer to T.38 re-invite

The chan_sip module performs a T.38 re-invite using a single media
stream of udptl, and expects the SDP answer to be the same.

If an SDP answer is received instead that contains an additional
media stream with no joint codec a crash will occur as the code
assumes that at least one joint codec will exist in this
scenario.

This change removes this assumption.

ASTERISK-28465

Change-Id: I8b02845b53344c6babe867a3f0a5231045c7ac87

6 years agoapp_voicemail: Remove dependency on the stasis cache
Kevin Harwell [Wed, 12 Jun 2019 18:49:30 +0000 (13:49 -0500)] 
app_voicemail: Remove dependency on the stasis cache

app_voicemail utilized the stasis cache when polling mailboxes for MWI. This
caused a memory leak (items were not being appropriately removed from the
cache), and subsequent slowdown in system processing. This patch removes the
stasis cache dependency, thus alleviating the memory leak. It does this by
utilizing the new MWI API that better manages state lifetime.

ASTERISK-28443
ASTERISK-27121

Change-Id: Ie89fedaca81ea1fd03d150d9d3a1ef3d53740e46

6 years agoMWI: Update modules that subscribe to MWI to use new API calls
Kevin Harwell [Wed, 12 Jun 2019 18:11:42 +0000 (13:11 -0500)] 
MWI: Update modules that subscribe to MWI to use new API calls

The MWI core recently got some new API calls that make tracking MWI state
lifetime more reliable. This patch updates those modules that subscribe to
specific MWI topics to use the new API. Specifically, these modules now
subscribe to both MWI topics and MWI state.

ASTERISK-28442

Change-Id: I32bef880b647246823dbccdf44a98d384fcabfbd

6 years agomwi: Update the MWI core to use stasis_state API
Kevin Harwell [Tue, 11 Jun 2019 19:12:12 +0000 (14:12 -0500)] 
mwi: Update the MWI core to use stasis_state API

** Note **

This patch is meant to be the minimum needed in order for the MWI core to use
the now underlying stasis_state module. As such it does not completely remove
its reliance on the stasis_cache. Doing so has allowed current consumers to
not have to change, and update those code paths for this patch. When time
allows, subsequent patches can/will be made to those consumers to take advantage
of some of the new MWI API included here. Thus, eventually and ultimately
removing MWI dependency on the stasis_cache.

** End Note **

This patch makes it so the MWI core now takes advantage of the new stasis_state
API. Consumers of MWI should no longer need to depend upon stasis topic pooling,
and the stasis cache directly. Similar functionality and implementation details
have now been pushed into the stasis_state module. However, all MWI state should
be accessed via the MWI API itself.

As such a few new methods, and constructs have been added to the MWI core that
facilitate consumer publishing, subscribing, and iterating over MWI state data.

* ast_mwi_subscriber *

Created via ast_mwi_add_subscriber, a subscriber subscribes to a given mailbox
in order to receive updates about the given mailbox. Adding a subscriber will
create the underlying topic, and associated state data if those do not already
exist for it. The topic, and last known state data is guaranteed to exist for
the lifetime of the subscriber.

* ast_mwi_publisher *

Before publishing to a particular topic a publisher should be created. This can
be achieved by using ast_mwi_add_publisher. Publishing to a mailbox should then
be done using one of the MWI publish functions. This ensures the message is
published to the appropriate topic, and the last known state is maintained.

* ast_mwi_observer *

Add an observer in order to watch for particular MWI module related events. For
instance if a submodule needs to know when a subscription is added to any
mailbox an observer can be added to watch for that.

* other *

Urgent message count is now part of the published MWI state object. Also state
can be iterated over using defined callbacks.

ASTERISK-28442

Change-Id: I93f935f9090cd5ddff6d4bc80ff90703c05cf776

6 years agostasis_state: Make unsubscribes NULL tolerant
Kevin Harwell [Mon, 8 Jul 2019 23:10:07 +0000 (18:10 -0500)] 
stasis_state: Make unsubscribes NULL tolerant

Regular stasis unsubscribes can handle NULL subscription objects. This patch
makes it so stasis state unsubscribes handles NULL's as well.

ASTERISK-28442

Change-Id: Ic3648e8df043a85b77cff085e9ff10356028e479

6 years agoREADME.md: Update year
Rodrigo Ramírez Norambuena [Fri, 5 Jul 2019 00:46:36 +0000 (20:46 -0400)] 
README.md: Update year

Change-Id: I746fb94d112c7d797e206bca0fd1e13fcd26bae3

6 years agoMerge "stasis_state: Add new stasis_state module"
Friendly Automation [Tue, 2 Jul 2019 14:30:35 +0000 (09:30 -0500)] 
Merge "stasis_state: Add new stasis_state module"

6 years agoMerge "chan_dahdi.c: crash in chan_dahdi"
Joshua Colp [Tue, 2 Jul 2019 13:25:41 +0000 (08:25 -0500)] 
Merge "chan_dahdi.c: crash in chan_dahdi"

6 years agochan_dahdi.c: crash in chan_dahdi
Chris-Savinovich [Mon, 1 Jul 2019 21:57:25 +0000 (16:57 -0500)] 
chan_dahdi.c: crash in chan_dahdi

Fixes a crash in chan_dahdi occurring on 32-bit systems. A previous
patch introduced a variable of type unassigned long long which is 64-bits.
Casting it as 'ast_json_int_t' along with JSON type 'I' makes it work
with 32-bit systems.

ASTERISK-28457

Change-Id: I9cef6b5f2d826fc5c93f2f6a1c997c4e3e6c93fe

6 years agores_pjsip_sdp_rtp: Remove unused variable
Kevin Harwell [Mon, 1 Jul 2019 15:49:56 +0000 (10:49 -0500)] 
res_pjsip_sdp_rtp: Remove unused variable

The variable 'endpoint_caps' in function 'set_caps' is not used, so remove.

ASTERISK-28458

Change-Id: Ia8766d05a0738aecb29dd018302c2dafca5cab34

6 years agoMerge "app_voicemail.c: Build all three variants for app_voicemail at the same time"
George Joseph [Mon, 1 Jul 2019 15:20:43 +0000 (10:20 -0500)] 
Merge "app_voicemail.c: Build all three variants for app_voicemail at the same time"

6 years agoMerge "tcptls.c: Add peer hostname and port to some error messages"
George Joseph [Mon, 1 Jul 2019 15:20:11 +0000 (10:20 -0500)] 
Merge "tcptls.c:  Add peer hostname and port to some error messages"

6 years agoMerge "pjproject_bundled: Add peer information to most SSL/TLS errors"
Friendly Automation [Mon, 1 Jul 2019 15:05:26 +0000 (10:05 -0500)] 
Merge "pjproject_bundled:  Add peer information to most SSL/TLS errors"

6 years agostasis_state: Add new stasis_state module
Kevin Harwell [Tue, 11 Jun 2019 17:30:27 +0000 (12:30 -0500)] 
stasis_state: Add new stasis_state module

This new module describes an API that can be thought of as a combination of
stasis topic pools, and caching. Except, hopefully done in a more efficient
and less memory "leaky" manner.

The API defines methods, and data structures for managing, and tracking
published message state through stasis. By adding a subscriber or publisher,
consumers can more easily track the lifetime of the contained state. For
instance, when no more publishers and/or subscribers have need of the topic,
and associated state its data is removed from the managed container.

* stasis_state_manager *

The manager stores and well, manages state data. Each state is an association
of a unique stasis topic, and the last known published stasis message on that
topic. There is only ever one managed state object per topic. For each topic
all messages are forwarded to an "all" topic also maintained by the manager.

* stasis_state_subscriber *

Topic and state can be created, or referenced within the manager by adding a
stasis_state_subscriber. When adding a subscriber if no state currently exists
new managed state is immediately created. If managed state already exists then
a new subscriber is created referencing that state. The managed state is
guaranteed to live throughout the subscriber's lifetime. State is only removed
from the manager when no other entities require it.

* stasis_state_publisher *

Topic and state can be created, or referenced within the manager by also adding
a stasis_state_publisher. When adding a publisher if no state currently exists
new managed state is created. If managed state already exists then a new
publisher is created referencing that state. The managed state is guaranteed to
live throughout the publisher's lifetime. State is only removed from the
manager when no other entities require it.

* stasis_state_observer *

Some modules may wish to watch for, and react to managed state events. By
registering a state observer, and implementing handlers for the desired
callbacks those modules can do so.

* other *

Callbacks also exist that allow consumers to iterate over all, or some of the
managed state.

ASTERISK-28442

Change-Id: I7a4a06685a96e511da9f5bd23f9601642d7bd8e5

6 years agoapp_voicemail.c: Build all three variants for app_voicemail at the same time
Chris-Savinovich [Thu, 27 Jun 2019 18:50:57 +0000 (13:50 -0500)] 
app_voicemail.c: Build all three variants for app_voicemail at the same time

Changes made to apps/Makefile to optionally build all three app_voicemail
variations at the same time: 1) file (default), 2) odbc, and 3) imap.
This functionality was requested by users. modules.conf.sample warns the
user to make sure only one voicemail is loaded at a time.

Change-Id: Iba3cd8ffb4b7e8b1c64a11dd383e1eafcd3ed0e7

6 years agoMerge "pjproject: Update to 2.9 release"
Kevin Harwell [Thu, 27 Jun 2019 21:52:59 +0000 (16:52 -0500)] 
Merge "pjproject: Update to 2.9 release"

6 years agotcptls.c: Add peer hostname and port to some error messages
George Joseph [Thu, 27 Jun 2019 20:04:27 +0000 (14:04 -0600)] 
tcptls.c:  Add peer hostname and port to some error messages

Where possble, hostname and port has been added to error
messages, mostly on the server side.

ASTERISK-26006
Reported by: Oleksandr Natalenko

Change-Id: Iff4f897277bc36ce8c5b493b71d0a4a7b74e62f0

6 years agopjproject_bundled: Add peer information to most SSL/TLS errors
George Joseph [Thu, 27 Jun 2019 17:46:44 +0000 (11:46 -0600)] 
pjproject_bundled:  Add peer information to most SSL/TLS errors

Most SSL/TLS error messages coming from pjproject now have either
the peer address:port or peer hostname, depending on what was
available at the time and code location where the error was
generated.

ASTERISK-28444
Reported by: Bernhard Schmidt

Change-Id: I41770e8a1ea5e96f6e16b236692c4269ce1ba91e

6 years agoMerge "res/ari/resource_channels.c: Added hangup reason code for channels"
Friendly Automation [Thu, 27 Jun 2019 17:03:35 +0000 (12:03 -0500)] 
Merge "res/ari/resource_channels.c: Added hangup reason code for channels"

6 years agoMerge "app_amd: issue with silence suppression fixed"
Kevin Harwell [Thu, 27 Jun 2019 16:33:22 +0000 (11:33 -0500)] 
Merge "app_amd: issue with silence suppression fixed"

6 years agores/ari/resource_channels.c: Added hangup reason code for channels
sungtae kim [Mon, 15 Apr 2019 23:26:46 +0000 (01:26 +0200)] 
res/ari/resource_channels.c: Added hangup reason code for channels

Currently, DELETE /ari/channels/<channelID> supports only few hangup reasons.
It's good enough for simple use, but when it needs to set the detail reason,
it comes challenges.
Added reason_code query parameter for that.

ASTERISK-28385

Change-Id: I1cf1d991ffd759d0591b347445a55f416ddc3ff2

6 years agoMerge "sig_pri: Address gcc9 issues"
George Joseph [Tue, 25 Jun 2019 14:55:17 +0000 (09:55 -0500)] 
Merge "sig_pri:  Address gcc9 issues"

6 years agochan_pjsip: Transmit REFER waits for the REFER result setting TRANSFERSTATUS
Dan Cropp [Tue, 2 Apr 2019 19:42:44 +0000 (14:42 -0500)] 
chan_pjsip:  Transmit REFER waits for the REFER result setting TRANSFERSTATUS

Previously, when a Transfer (REFER) was performed, chan_pjsip would set
the TRANSFERSTATUS to SUCCESS when the REFER was queued up.  This did not
reflect a successful/unsuccessful transfer the way chan_sip did.
Added a callback module to process the refer subscription information.

Now depends on res_pjsip_pubsub so call transfer progress can be monitored
and reported

ASTERISK-26968 #close
Reported-by: Dan Cropp
Change-Id: If6c27c757c66f71e8b75e3fe49da53ebe62395dc

6 years agoMerge "CI: New way to determnine libdir"
George Joseph [Tue, 25 Jun 2019 14:07:12 +0000 (09:07 -0500)] 
Merge "CI:  New way to determnine libdir"

6 years agoMerge "res_fax: gateway sends T.38 request to both endpoints if V.21 detected"
George Joseph [Mon, 24 Jun 2019 20:16:36 +0000 (15:16 -0500)] 
Merge "res_fax: gateway sends T.38 request to both endpoints if V.21 detected"

6 years agosig_pri: Address gcc9 issues
George Joseph [Mon, 24 Jun 2019 13:30:19 +0000 (07:30 -0600)] 
sig_pri:  Address gcc9 issues

A few more format truncation issues addressed.

Change-Id: I047f373169caaca0eec4889d3c0e5e10f130017a

6 years agoMerge "translate.c do not log WARNING on empty audio frame"
George Joseph [Fri, 21 Jun 2019 18:41:29 +0000 (13:41 -0500)] 
Merge "translate.c do not log WARNING on empty audio frame"

6 years agoMerge "app_confbridge: Attended transfer event fixup"
Friendly Automation [Fri, 21 Jun 2019 16:24:35 +0000 (11:24 -0500)] 
Merge "app_confbridge:  Attended transfer event fixup"

6 years agoapp_amd: issue with silence suppression fixed
Nasir Iqbal [Tue, 21 May 2019 06:38:24 +0000 (11:38 +0500)] 
app_amd: issue with silence suppression fixed

Now AMD algorithm will not ignore AST_FRAME_NULL, As I think using manual
wait time instead of `framelength` is enough to fix timeout / TOOLONG issue.

ASTERISK-28419 #close

Change-Id: I16ea2d6295bc99b975e8c092e5f9fbd9214debdb

6 years agores_fax: gateway sends T.38 request to both endpoints if V.21 detected
Alexei Gradinari [Wed, 29 May 2019 22:54:16 +0000 (18:54 -0400)] 
res_fax: gateway sends T.38 request to both endpoints if V.21 detected

According T.38 Gateway 'Use case 3'
https://wiki.asterisk.org/wiki/display/AST/T.38+Gateway
T.38 Gateway should send T.38 negotiation request to called endpoint
if FAX preamble (using V.21 detector) generated by called endpoint.
But it does not, because fax_gateway_detect_v21 constructs T.38
negotiation request, but forwards it only to other channel,
not to the channel on which FAX preamble is detected.

Some SIP endpoints could be improperly configured to rely on the other side
to initiate T.38 re-INVITEs.

With this patch the T.38 Gateway tries to negotiate with both sides
by sending T.38 negotiation request to both endpoints supported T.38.

Change-Id: I73bb24799bfe1a48adae9c034a2edbae54cc2a39

6 years agoCI: New way to determnine libdir
George Joseph [Wed, 19 Jun 2019 16:58:39 +0000 (10:58 -0600)] 
CI:  New way to determnine libdir

We were using the presence of /usr/lib64 to determine where
shared libraries should be installed.  This only existed on
Redhat based systems and was safe.  If it existed, use it,
otherwise use /usr/lib.

Unfortunately, Ubuntu 19 decided to create a /usr/lib64 BUT
NOT INCLUDE IT IN THE DEFAULT ld.so.conf.  So if anything is
installed there, it won't work.

The new method, just looks for $ID in /etc/os-release and if it's
centos or fedora, uses /usr/lib64 and if ubuntu, uses /usr/lib.

NOTE:  This applies only to the CI scripts.  Normal asterisk
build and install is not affected.

Change-Id: Iad66374b550fd89349bedbbf2b93f8edd195a7c3

6 years agotranslate.c do not log WARNING on empty audio frame
Alexei Gradinari [Fri, 14 Jun 2019 20:45:39 +0000 (16:45 -0400)] 
translate.c do not log WARNING on empty audio frame

There is WARNING "no samples for ..." on each Playtones.
The function ast_playtones_start calls ast_activate_generator,
which calls ast_prod.
The function ast_prod calls ast_write with empty audio frame.
In this case it's spam log.

Change-Id: Id4ac309489d9ff281bad02abdef341cecdede660

6 years agochan_dahdi: Address gcc9 issues
George Joseph [Mon, 17 Jun 2019 17:11:49 +0000 (11:11 -0600)] 
chan_dahdi:  Address gcc9 issues

Fixed format-truncation issues in chan_dahdi.c and
sig_analog.c.  Since they're related to fields provided
by dahdi-tools we can't change the buffer sizes so we're just
checking the return from snprintf and printing an errior if we
overflow.

Change-Id: Idc1f3c1565b88a7d145332a0196074b5832864e5

6 years agoapp_confbridge: Attended transfer event fixup
George Joseph [Mon, 10 Jun 2019 21:58:59 +0000 (15:58 -0600)] 
app_confbridge:  Attended transfer event fixup

When a channel already in a conference bridge is attended transfered
to another extension, or when an existing call is attended
transferred into a conference bridge, we now generate ConfbridgeJoin
and ConfbridgeLeave events for the entering and departing channels.

Change-Id: Id7709cfbceb26fbcb828b2d0d2a6b2fbeaf028e1

6 years agopjproject: Update to 2.9 release
Sean Bright [Thu, 13 Jun 2019 15:11:48 +0000 (11:11 -0400)] 
pjproject: Update to 2.9 release

Relies on https://github.com/asterisk/third-party/pull/4

Change-Id: Iec9cad42cb4ae109a86a3d4dae61e8bce4424ce3

6 years agores_rtp_asterisk: Add support for DTLS packet fragmentation.
Joshua Colp [Tue, 11 Jun 2019 12:26:42 +0000 (09:26 -0300)] 
res_rtp_asterisk: Add support for DTLS packet fragmentation.

This change adds support for larger TLS certificates by allowing
OpenSSL to fragment the DTLS packets according to the configured
MTU. By default this is set to 1200.

This is accomplished by implementing our own BIO method that
supports MTU querying. The configured MTU is returned to OpenSSL
which fragments the packet accordingly. When a packet is to be
sent it is done directly out the RTP instance.

ASTERISK-28018

Change-Id: If2d5032019a28ffd48f43e9e93ed71dbdbf39c06

6 years agoMerge "app_attended_transfer: new application AttendedTransfer"
George Joseph [Wed, 12 Jun 2019 15:44:06 +0000 (10:44 -0500)] 
Merge "app_attended_transfer: new application AttendedTransfer"

6 years agoMerge "app_blind_transfer: new application BlindTransfer"
Friendly Automation [Wed, 12 Jun 2019 14:31:36 +0000 (09:31 -0500)] 
Merge "app_blind_transfer: new application BlindTransfer"

6 years agoMerge "chan_pjsip.c: Check for channel and session to not be NULL in hangup"
George Joseph [Wed, 12 Jun 2019 13:50:01 +0000 (08:50 -0500)] 
Merge "chan_pjsip.c: Check for channel and session to not be NULL in hangup"

6 years agoapp_attended_transfer: new application AttendedTransfer
Alexei Gradinari [Tue, 21 May 2019 19:12:55 +0000 (15:12 -0400)] 
app_attended_transfer: new application AttendedTransfer

AttendedTransfer queues up attended transfer to the given extension.

This application can be useful with Custom Dynamic Features.
For example to make attended transfer to a predefined number.

features.conf
;;;
[applicationmap]
my_atxfer => *7,self,GoSub,"my_atxfer,s,1",default
;;;

extensions.conf
;;;
[globals]
DYNAMIC_FEATURES=my_atxfer
TRANSFER_CONTEXT=my_transfer

[my_atxfer]
exten => s,1,AttendedTransfer(1234567890)
   same => n,Return()

[my_transfer]
include => default
;;;

This application also can be used to completly redefine Attended transfer
feature using dialplan. For example:

features.conf
;;;
[featuremap]
atxfer => *7

[applicationmap]
custom_atxfer => *2,self,GoSub,"custom_atxfer,s,1",default
;;;

extensions.conf
;;;
[globals]
DYNAMIC_FEATURES=custom_atxfer
TRANSFER_CONTEXT=my_transfer

[custom_atxfer]
exten => s,1,
   same => n,Playback(pbx-transfer)
   same => n,Read(dest,dial,10,i,3,3)
   same => n,AttendedTransfer(${dest})
   same => n,Return()

[my_transfer]
include => default
;;;

Change-Id: Ie5cfa455d0813cffd5c85a6fb117f07d8f0b903b

6 years agoMerge "cdr_pgsql: fix error in connection string"
Friendly Automation [Tue, 11 Jun 2019 13:03:09 +0000 (08:03 -0500)] 
Merge "cdr_pgsql: fix error in connection string"

6 years agochan_pjsip.c: Check for channel and session to not be NULL in hangup
agupta [Thu, 6 Jun 2019 12:48:18 +0000 (18:18 +0530)] 
chan_pjsip.c: Check for channel and session to not be NULL in hangup

We have seen some rare case of segmentation fault in hangup function
and we could notice that channel pointer was NULL.  Debug log shows
that there is a 200 OK answer and SIP timeout at the same time.  It
looks that while the SIP session was being destroyed due to timeout
call hangup due to answer event lead to race condition and channel
is being destroyed from two different places.  The check ensures we
check it not to be NULL before freeing it.

ASTERISK-25371

Change-Id: I19f6566830640625e08f7b87bfe15758ad33a778

6 years agoapp_blind_transfer: new application BlindTransfer
Alexei Gradinari [Tue, 21 May 2019 19:53:47 +0000 (15:53 -0400)] 
app_blind_transfer: new application BlindTransfer

BlindTransfer redirects all channels currently bridged to the
caller channel to the specified destination.

This application can be useful with Custom Dynamic Features.
For example to make blind transfer to a predefined number.

features.conf
;;;
[applicationmap]
my_blindxfer => *6,self,GoSub,"my_blindxfer,s,1",default
;;;

extensions.conf
;;;
[globals]
DYNAMIC_FEATURES=my_blindxfer

[my_blindxfer]
exten => s,1,BlindTransfer(1234567890,default)
   same => n,Return()
;;;

This application also can be used to completly redefine Blind transfer
feature using dialplan. For example:

features.conf
;;;
[featuremap]
blindxfer =>

[applicationmap]
custom_blindxfer => ##,self,GoSub,"custom_blindxfer,s,1",default
;;;

extensions.conf
;;;
[globals]
DYNAMIC_FEATURES=custom_blindxfer

[custom_blindxfer]
exten => s,1,
   same => n,Playback(pbx-transfer)
   same => n,Read(dest,dial,10,i,3,3)
   same => n,BlindTransfer(${dest},default)
   same => n,Return()
;;;

Change-Id: I9d55e7f69ccfd4472dec00d62771d6de8803215a

6 years agopbx_dundi: added IPv4/IPv6 dual bind support to DUNDi
Kirsty Tyerman [Tue, 8 Jan 2019 06:14:07 +0000 (16:14 +1000)] 
pbx_dundi: added IPv4/IPv6 dual bind support to DUNDi

ASTERISK-28234
Reported-by: Kirsty Tyerman
Change-Id: I5d6e6b52dbe51415046bb3953fd16f5b421bc2e1

6 years agocdr_pgsql: fix error in connection string
Chris-Savinovich [Tue, 4 Jun 2019 17:41:33 +0000 (12:41 -0500)] 
cdr_pgsql: fix error in connection string

Fixes an error occurring in function pgsql_reconnect() caused when value of
hostname is blank. Which in turn will cause the connection string to look
like this: "host= port=xx", which creates a sintax error. This fix now checks
if the corresponding values for host, port, dbname, and user are blank. Note
that since this is a reconnect function the database library will replace any
missing value pairs with default ones.

ASTERISK-28435

Change-Id: I0a921f99bbd265768be08cd492f04b30855b8423

6 years agoMerge "res_fax: fix segfault on inactive "reserved" fax session"
Friendly Automation [Tue, 4 Jun 2019 10:07:14 +0000 (05:07 -0500)] 
Merge "res_fax: fix segfault on inactive "reserved" fax session"

6 years agoMerge "app_readexten: new option 'p' to stop reading on '#' key"
Friendly Automation [Mon, 3 Jun 2019 15:05:11 +0000 (10:05 -0500)] 
Merge "app_readexten: new option 'p' to stop reading on '#' key"

6 years agoMerge "pjsip: replace 180 by 183 if SDP negotiation has completed"
George Joseph [Mon, 3 Jun 2019 14:36:43 +0000 (09:36 -0500)] 
Merge "pjsip: replace 180 by 183 if SDP negotiation has completed"

6 years agoMerge "res_fax: add channel name to CLI 'fax show session'"
Friendly Automation [Mon, 3 Jun 2019 14:29:12 +0000 (09:29 -0500)] 
Merge "res_fax: add channel name to CLI 'fax show session'"

6 years agores_fax: fix segfault on inactive "reserved" fax session
Alexei Gradinari [Tue, 28 May 2019 20:35:17 +0000 (16:35 -0400)] 
res_fax: fix segfault on inactive "reserved" fax session

The change #10017 "Handle fax gateway being started more than once"
introdiced a bug which leads to segfault in res_fax_spandsp.

The res_fax_spandsp module does not support reserving sessions, so
fax_session_reserve returns a fax session with state AST_FAX_STATE_INACTIVE.

The fax_gateway_start does not create a real fax session if the fax session
is already present and the state is not AST_FAX_STATE_RESERVED.
But the "reserved" session created for res_fax_spandsp has state
AST_FAX_STATE_INACTIVE, so fax_gateway_start not starting.

Then when fax_gateway_framehook is called and gateway T.38 state is
NEGOTIATED the call of gateway->s->tech->write(gateway->s, f) leads to
segfault, because session tech_pvt is not set, i.e. the tech session
was not initialized/started.

This patch adds check also on AST_FAX_STATE_INACTIVE to the "reserved"
session created for res_fax_spandsp will start.

This patch also adds extra check and log ERROR if tech_pvt is not set
before call tech->write.

ASTERISK-27981 #close

Change-Id: Ife3e65e5f18c902db2ff0538fccf7d28f88fa803

6 years agores_fax: add channel name to CLI 'fax show session'
Alexei Gradinari [Tue, 28 May 2019 22:15:40 +0000 (18:15 -0400)] 
res_fax: add channel name to CLI 'fax show session'

This patch adds a channel name to output of CLI 'fax show session'
and also expands the channel name field up to 30 characters on
CLI 'fax show sessions'

Change-Id: Id059c43ff41811f5e76712b83fb63b8f246da953

6 years agobuild: Fix file format in CHANGES-staging.
Ben Ford [Fri, 24 May 2019 14:01:14 +0000 (09:01 -0500)] 
build: Fix file format in CHANGES-staging.

One of the change files doesn't conform to the format that the release
scripts need in order to parse it.

Change-Id: Ie0b634cf27e4cbc671b9fe92993b6f2ecf60254c

6 years agochan_dahdi: add missing include.
Guido Falsi [Thu, 23 May 2019 14:44:07 +0000 (16:44 +0200)] 
chan_dahdi: add missing include.

After some definitions have been moved to asterisk/mwi.h the files
channels/chan_dahdi.h channels/sig_pri.c are missing this new
include.

ASTERISK-28427 #close

Change-Id: Ia8cc595eeda653324643f40dcd9799d4c3f0ac91

6 years agoapp_readexten: new option 'p' to stop reading on '#' key
Alexei Gradinari [Fri, 17 May 2019 22:45:25 +0000 (18:45 -0400)] 
app_readexten: new option 'p' to stop reading on '#' key

This patch adds the 'p' option.
The extension entered will be considered complete when a # is entered.

Change-Id: If77c40c9c8b525885730821e768f5dea71cf04c1

6 years agoMerge "res_rtp_asterisk: timestamp should be unsigned instead of signed int"
Friendly Automation [Thu, 23 May 2019 14:03:49 +0000 (09:03 -0500)] 
Merge "res_rtp_asterisk: timestamp should be unsigned instead of signed int"

6 years agoMerge "pjproject-bundled: Add upstream timer fixes"
Friendly Automation [Wed, 22 May 2019 17:07:50 +0000 (12:07 -0500)] 
Merge "pjproject-bundled:  Add upstream timer fixes"

6 years agoMerge "res_rtp_asterisk: Add ability to propose local address in ICE"
Friendly Automation [Wed, 22 May 2019 16:28:18 +0000 (11:28 -0500)] 
Merge "res_rtp_asterisk:  Add ability to propose local address in ICE"

6 years agores_prometheus: Add metrics for PJSIP outbound registrations
Matt Jordan [Fri, 10 May 2019 14:36:01 +0000 (09:36 -0500)] 
res_prometheus: Add metrics for PJSIP outbound registrations

When monitoring Asterisk instances, it's often useful to know when an
outbound registration fails, as this often maps to the notion of a trunk
and having a trunk fail is usually a "bad thing". As such, this patch
adds monitoring metrics that track the state of PJSIP outbound registrations.
It does this by looking for the Registry events coming across the Stasis
system topic, and publishing those as metrics to Prometheus. Note that
while this may support other outbound registration types (IAX2, SIP, etc.)
those haven't been tested. Your mileage may vary.

(And why are you still using IAX2 and SIP? It's 2019 folks. Get with the
program.)

This patch also adds Sorcery observers to handle modifications to the
underlying PJSIP outbound registration objects. This is useful when a
reload is triggered that modifies the properties of an outbound registration,
or when ARI push configuration is used and an object is updated or
deleted. Because we rely on properties of the registration object to
define the metric (label key/value pairs), we delete the relevant metric when
we notice that something has changed and wait for a new Stasis message to
arrive to re-create the metric.

ASTERISK-28403

Change-Id: If01420e38530fc20b6dd4aa15cd281d94cd2b87e

6 years agores_prometheus: Add CLI commands
Matt Jordan [Thu, 3 Jan 2019 16:28:28 +0000 (10:28 -0600)] 
res_prometheus: Add CLI commands

This patch adds a few CLI commands to the res_prometheus module to aid
system administrators setting up and configuring the module. This includes:

* prometheus show status: Display basic statistics about the Prometheus
  module, including its essential configuration, when it was last scraped,
  and how long the scrape took. The last two bits of information are useful
  when Prometheus isn't generating metrics appropriately, as it will at
  least tell you if Asterisk has had its HTTP route hit by the remote
  server.

* prometheus show metrics: Dump the current metrics to the CLI. Useful for
  system administrators to see what metrics are currently available without
  having to cURL or go to Prometheus itself.

ASTERISK-28403

Change-Id: Ic09813e5e14b901571c5c96ebeae2a02566c5172

6 years agores_prometheus: Add Asterisk bridge metrics
Matt Jordan [Thu, 9 May 2019 14:41:49 +0000 (09:41 -0500)] 
res_prometheus: Add Asterisk bridge metrics

This patch adds basic Asterisk bridge statistics to the res_prometheus
module. This includes:

* asterisk_bridges_count: The current number of bridges active on the
  system.

* asterisk_bridges_channels_count: The number of channels active in a
  bridge.

In all cases, enough information is provided with each bridge metric
to determine a unique instance of Asterisk that provided the data, along
with the technology, subclass, and creator of the bridge.

ASTERISK-28403

Change-Id: Ie27417dd72c5bc7624eb2a7a6a8829d7551788dc

6 years agores_prometheus: Add Asterisk endpoint metrics
Matt Jordan [Thu, 9 May 2019 14:41:02 +0000 (09:41 -0500)] 
res_prometheus: Add Asterisk endpoint metrics

This patch adds basic Asterisk endpoint statistics to the res_prometheus
module. This includes:

* asterisk_endpoints_state: The current state (unknown, online, offline)
  for each defined endpoint.

* asterisk_endpoints_channels_count: The current number of channels
  associated with a given endpoint.

* asterisk_endpoints_count: The current number of defined endpoints.

In all cases, enough information is provided with each endpoint metric
to determine a unique instance of Asterisk that provided the data, as well
as the underlying technology and resource definition.

ASTERISK-28403

Change-Id: I46443963330c206a7d12722d08dcaabef672310e

6 years agores_rtp_asterisk: timestamp should be unsigned instead of signed int
Morten Tryfoss [Tue, 21 May 2019 16:29:05 +0000 (18:29 +0200)] 
res_rtp_asterisk: timestamp should be unsigned instead of signed int

Using timestamp with signed int will cause timestamps exceeding max value
to be negative.
This causes the jitterbuffer to do passthrough of the packet.

ASTERISK-28421

Change-Id: I9dabd0718180f2978856c50f43aac4e52dc3cde9

6 years agores_prometheus: Add Asterisk channel metrics
Matt Jordan [Fri, 3 May 2019 00:45:27 +0000 (19:45 -0500)] 
res_prometheus: Add Asterisk channel metrics

This patch adds basic Asterisk channel statistics to the res_prometheus
module. This includes:

* asterisk_calls_sum: A running sum of the total number of
  processed calls

* asterisk_calls_count: The current number of calls

* asterisk_channels_count: The current number of channels

* asterisk_channels_state: The state of any particular channel

* asterisk_channels_duration_seconds: How long a channel has existed,
  in seconds

In all cases, enough information is provided with each channel metric
to determine a unique instance of Asterisk that provided the data, as
well as the name, type, unique ID, and - if present - linked ID of each
channel.

ASTERISK-28403

Change-Id: I0db306ec94205d4f58d1e7fbabfe04b185869f59