]> git.ipfire.org Git - thirdparty/asterisk.git/log
thirdparty/asterisk.git
7 years agoMerge "tcptls: Allow OpenSSL 1.1.x configured with enable-ssl3-method no-deprecated...
George Joseph [Tue, 5 Jun 2018 18:01:08 +0000 (13:01 -0500)] 
Merge "tcptls: Allow OpenSSL 1.1.x configured with enable-ssl3-method no-deprecated." into 13

7 years agoMerge "app_meetme: Fix manager event documentation for several events." into 13
Joshua Colp [Tue, 5 Jun 2018 11:53:33 +0000 (06:53 -0500)] 
Merge "app_meetme: Fix manager event documentation for several events." into 13

7 years agoapp_sendtext: Allow content types other than text/plain
George Joseph [Mon, 4 Jun 2018 14:50:51 +0000 (08:50 -0600)] 
app_sendtext:  Allow content types other than text/plain

There was no real reason to limit the conteny type to text/plain other
than that's what it was limited to before.  Now any text/* content
type will be allowed for channel drivers that don't support enhanced
messaging and any type will be allowed for channel drivers that do
support enhanced messaging.

Change-Id: I94a90cfee98b4bc8e22aa5c0b6afb7b862f979d9

7 years agoMerge "ast_coredumper: Fix output directory and variable precedence" into 13
Joshua Colp [Thu, 31 May 2018 10:15:57 +0000 (05:15 -0500)] 
Merge "ast_coredumper:  Fix output directory and variable precedence" into 13

7 years agoapp_meetme: Fix manager event documentation for several events.
Richard Mudgett [Tue, 29 May 2018 17:28:48 +0000 (12:28 -0500)] 
app_meetme: Fix manager event documentation for several events.

The MeetmeJoin, MeetmeLeave, MeetmeEnd, MeetmeMute, MeetmeTalking, and
MeetmeTalkRequest AMI events were documented with sending out a Usernum
header when the User header was actually output.

* Change the online documentation to match reality.

ASTERISK-27873
ASTERISK-25261

Change-Id: I437bc70618d07c183c9624b7069c2fcae7f17a39

7 years agoMerge "libasteriskssl: Allow OpenSSL 1.0.2 configured with no-deprecated." into 13
Joshua Colp [Tue, 29 May 2018 17:07:39 +0000 (12:07 -0500)] 
Merge "libasteriskssl: Allow OpenSSL 1.0.2 configured with no-deprecated." into 13

7 years agotcptls: Allow OpenSSL 1.1.x configured with enable-ssl3-method no-deprecated.
Alexander Traud [Fri, 25 May 2018 12:24:51 +0000 (14:24 +0200)] 
tcptls: Allow OpenSSL 1.1.x configured with enable-ssl3-method no-deprecated.

ASTERISK-27874

Change-Id: Ica65113511c7a1c13f7988e7d9e7d9e7f3f620dd

7 years agoMerge "res/res_rtp_asterisk: ensure marker bit is correctly set on ssrc change" into 13
Joshua Colp [Thu, 24 May 2018 19:55:59 +0000 (14:55 -0500)] 
Merge "res/res_rtp_asterisk: ensure marker bit is correctly set on ssrc change" into 13

7 years agoast_coredumper: Fix output directory and variable precedence
George Joseph [Tue, 15 May 2018 13:45:20 +0000 (07:45 -0600)] 
ast_coredumper:  Fix output directory and variable precedence

The OUTPUTDIR variable in ast_debug_tools.conf.sample is now set
to "/tmp" instead of "/some/directory".

Variables set on the command line or that are already in the
environment now take predecence over variables set in the config files.

ASTERISK-27846
Reported by: Ted G

Change-Id: Ie8baec52d531886bf5849ec1d59bb59dc87ad387

7 years agoMerge "tcptls: Repair ./configure --with-ssl=PATH." into 13
Joshua Colp [Thu, 24 May 2018 11:07:18 +0000 (06:07 -0500)] 
Merge "tcptls: Repair ./configure --with-ssl=PATH." into 13

7 years agoMerge "channel.c: Fix off nominal channel allocation failure path." into 13
Joshua Colp [Thu, 24 May 2018 10:15:50 +0000 (05:15 -0500)] 
Merge "channel.c: Fix off nominal channel allocation failure path." into 13

7 years agoMerge "config.c: Fix successful DELETE treated as failure" into 13
Joshua Colp [Thu, 24 May 2018 10:10:07 +0000 (05:10 -0500)] 
Merge "config.c: Fix successful DELETE treated as failure" into 13

7 years agores/res_rtp_asterisk: ensure marker bit is correctly set on ssrc change
Torrey Searle [Wed, 9 May 2018 13:31:47 +0000 (15:31 +0200)] 
res/res_rtp_asterisk: ensure marker bit is correctly set on ssrc change

Certain race conditions between changing bridge types and DTMF can
cause the current FLAG_NEED_MARKER_BIT to send the marker bit before
the actual first packet of native bridging.

This logic keeps track of the ssrc the bridge is currently sending
and will correctly ensure the marker bit is set if SSRC as changed
from the previous sent packet.

ASTERISK-27845

Change-Id: I01858bd0235f1e5e629e20de71b422b16f55759b

7 years agochannel.c: Fix off nominal channel allocation failure path.
Richard Mudgett [Tue, 22 May 2018 22:17:31 +0000 (17:17 -0500)] 
channel.c: Fix off nominal channel allocation failure path.

__ast_channel_alloc_ap() had a failure exit path that hadn't setup the fd
descriptors to -1 yet.  The destructor would then attempt to close these
fd's that had never been opened.

Change-Id: Icf21093f36c60781e8cf6ee9d586536302af33e3

7 years agoconfig.c: Fix successful DELETE treated as failure
Alexei Gradinari [Fri, 18 May 2018 21:45:22 +0000 (17:45 -0400)] 
config.c: Fix successful DELETE treated as failure

The config engine destroy_func callback function returns the number of
rows deleted or -1 on error.  But the function
ast_destroy_realtime_fields treated non-zero return values as error.

ASTERISK-27863

Change-Id: Ied02b38e8196cb03043e609a0679feebd288d17b

7 years agoMerge "app_voicemail: Fix data-type mismatch between app_voicemail and database"...
Joshua Colp [Mon, 21 May 2018 14:05:37 +0000 (09:05 -0500)] 
Merge "app_voicemail: Fix data-type mismatch between app_voicemail and database" into 13

7 years agolibasteriskssl: Allow OpenSSL 1.0.2 configured with no-deprecated.
Alexander Traud [Sun, 20 May 2018 11:41:41 +0000 (13:41 +0200)] 
libasteriskssl: Allow OpenSSL 1.0.2 configured with no-deprecated.

Use CRYPTO_set_id_callback(.) only with OpenSSL 0.9.8 and older.

ASTERISK-27867

Change-Id: Iadd58d5bf6f538eb224203970a4e88e26f259655

7 years agotcptls: Repair ./configure --with-ssl=PATH.
Alexander Traud [Sat, 19 May 2018 13:23:30 +0000 (15:23 +0200)] 
tcptls: Repair ./configure --with-ssl=PATH.

SSL_OP_NO_TLSv1_1 and SSL_OP_NO_TLSv1_2 got discovered without honoring a PATH.

ASTERISK-27865

Change-Id: I8cd358eed7411726d08fa7b01691bef122fbeb71

7 years agoMerge "app_voicemail: Fix incorrect msg leaving/retrieving an ODBC voicemail" into 13
Kevin Harwell [Fri, 18 May 2018 21:43:06 +0000 (16:43 -0500)] 
Merge "app_voicemail: Fix incorrect msg leaving/retrieving an ODBC voicemail" into 13

7 years agoMerge "chan_mobile: support handling of caller-id names ("cnam")." into 13
Jenkins2 [Fri, 18 May 2018 21:06:34 +0000 (16:06 -0500)] 
Merge "chan_mobile: support handling of caller-id names ("cnam")." into 13

7 years agoMerge "res_pjsip_endpoint_identifier_ip: Unregister the module for headers." into 13
Jenkins2 [Fri, 18 May 2018 20:18:33 +0000 (15:18 -0500)] 
Merge "res_pjsip_endpoint_identifier_ip: Unregister the module for headers." into 13

7 years agoapp_voicemail: Fix incorrect msg leaving/retrieving an ODBC voicemail
Nic Colledge [Sat, 12 May 2018 11:53:13 +0000 (12:53 +0100)] 
app_voicemail: Fix incorrect msg leaving/retrieving an ODBC voicemail

Correct the log warning message shown when ODBC voicemail
retrieve_file is called and there is a null value in the category
column.
A more meaningfull message is now written at debug level.

ASTERISK-27853

Change-Id: Ic36e97d5eb070a23a12ba45972f6b53e2182a3f4

7 years agochan_mobile: support handling of caller-id names ("cnam").
Brian P. Martin [Wed, 18 Apr 2018 02:15:08 +0000 (19:15 -0700)] 
chan_mobile: support handling of caller-id names ("cnam").

Add support to handle caller-ID names ("cnam") in addition to caller-ID
numbers.  The prior code ignored the caller-ID name altogether, and
used the local name for the cell phone (e.g. "my-iphone") in its place.

Note: as of this writing, at least some Android phones don't pass cnam to
us. This can be seen by issuing "core set debug 2" in the CLI and watching
the "CLIP" record when a call comes in.  If cnam isn't in the CLIP record,
there's nothing we can do to provide one.  We'll provide a null cnam field,
so later Asterisk processes know to try other sources (e.g. cidname database,
OpenCNAM, etc.).

Reported by: Brian Martin
Tested by: Brian Martin
ASTERISK-27726

Change-Id: I89490d85fa406c36261879c50ae5e65595538ba5

7 years agores_pjsip_endpoint_identifier_ip: Unregister the module for headers.
Alexander Traud [Thu, 17 May 2018 06:58:43 +0000 (08:58 +0200)] 
res_pjsip_endpoint_identifier_ip: Unregister the module for headers.

Asterisk uses Reference Counting to track whether a module can be unloaded.
Every consumer who requires a module, increases the reference count. When the
consumer goes, is unloaded itself, it has to decrease the reference count on
all its used/required modules. That way
 core stop gracefully
works on the command-line interface (CLI): One module after the other is
unloaded. A recent change broke this for the module res_pjsip.

ASTERISK-27861

Change-Id: I261abcb411d026bbb0691cc78f28300bfd3103a3

7 years agores_pjsip: Register pjsip_transport_management not externally but internally.
Alexander Traud [Thu, 17 May 2018 05:34:03 +0000 (07:34 +0200)] 
res_pjsip: Register pjsip_transport_management not externally but internally.

The module (res_)pjsip_transport_management got moved into res_pjsip. It is no
longer an independent/external module with (un)load_module and therefore has to
register just internally with res_pjsip.

ASTERISK-27860

Change-Id: Icd0413be7d2e98b92f51e6d6c353f2570bb4be95

7 years agoMerge "cli: Display correct unit for HTTP timeout in "manager show settings"." into 13
Jenkins2 [Wed, 16 May 2018 14:40:58 +0000 (09:40 -0500)] 
Merge "cli: Display correct unit for HTTP timeout in "manager show settings"." into 13

7 years agoMerge "Fix GCC 8 build issues." into 13
Jenkins2 [Wed, 16 May 2018 14:37:35 +0000 (09:37 -0500)] 
Merge "Fix GCC 8 build issues." into 13

7 years agoMerge "rtp_engine: Remove the double assigned RTP payload ID of H.263+." into 13
Joshua Colp [Tue, 15 May 2018 09:13:41 +0000 (04:13 -0500)] 
Merge "rtp_engine: Remove the double assigned RTP payload ID of H.263+." into 13

7 years agoMerge "rtp_engine: Avoid a typo error in Doxygen for ast_rtp_codecs_find_payload_code...
Joshua Colp [Mon, 14 May 2018 11:25:06 +0000 (06:25 -0500)] 
Merge "rtp_engine: Avoid a typo error in Doxygen for ast_rtp_codecs_find_payload_code." into 13

7 years agoMerge "git: Ignore *.orig." into 13
Jenkins2 [Mon, 14 May 2018 11:24:09 +0000 (06:24 -0500)] 
Merge "git: Ignore *.orig." into 13

7 years agoMerge "pjsip: Rewrite OPTIONS support with new eyes." into 13
Joshua Colp [Mon, 14 May 2018 09:06:20 +0000 (04:06 -0500)] 
Merge "pjsip: Rewrite OPTIONS support with new eyes." into 13

7 years agoapp_voicemail: Fix data-type mismatch between app_voicemail and database
Nic Colledge [Tue, 27 Mar 2018 23:53:07 +0000 (00:53 +0100)] 
app_voicemail: Fix data-type mismatch between app_voicemail and database

Fix data-type mismatch between app_voicemail and database columns
exposed by new version of MariaDB

ASTERISK-27760

Change-Id: I8543ad480a08c98be78bde1ee870e6e6c84b2c5b

7 years agortp_engine: Remove the double assigned RTP payload ID of H.263+.
Alexander Traud [Fri, 11 May 2018 17:49:12 +0000 (19:49 +0200)] 
rtp_engine: Remove the double assigned RTP payload ID of H.263+.

Mantis-3709 (Commit 68ff3c3, Asterisk 1.2) added support for the video format
H.263+. For this, the RTP payload ID 103 got assigned statically. Commit f1aadc8
assigned another payload ID 98 for this format in Asterisk 1.6.

Change-Id: I90e35b158487f8f1f8187da6241b54cd3b74e667

7 years agocli: Display correct unit for HTTP timeout in "manager show settings".
Corey Farrell [Fri, 11 May 2018 17:26:39 +0000 (13:26 -0400)] 
cli: Display correct unit for HTTP timeout in "manager show settings".

HTTP timeout is in seconds, not minutes.

ASTERISK-27852 #close

Change-Id: Ie6640835cb07307555741f9b559c2eb876d9343e

7 years agortp_engine: Avoid a typo error in Doxygen for ast_rtp_codecs_find_payload_code.
Alexander Traud [Fri, 11 May 2018 15:37:57 +0000 (17:37 +0200)] 
rtp_engine: Avoid a typo error in Doxygen for ast_rtp_codecs_find_payload_code.

Change-Id: Ica089d4507a27ddfc4ce3a88d697ffbef378de48

7 years agoFix GCC 8 build issues.
Corey Farrell [Mon, 7 May 2018 15:49:18 +0000 (11:49 -0400)] 
Fix GCC 8 build issues.

This fixes build warnings found by GCC 8.  In some cases format
truncation is intentional so the warning is just suppressed.

ASTERISK-27824 #close

Change-Id: I724f146cbddba8b86619d4c4a9931ee877995c84

7 years agoMerge "makeopts.in: Remove unused/undefined AST_MARCH_NATIVE." into 13
Joshua Colp [Thu, 10 May 2018 08:45:35 +0000 (03:45 -0500)] 
Merge "makeopts.in: Remove unused/undefined AST_MARCH_NATIVE." into 13

7 years agoMerge "sip_to_pjsip: Enable python3 compatibility." into 13
Joshua Colp [Thu, 10 May 2018 00:01:02 +0000 (19:01 -0500)] 
Merge "sip_to_pjsip: Enable python3 compatibility." into 13

7 years agores_hep: Adds hostname resolution support for capture_address
Matthew Fredrickson [Fri, 4 May 2018 21:07:10 +0000 (16:07 -0500)] 
res_hep: Adds hostname resolution support for capture_address

Previously, only an IP address would be accepted for the capture_address config
setting in hep.conf.  This change allows capture_address to be a resolvable
hostname or an IP address.

ASTERISK-27796 #close
Reported-By: Sebastian Gutierrez
Change-Id: I33e1a37a8b86e20505dadeda760b861a9ef51f6f

7 years agoMerge "app_macro: Prevent infinite loop in find_matching_priority." into 13
Jenkins2 [Wed, 9 May 2018 16:27:41 +0000 (11:27 -0500)] 
Merge "app_macro: Prevent infinite loop in find_matching_priority." into 13

7 years agogit: Ignore *.orig.
Corey Farrell [Wed, 9 May 2018 14:30:41 +0000 (10:30 -0400)] 
git: Ignore *.orig.

This prevents accidental commit of files created by patch.

Change-Id: I68380db61f0f9d620046f719ccd978811d0e9964

7 years agosip_to_pjsip: Enable python3 compatibility.
Alexander Traud [Wed, 18 Apr 2018 07:27:51 +0000 (09:27 +0200)] 
sip_to_pjsip: Enable python3 compatibility.

The script remains compatible with Python 2.7 but now also works with
Python 3.3 and newer; to ease the migration from chan_sip to chan_pjsip.

ASTERISK-27811

Change-Id: I59cc6b52a1a89777eebcf25b3023bdf93babf835

7 years agomakeopts.in: Remove unused/undefined AST_MARCH_NATIVE.
Corey Farrell [Tue, 8 May 2018 19:28:10 +0000 (15:28 -0400)] 
makeopts.in: Remove unused/undefined AST_MARCH_NATIVE.

Change-Id: I617a96ebb83ec99f5d3176bbbee2d2a272ccb203

7 years agomanager: fix digest auth for ami/http mechanism.
Jaco Kroon [Tue, 8 May 2018 09:59:02 +0000 (11:59 +0200)] 
manager: fix digest auth for ami/http mechanism.

Due to a fixed size buffer the digest authentication could be
incorrectly calculated if a large URI was provided, causing
authentication failure. The buffer is now dynamically allocated to allow
any size URI within the normal limits of the HTTP request size.

ASTERISK-27841

Change-Id: I660609db13b8f9e5f9567f339dd804f4985d41b3

7 years agoapp_macro: Prevent infinite loop in find_matching_priority.
Corey Farrell [Fri, 4 May 2018 18:47:25 +0000 (14:47 -0400)] 
app_macro: Prevent infinite loop in find_matching_priority.

Use AST_PBX_MAX_STACK to escape if we recurse 128 times.  This will
prevent crash if dialplan contains an include loop.  Log an error when
this occurs, at most one message per call to Macro() so we avoid logger
spam.

ASTERISK-26570 #close

Change-Id: I6c71b76998c31434391b150de055ae9a531e31da

7 years agoMerge "res_ari: Remove requirement that body exists when debug is on." into 13
Jenkins2 [Fri, 4 May 2018 11:08:40 +0000 (06:08 -0500)] 
Merge "res_ari: Remove requirement that body exists when debug is on." into 13

7 years agoMerge "res_pjsip/pjsip_distributor.c: Add missing off-nominal request response."...
Jenkins2 [Thu, 3 May 2018 17:11:00 +0000 (12:11 -0500)] 
Merge "res_pjsip/pjsip_distributor.c: Add missing off-nominal request response." into 13

7 years agoMerge "pjsip: Increase maximum number of usable ciphers & other cleanups" into 13
Joshua Colp [Thu, 3 May 2018 12:25:17 +0000 (07:25 -0500)] 
Merge "pjsip: Increase maximum number of usable ciphers & other cleanups" into 13

7 years agores_ari: Remove requirement that body exists when debug is on.
Joshua Colp [Thu, 3 May 2018 11:34:32 +0000 (11:34 +0000)] 
res_ari: Remove requirement that body exists when debug is on.

The "ari set debug" code for incoming requests incorrectly assumed
that all requests would contain a body. If one did not exist the
request would be incorrectly rejected. The response that was sent
was also incomplete as an incorrect function was used to construct
the response.

The code has now been changed to no longer require a request to have
a body and the response updated to use the correct function.

ASTERISK-27801

Change-Id: I4eef036ad54550a4368118cc348765ecac25e0f8

7 years agopjsip: Increase maximum number of usable ciphers & other cleanups
Sean Bright [Wed, 2 May 2018 12:43:35 +0000 (08:43 -0400)] 
pjsip: Increase maximum number of usable ciphers & other cleanups

* Increase maximum number of ciphers from 100 to 256 (or whatever
  PJ_SSL_SOCK_MAX_CIPHERS is #define'd to)

* Simplify logic in cipher_name_to_id()

* Make signed/unsigned comparison consistent

Re: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=897412

Reported by: OndÅ™ej Holas

Change-Id: Iea620f03915a1b873e79743154255c3148a514e7

7 years agores_pjsip/pjsip_distributor.c: Add missing off-nominal request response.
Richard Mudgett [Mon, 30 Apr 2018 22:24:33 +0000 (17:24 -0500)] 
res_pjsip/pjsip_distributor.c: Add missing off-nominal request response.

Change-Id: I389579b39c523d1d1e8ce020ef549a8bb5781c9b

7 years agores_pjsip/pjsip_distributor.c: Pull some assignments out of if tests.
Richard Mudgett [Mon, 30 Apr 2018 22:20:13 +0000 (17:20 -0500)] 
res_pjsip/pjsip_distributor.c: Pull some assignments out of if tests.

Change-Id: I3d30d638b53a4bbe9bf9aad853c649d583894112

7 years agoMerge "BuildSystem: Add DragonFly BSD." into 13
George Joseph [Mon, 30 Apr 2018 14:06:45 +0000 (09:06 -0500)] 
Merge "BuildSystem: Add DragonFly BSD." into 13

7 years agoMerge "translate: generic plc not filled in after translation" into 13
George Joseph [Mon, 30 Apr 2018 13:38:09 +0000 (08:38 -0500)] 
Merge "translate: generic plc not filled in after translation" into 13

7 years agoMerge "app_sendtext: Enhance SendText to support Enhanced Messaging" into 13
George Joseph [Mon, 30 Apr 2018 12:35:17 +0000 (07:35 -0500)] 
Merge "app_sendtext:  Enhance SendText to support Enhanced Messaging" into 13

7 years agopjsip: Rewrite OPTIONS support with new eyes.
Joshua Colp [Mon, 11 Dec 2017 18:34:53 +0000 (18:34 +0000)] 
pjsip: Rewrite OPTIONS support with new eyes.

The OPTIONS support in PJSIP has organically grown, like many things in
Asterisk.  It has been tweaked, changed, and adapted based on situations
run into.  Unfortunately this has taken its toll.  Configuration file
based objects have poor performance and even dynamic ones aren't that
great.

This change scraps the existing code and starts fresh with new eyes.  It
leverages all of the APIs made available such as sorcery observers and
serializers to provide a better implementation.

1.  The state of contacts, AORs, and endpoints relevant to the qualify
process is maintained.  This state can be updated by external forces (such
as a device registering/unregistering) and also the reload process.  This
state also includes the association between endpoints and AORs.

2.  AORs are scheduled and not contacts.  This reduces the amount of work
spent juggling scheduled items.

3.  Manipulation of which AORs are being qualified and the endpoint states
all occur within a serializer to reduce the conflict that can occur with
multiple threads attempting to modify things.

4.  Operations regarding an AOR use a serializer specific to that AOR.

5.  AORs and endpoint state act as state compositors.  They take input
from lower level objects (contacts feed AORs, AORs feed endpoint state)
and determine if a sufficient enough change has occurred to be fed further
up the chain.

6.  Realtime is supported by using observers to know when a contact has
been registered.  If state does not exist for the associated AOR then it
is retrieved and becomes active as appropriate.

The end result of all of this is best shown with a configuration file of
3000 endpoints each with an AOR that has a static contact.  In the old
code it would take over a minute to load and use all 8 of my cores.  This
new code takes 2-3 seconds and barely touches the CPU even while dealing
with all of the OPTIONS requests.

ASTERISK-26806

Change-Id: I6a5ebbfca9001dfe933eaeac4d3babd8d2e6f082

7 years agoMerge "bridge_softmix: Forward TEXT frames" into 13
George Joseph [Fri, 27 Apr 2018 18:17:27 +0000 (13:17 -0500)] 
Merge "bridge_softmix:  Forward TEXT frames" into 13

7 years agoMerge "BuildSystem: Enable IMAP storage on FreeBSD and DragonFly BSD." into 13
Joshua Colp [Fri, 27 Apr 2018 00:06:31 +0000 (19:06 -0500)] 
Merge "BuildSystem: Enable IMAP storage on FreeBSD and DragonFly BSD." into 13

7 years agoMerge "install_prereq: Add DragonFly BSD." into 13
Joshua Colp [Wed, 25 Apr 2018 18:55:19 +0000 (13:55 -0500)] 
Merge "install_prereq: Add DragonFly BSD." into 13

7 years agoMerge "format_pcm: Correct behavior of fseek and ftell for G.722" into 13
Joshua Colp [Wed, 25 Apr 2018 18:30:42 +0000 (13:30 -0500)] 
Merge "format_pcm: Correct behavior of fseek and ftell for G.722" into 13

7 years agoMerge "menuselect: Add DragonFly BSD." into 13
Joshua Colp [Wed, 25 Apr 2018 18:21:45 +0000 (13:21 -0500)] 
Merge "menuselect: Add DragonFly BSD." into 13

7 years agoMerge "chan_ooh323: fix ooManualProgress/ooManualRingback on ooh323 debuggin on"...
Jenkins2 [Wed, 25 Apr 2018 15:20:42 +0000 (10:20 -0500)] 
Merge "chan_ooh323: fix ooManualProgress/ooManualRingback on ooh323 debuggin on" into 13

7 years agoMerge "res_pjsip: Fix initialization of extended stringfields." into 13
Joshua Colp [Tue, 24 Apr 2018 23:59:01 +0000 (18:59 -0500)] 
Merge "res_pjsip: Fix initialization of extended stringfields." into 13

7 years agoMerge "chan_ooh323: Fix cppcheck warnings" into 13
Joshua Colp [Tue, 24 Apr 2018 23:39:17 +0000 (18:39 -0500)] 
Merge "chan_ooh323: Fix cppcheck warnings" into 13

7 years agotranslate: generic plc not filled in after translation
Kevin Harwell [Wed, 18 Apr 2018 20:59:38 +0000 (15:59 -0500)] 
translate: generic plc not filled in after translation

If during translation a codec could not handle a given frame the translation
core would return NULL, thus not passing along the "missing" frame. Due to this
there was no frame to apply generic plc to, thus rendering it useless.

This patch makes it so the translation core produces an interpolated slin frame
in the cases where an attempt was made to translate to slin, but failed. This
interpolated frame is then passed along and can be used by the generic plc
algorithms to fill in the frame.

ASTERISK-27814 #close

Change-Id: I133d084da87adef913bf2ecc9c9240e3eaf4f40a

7 years agochan_ooh323: fix ooManualProgress/ooManualRingback on ooh323 debuggin on
Alexander Anikin [Fri, 20 Apr 2018 19:07:21 +0000 (22:07 +0300)] 
chan_ooh323: fix ooManualProgress/ooManualRingback on ooh323 debuggin on

Call ooManualProgress/Ringback outside of ast_debug function
when ooh323 debugging is on

ASTERISK-27812 #close
ASTERISK-26893 #close
Reported by: Dimos, Marco Giordani

Change-Id: I5873762e4f05824e7b6e94a19dd4eb56adbbbb79

7 years agoBuildSystem: Enable IMAP storage on FreeBSD and DragonFly BSD.
Alexander Traud [Fri, 20 Apr 2018 12:13:12 +0000 (14:13 +0200)] 
BuildSystem: Enable IMAP storage on FreeBSD and DragonFly BSD.

ASTERISK-27639

Change-Id: I1347f3f2f3737010d0a80a5c30b5aaf71cf3ccb0

7 years agoBuildSystem: Add DragonFly BSD.
Alexander Traud [Fri, 20 Apr 2018 10:54:57 +0000 (12:54 +0200)] 
BuildSystem: Add DragonFly BSD.

ASTERISK-27820

Change-Id: I310896143e94d65da1c2be3bb448204a8b86d557

7 years agomenuselect: Add DragonFly BSD.
Alexander Traud [Fri, 20 Apr 2018 10:40:21 +0000 (12:40 +0200)] 
menuselect: Add DragonFly BSD.

In DragonFly BSD, added libraries from ports are placed into /usr/local.
Therefore, this directory must be added for the preprocessor, compiler, and
linker.

Beside that, the script ./configure was updated:
* OSARCH list was outdated and not used, removed.
* AC_CANONICAL_BUILD was not used.
* _REENTRANT, this feature test macro is obsolete.

ASTERISK-27820

Change-Id: I186d88d99cfa4de6569888e12ac97bd2f441c422

7 years agoinstall_prereq: Add DragonFly BSD.
Alexander Traud [Fri, 20 Apr 2018 10:23:26 +0000 (12:23 +0200)] 
install_prereq: Add DragonFly BSD.

ASTERISK-27820

Change-Id: I718ddb000fe5184b1bdc7759da67a370a7520144

7 years agoMerge "chan_vpb: Avoid GNU old-style field designator extension." into 13
Jenkins2 [Thu, 19 Apr 2018 19:36:34 +0000 (14:36 -0500)] 
Merge "chan_vpb: Avoid GNU old-style field designator extension." into 13

7 years agoMerge "res_pjsip: Fix deadlock on reliable transport shutdown." into 13
Jenkins2 [Wed, 18 Apr 2018 22:20:19 +0000 (17:20 -0500)] 
Merge "res_pjsip: Fix deadlock on reliable transport shutdown." into 13

7 years agoMerge "Build System: Enable python3 compatibility." into 13
Jenkins2 [Wed, 18 Apr 2018 22:06:26 +0000 (17:06 -0500)] 
Merge "Build System: Enable python3 compatibility." into 13

7 years agores_pjsip: Fix initialization of extended stringfields.
Corey Farrell [Wed, 18 Apr 2018 21:24:31 +0000 (17:24 -0400)] 
res_pjsip: Fix initialization of extended stringfields.

It is possible for initialization of extended stringfields to fail.  Add
checks for this failure.

Change-Id: I062e09852db3d37ceefaf6c2048958fa0118304f

7 years agoMerge "utils/pval: Add -lBlocksRuntime for compiler clang conditionally." into 13
Jenkins2 [Wed, 18 Apr 2018 20:18:32 +0000 (15:18 -0500)] 
Merge "utils/pval: Add -lBlocksRuntime for compiler clang conditionally." into 13

7 years agoMerge "utils: Add ast_assert_return" into 13
Jenkins2 [Wed, 18 Apr 2018 19:35:55 +0000 (14:35 -0500)] 
Merge "utils:  Add ast_assert_return" into 13

7 years agoformat_pcm: Correct behavior of fseek and ftell for G.722
Sean Bright [Wed, 18 Apr 2018 18:40:49 +0000 (14:40 -0400)] 
format_pcm: Correct behavior of fseek and ftell for G.722

There are twice as many samples in the same number of bytes, so redefine
some of the G.722 format functions in terms of their PCM counterparts.

Change-Id: I6a8c7352624b930a5f2d9e4857f75283fa5dd9f9

7 years agochan_ooh323: Fix cppcheck warnings
Alexander Anikin [Wed, 18 Apr 2018 10:32:34 +0000 (13:32 +0300)] 
chan_ooh323: Fix cppcheck warnings

Fix cppcheck warnings about redundant conditions and possible
null pointer usage

ASTERISK-27793 #close
Reported by: Ilya Shipitsin
Tested by: Ilya Shipitsin

Change-Id: I0b31933b062a23331dbac9a82b8bcfe345f406f6

7 years agoMerge "res_musiconhold: Don't restart MOH from beginning after announcement." into 13
Jenkins2 [Tue, 17 Apr 2018 17:11:48 +0000 (12:11 -0500)] 
Merge "res_musiconhold: Don't restart MOH from beginning after announcement." into 13

7 years agoapp_sendtext: Enhance SendText to support Enhanced Messaging
George Joseph [Tue, 10 Apr 2018 21:09:49 +0000 (15:09 -0600)] 
app_sendtext:  Enhance SendText to support Enhanced Messaging

SendText now accepts new channel variables that can be used
to override the To and From display names and set the Content-Type
of a message.  Since you can now set Content-Type, other text/*
content types are now valid.

Change-Id: I648b4574478119f95de09d9f08e9595831b02830

7 years agobridge_softmix: Forward TEXT frames
George Joseph [Wed, 27 Sep 2017 16:44:53 +0000 (10:44 -0600)] 
bridge_softmix:  Forward TEXT frames

Core bridging and, more specifically, bridge_softmix have been
enhanced to relay received frames of type TEXT or TEXT_DATA to all
participants in a softmix bridge.  res_pjsip_messaging and
chan_pjsip have been enhanced to take advantage of this so when
res_pjsip_messaging receives an in-dialog MESSAGE message from a
user in a conference call, it's relayed to all other participants
in the call.

res_pjsip_messaging already queues TEXT frames to the channel when
it receives an in-dialog MESSAGE from an endpoint and chan_pjsip
will send an MESSAGE when it gets a TEXT frame.  On a normal
point-to-point call, the frames are forwarded between the two
correctly.  bridge_softmix was not though so messages weren't
getting forwarded to conference bridge participants.  Even if they
were, the bridging code had no way to tell the participants who
sent the message so it would look like it came from the bridge
itself.

* The TEXT frame type doesn't allow storage of any meta data, such
as sender, on the frame so a new TEXT_DATA frame type was added that
uses the new ast_msg_data structure as its payload.  A channel
driver can queue a frame of that type when it receives a message
from outside.  A channel driver can use it for sending messages
by implementing the new send_text_data channel tech callback and
setting the new AST_CHAN_TP_SEND_TEXT_DATA flag in its tech
properties.  If set, the bridging/channel core will use it instead
of the original send_text callback and it will get the ast_msg_data
structure. Channel drivers aren't required to implement this.  Even
if a TEXT_DATA enabled driver uses it for incoming messages, an
outgoing channel driver that doesn't will still have it's send_text
callback called with only the message text just as before.

* res_pjsip_messaging now creates a TEXT_DATA frame for incoming
in-dialog messages and sets the "from" to the display name in the
"From" header, or if that's empty, the caller id name from the
channel.  This allows the chat client user to set a friendly name
for the chat.

* bridge_softmix now forwards TEXT and TEXT_DATA frames to all
participants (except the sender).

* A new function "ast_sendtext_data" was added to channel which
takes an ast_msg_data structure and calls a channel's
send_text_data callback, or if that's not defined, the original
send_text callback.

* bridge_channel now calls ast_sendtext_data for TEXT_DATA frame
types and ast_sendtext for TEXT frame types.

* chan_pjsip now uses the "from" name in the ast_msg_data structure
(if it exists) to set the "From" header display name on outgoing text
messages.

Change-Id: Idacf5900bfd5f22ab8cd235aa56dfad090d18489

7 years agoutils/pval: Add -lBlocksRuntime for compiler clang conditionally.
Alexander Traud [Tue, 17 Apr 2018 12:09:46 +0000 (14:09 +0200)] 
utils/pval: Add -lBlocksRuntime for compiler clang conditionally.

ASTERISK-27809

Change-Id: I930b364a33d54cc08dedfcd5bb45f7e83242f134

7 years agochan_vpb: Avoid GNU old-style field designator extension.
Alexander Traud [Tue, 17 Apr 2018 10:31:52 +0000 (12:31 +0200)] 
chan_vpb: Avoid GNU old-style field designator extension.

clang 6.0 warned about this. Beside that, this change removes the used variable
'desc'.

ASTERISK-27808

Change-Id: Ia26bdcc0a562c058151814511cfcf70ecafa595b

7 years agoutils: Add ast_assert_return
George Joseph [Fri, 13 Apr 2018 20:17:36 +0000 (14:17 -0600)] 
utils:  Add ast_assert_return

Similar to pjproject's PJ_ASSERT_RETURN macro, this one will do the
following...

If the assert passes... NoOp

If the assert fails and AST_DEVMODE is defined, execute ast_assert()
then, if DO_CRASH isn't set, return from the calling function with
the supplied value.

If the assert fails and AST_DEVMODE is not defined, return from the
calling function with the supplied value.

The macro will execute a return without a value if one isn't suppled.

Change-Id: I0003844affeab550d5ff5bca7aa7cf8a559b873e

7 years agoMerge "pjsip_scheduler.c: Add ability to trace scheduled tasks." into 13
Jenkins2 [Mon, 16 Apr 2018 12:00:21 +0000 (07:00 -0500)] 
Merge "pjsip_scheduler.c: Add ability to trace scheduled tasks." into 13

7 years agoMerge "res_pjsip.c: Split ast_sip_push_task_synchronous() to fit expectations." into 13
Jenkins2 [Mon, 16 Apr 2018 11:46:30 +0000 (06:46 -0500)] 
Merge "res_pjsip.c: Split ast_sip_push_task_synchronous() to fit expectations." into 13

7 years agoMerge "pjsip_scheduler.c: Fix some corner cases." into 13
Jenkins2 [Mon, 16 Apr 2018 11:39:35 +0000 (06:39 -0500)] 
Merge "pjsip_scheduler.c: Fix some corner cases." into 13

7 years agores_musiconhold: Don't restart MOH from beginning after announcement.
Ben Ford [Fri, 13 Apr 2018 19:32:48 +0000 (14:32 -0500)] 
res_musiconhold: Don't restart MOH from beginning after announcement.

This reverts a problem introduced by the fix for ASTERISK_24329.
Now, when an announcement is played while waiting in a queue, music on
hold will not restart from the beginning of the sound file and will
instead pick up where it left off. However, the incorrect behavior in
ASTERISK_24329 is now present again; if an announcement X seconds
long is played when music on hold starts, music on hold will start X
seconds into the file.

ASTERISK-27774 #close
Reported by: lvl

Change-Id: I86b2885ee7063268f9b9747eddb788336ade989b

7 years agopjsip_scheduler.c: Add ability to trace scheduled tasks.
Richard Mudgett [Wed, 28 Mar 2018 20:13:13 +0000 (15:13 -0500)] 
pjsip_scheduler.c: Add ability to trace scheduled tasks.

When a scheduled task is created you can pass in the
AST_SIP_SCHED_TASK_TRACK flag.  This new flag causes scheduling events to
be logged.

Change-Id: I91967eb3d5a220915ce86881a28af772f9a7f56b

7 years agores_pjsip.c: Split ast_sip_push_task_synchronous() to fit expectations.
Richard Mudgett [Tue, 27 Mar 2018 16:04:42 +0000 (11:04 -0500)] 
res_pjsip.c: Split ast_sip_push_task_synchronous() to fit expectations.

ast_sip_push_task_synchronous() did not necessarily execute the passed in
task under the specified serializer.  If the current thread is any
registered pjsip thread then it would execute the task immediately instead
of under the specified serializer.  Reentrancy issues could result if the
task does not execute with the right serializer.

The original reason ast_sip_push_task_synchronous() checked to see if the
current thread was a registered pjsip thread was because of a deadlock
with masquerades and the channel technology's fixup callback
(ASTERISK_22936).  A subsequent masquerade deadlock fix (ASTERISK_24356)
involving call pickups avoided the original deadlock situation entirely.
The PJSIP channel technology's fixup callback no longer needed to call
ast_sip_push_task_synchronous().

However, there are a few places where this unexpected behavior is still
required to avoid deadlocks.  The pjsip monitor thread executes callbacks
that do calls to ast_sip_push_task_synchronous() that would deadlock if
the task were actually pushed to the specified serializer.  I ran into one
dealing with the pubsub subscriptions where an ao2 destructor called
ast_sip_push_task_synchronous().

* Split ast_sip_push_task_synchronous() into
ast_sip_push_task_wait_servant() and ast_sip_push_task_wait_serializer().
ast_sip_push_task_wait_servant() has the old behavior of
ast_sip_push_task_synchronous().  ast_sip_push_task_wait_serializer() has
the new behavior where the task is always executed by the specified
serializer or a picked serializer if one is not passed in.  Both functions
behave the same if the current thread is not a SIP servant.

* Redirected ast_sip_push_task_synchronous() to
ast_sip_push_task_wait_servant() to preserve API for released branches.

ASTERISK_26806

Change-Id: Id040fa42c0e5972f4c8deef380921461d213b9f3

7 years agopjsip_scheduler.c: Fix some corner cases.
Richard Mudgett [Thu, 22 Mar 2018 00:43:21 +0000 (19:43 -0500)] 
pjsip_scheduler.c: Fix some corner cases.

* Fix the periodic interval wander because it may take significant time
between the sched thread queueing the task in the serializer and the
serializer actually executing the task.  The time it takes to actually
execute the task was already taken into account.

* Pass a schtd ref to the serializer when we queue a scheduled task on
the serializer.  We don't want it going away on us while it is in the
serializer queue.

* Skip the scheduled task if the task was canceled between queueing the
task to the serializer and the serializer actually executing the task.

* Reorder struct ast_sip_sched_task to avoid unnecessary padding.  Removed
task_id and added next_periodic.

* Hold a ref to the passed in serializer so the serializer cannot go away
on the scheduled task.

ASTERISK_26806

Change-Id: I6c8046b75f6953792c8c30e55b836a4291143f24

7 years agopjsip_scheduler.c: Sort "pjsip show scheduled_tasks" output.
Richard Mudgett [Fri, 23 Mar 2018 00:09:02 +0000 (19:09 -0500)] 
pjsip_scheduler.c: Sort "pjsip show scheduled_tasks" output.

* A side benefit is that the scheduled tasks are not completely blocked
while the CLI command executes.

* Adjusted the "Task Name" column width to have more room for longer
names.

Change-Id: Iec64aa463ee8b10eef90120e00c38b1fb444087e

7 years agoMerge "res_pjsip_notify.c: enable in-dialog NOTIFY" into 13
Jenkins2 [Thu, 12 Apr 2018 19:57:33 +0000 (14:57 -0500)] 
Merge "res_pjsip_notify.c: enable in-dialog NOTIFY" into 13

7 years agoMerge "pjsip_scheduler.c: Fix ao2 usage errors." into 13
Jenkins2 [Thu, 12 Apr 2018 15:10:28 +0000 (10:10 -0500)] 
Merge "pjsip_scheduler.c: Fix ao2 usage errors." into 13

7 years agoMerge "Build System: Strip '-std=c99' from CFLAGS provided by libraries." into 13
Jenkins2 [Thu, 12 Apr 2018 14:43:14 +0000 (09:43 -0500)] 
Merge "Build System: Strip '-std=c99' from CFLAGS provided by libraries." into 13

7 years agocdr_mysql: Compile error because MYSQL_PORT definition is missing
Evandro Cesar Arruda [Mon, 2 Apr 2018 20:59:29 +0000 (17:59 -0300)] 
cdr_mysql: Compile error because MYSQL_PORT definition is missing

If it is not defined, it will add MYSQL_PORT definition. After some
research on MySQL/MariaDB development tree, I couldn't find any reference
to MYSQL_PORT definition in include files.

ASTERISK-27782 #close

Change-Id: Ieee56c836fc2e8bd021c456145bba04c6068bb77

7 years agores_pjsip_session: Rewrite o= with external_media_address.
Chris-Savinovich [Tue, 10 Apr 2018 01:00:37 +0000 (21:00 -0400)] 
res_pjsip_session: Rewrite o= with external_media_address.

It now appends the external IP address on the
o= line of the SDP packet.  The decision was made to write
the numeric IP address as opposed to the RFC that states
the FQDN should be used if and when available.  We believe
the usage of literal IP address will help avoid
potential problems.

ASTERISK-27614 #close

Change-Id: I84f3360f3606b8c4e8d161edb228799ec0b8a302

7 years agores_pjsip_notify.c: enable in-dialog NOTIFY
Nathan Bruning [Thu, 22 Feb 2018 18:18:48 +0000 (19:18 +0100)] 
res_pjsip_notify.c: enable in-dialog NOTIFY

This patch adds support to send in-dialog SIP NOTIFY commands on
chan_pjsip channels, similar to the functionality recently added
for chan_sip (ASTERISK_27461).

This extends res_pjsip_notify to allow for in-dialog messages.

ASTERISK-27697

Change-Id: If7f3151a6d633e414d5dc319d5efc1443c43dd29

7 years agoMerge "res_pjsip_refer/chan_sip: Fix INVITE with replaces transfer to ConfBridge...
Jenkins2 [Wed, 11 Apr 2018 12:03:19 +0000 (07:03 -0500)] 
Merge "res_pjsip_refer/chan_sip: Fix INVITE with replaces transfer to ConfBridge" into 13

7 years agoMerge "chan_sip.c: Fix INVITE with replaces channel ref leak." into 13
Jenkins2 [Tue, 10 Apr 2018 14:58:22 +0000 (09:58 -0500)] 
Merge "chan_sip.c: Fix INVITE with replaces channel ref leak." into 13