Commit Graph

27759 Commits

Author SHA1 Message Date
Joshua Colp
cf223d2cad .lastclean: Update for 13.10.0 2016-07-21 09:49:38 -05:00
Joshua Colp
07af28131f realtime: Add database scripts for 13.10.0 2016-07-21 09:49:38 -05:00
Mark Michelson
af14215882 ChangeLog: Updated for 13.10.0-rc3 13.10.0-rc3 2016-07-14 12:52:01 -05:00
Mark Michelson
d456aa0519 Release summaries: Add summaries for 13.10.0-rc3 2016-07-14 12:51:48 -05:00
Mark Michelson
b3df380e56 Release summaries: Remove previous versions 2016-07-14 12:51:37 -05:00
Mark Michelson
ac5a6c8cad .version: Update for 13.10.0-rc3 2016-07-14 12:51:37 -05:00
Mark Michelson
d3c10e5de3 .lastclean: Update for 13.10.0-rc3 2016-07-14 12:51:37 -05:00
Mark Michelson
305a6dbc85 realtime: Add database scripts for 13.10.0-rc3 2016-07-14 12:51:37 -05:00
Richard Mudgett
25a42c176f res_pjsip: Fix statsd regression.
The ASTERISK-25904 change-id I8fad8aae9305481469c38d2146e1ba3a56d3108f
patch introduced several regressions when the newly created "Updated"
state goes out for each endpoint registration refresh.

1) It restarted any OPTIONS RTT ping cycle.

2) It would interfere with a currently active ping and throw off that
ping's resulting RTT calculation.

3) It cleared the RTT time each time the endpoint was refreshed.

4) The cleared RTT time was sent out as a statsd update each time.

5) It created two AMI events for each update.

* Revert the original patch and reimplement it.  Now the current contact
status state is re-sent instead of the state being momentarily toggled
every time the endpoint refreshes its registration.  The statsd events are
not created for the re-sent refresh because they are sent after every
OPTIONS ping.

ASTERISK-26160 #close
Reported by: Matt Jordan

Change-Id: Ie072be790fbb2a8f5c1c874266e4143fa31f66d1
2016-07-13 12:28:34 -05:00
Joshua Colp
21b5d56f39 func_odbc: Fix connection deadlock.
The func_odbc module was modified to ensure that the
previous behavior of using a single database connection
was maintained. This was done by getting a single database
connection and holding on to it. With the new multiple
connection support in res_odbc this will actually starve
every other thread from getting access to the database as
it also maintains the previous behavior of having only
a single database connection.

This change disables the func_odbc specific behavior if
the res_odbc module is running with only a single database
connection active. The connection is only kept for the
duration of the request.

ASTERISK-26177 #close

Change-Id: I9bdbd8a300fb3233877735ad3fd07bce38115b7f
2016-07-12 05:00:05 -05:00
Mark Michelson
9a8b4251b8 ChangeLog: Updated for 13.10.0-rc2 13.10.0-rc2 2016-07-05 11:07:22 -05:00
Mark Michelson
d579dce147 Release summaries: Add summaries for 13.10.0-rc2 2016-07-05 11:07:08 -05:00
Mark Michelson
486fbce3d5 Release summaries: Remove previous versions 2016-07-05 11:06:56 -05:00
Mark Michelson
fb6bd30291 .version: Update for 13.10.0-rc2 2016-07-05 11:06:56 -05:00
Mark Michelson
f6bd754584 .lastclean: Update for 13.10.0-rc2 2016-07-05 11:06:56 -05:00
Mark Michelson
40cd52de7e realtime: Add database scripts for 13.10.0-rc2 2016-07-05 11:06:56 -05:00
George Joseph
78dcdd3010 configure: Fix HAVE_PJSIP_EVSUB_GRP_LOCK not set with external pjproject
There was a typo in configure.ac preventing HAVE_PJSIP_EVSUB_GRP_LOCK
from getting set when using an external pjproject.

ASTERISK-26099 #close
Reported-by: Ross Beer

Change-Id: I709af70428e125fb5ccd44b171d25dd29141f0ae
2016-06-30 08:30:53 -05:00
George Joseph
1529e62f42 codecs: Fix ABI incompatibility created by adding format_name to ast_codec
Adding format_name even to the end of ast_codec caused issued with
binary codec modules because the pointer would be garbage in asterisk
when they registered.  So, the ast_codec structure was reverted and an
internal_ast_codec structure was created just for use in codec.c.  A new
internal-only API was also added (__ast_codec_register_with_format) so
that codec_builtin could register codecs with the format_name in a
separate parameter rather than in the ast_codec structure.

ASTERISK-26144 #close
Reported-by: Alexei Gradinari

Change-Id: I6df1b08f6a6ae089db23adfe1ebc8636330265ba
2016-06-29 09:01:22 -05:00
Mark Michelson
3c4b64351b ChangeLog: Updated for 13.10.0-rc1 13.10.0-rc1 2016-06-23 08:47:35 -05:00
Mark Michelson
62349ac1b4 Release summaries: Add summaries for 13.10.0-rc1 2016-06-23 08:42:48 -05:00
Mark Michelson
8da6ba4328 .version: Update for 13.10.0-rc1 2016-06-23 08:38:42 -05:00
Mark Michelson
170b85e3ae .lastclean: Update for 13.10.0-rc1 2016-06-23 08:38:42 -05:00
Mark Michelson
4af7049b8f realtime: Add database scripts for 13.10.0-rc1 2016-06-23 08:38:42 -05:00
zuul
73e2186195 Merge "res_fax: Fix reference leak in fax_v21_session_new." into 13 2016-06-22 21:50:19 -05:00
zuul
5a568df73d Merge "res_rtp_asterisk: Fix a self-comparison identified by gcc 6" into 13 2016-06-22 19:23:16 -05:00
zuul
b044195e31 Merge "chan_unistim: Fix memcpy in get_to_address" into 13 2016-06-22 18:50:52 -05:00
Joshua Colp
5a73c115c8 Merge "BuildSystem: Avoid obsolete warning with AC_FUNC_SETVBUF_REVERSED on autoconf." into 13 2016-06-22 17:26:01 -05:00
zuul
43612a84c8 Merge "Fix Alembic upgrades." into 13 2016-06-22 15:22:44 -05:00
zuul
08a4699367 Merge "res_pjproject.c: Replace inlined DEBUG_ATLEAST() with macro." into 13 2016-06-22 15:16:18 -05:00
Corey Farrell
3d904659ec res_fax: Fix reference leak in fax_v21_session_new.
fax_v21_session_new created a session details object but only released
the allocation reference during error conditions.  fax_session_new adds
it's own reference to details if needed so the caller is always
responsible for cleaning it's own reference.

ASTERISK-26141 #close

Change-Id: Ie7fc52a83b6596ce9ce2d5a2bd9f3e204f48fc88
2016-06-22 16:09:09 -04:00
zuul
dab39a6813 Merge "test_res_pjsip_scheduler: Add 'depends' on pjproject in MODULEINFO" into 13 2016-06-22 14:29:26 -05:00
George Joseph
48db4c2159 res_rtp_asterisk: Fix a self-comparison identified by gcc 6
gcc 6 caught a previously unidentified self-comparison in
ice_candidate_cmp.  Fixed it and re-ordered the predicates for better
short-circuiting.

ASTERISK-26140 #close

Change-Id: I3da713c568e24064430257b3502fbdafd35af7a7
2016-06-22 12:41:57 -06:00
George Joseph
bc69b03316 chan_unistim: Fix memcpy in get_to_address
A code block only enabled when HAVE_PKTINFO is not defined (FreeBSD)
was using a pointer to a pointer as the destination of a memcpy and a
'&' instead of '*' in the sizeof.

ASTERISK-26138 #close

Change-Id: Id4927ff256c0e470bdf7bcfc025146a2f656e708
2016-06-22 12:28:58 -06:00
Mark Michelson
1b79e2deff Fix Alembic upgrades.
A non-existent constraint was being referenced in the upgrade script.
This patch corrects the problem by removing the reference.

This patch fixes another realtime problem as well. Our Alembic scripts
store booleans as yes or no values. However, Sorcery tries to insert
"true" or "false" instead. This patch updates Sorcery to use "yes" and
"no"

ASTERISK-26128 #close

Change-Id: I366dbbf91418a9cb160b3ca74b0e59b5ac284bec
2016-06-22 12:21:11 -05:00
Alexander Traud
e30602587c BuildSystem: Avoid obsolete warning with AC_FUNC_SETVBUF_REVERSED on autoconf.
Removed the obsolete macro AC_FUNC_SETVBUF_REVERSED because Asterisk does not
support the platform SVR2 from the year 1987 anymore.

ASTERISK-26046

Change-Id: I28161b037feb2d29ab46ed20e785928460226c22
2016-06-22 10:58:25 -05:00
George Joseph
77da168e58 test_res_pjsip_scheduler: Add 'depends' on pjproject in MODULEINFO
Since the file was missing the depends on pjproject, it wasn't
picking up the pjproject related include path.  If there was no
system installed pjproject and pjproject-bundled was used, a compile
would fail because pjsip.h wasn't found.

ASTERISK-26139 #close

Change-Id: I2ee64a999051452bc198c4e2c168c70769cd3757
2016-06-22 09:51:14 -06:00
Torrey Searle
dfcd466bf0 res_rtp_asterisk: fix memory leak in dtls
ensure that cert bios get freed after creating the fingerprint

ASTERISK-26129 #close

Change-Id: I44d23aea07dce80176ca1ff877c5ace9452ef451
2016-06-22 02:22:22 -05:00
zuul
d155d82747 Merge "res_pjsip_pubsub: Address SEGV when attempting to terminate a subscription" into 13 2016-06-21 21:07:45 -05:00
Joshua Colp
6a2deb4d21 Merge "res_rtp_asterisk: Use latest DTLS version available by underlying platform." into 13 2016-06-21 19:49:20 -05:00
zuul
5280813846 Merge "res_pjsip_session: Handle race condition at shutdown with timer." into 13 2016-06-21 19:04:29 -05:00
Richard Mudgett
c982da0641 res_pjproject.c: Replace inlined DEBUG_ATLEAST() with macro.
Change-Id: I8799fb0a347ad76e747dafd0eacf1ea1086b9a8c
2016-06-21 17:57:58 -05:00
Joshua Colp
d19169396c Merge "PJSIP: provide transport type with received messages" into 13 2016-06-21 15:24:59 -05:00
George Joseph
6a568bcc66 res_pjsip_pubsub: Address SEGV when attempting to terminate a subscription
Occasionally under load we'll attempt to send a final NOTIFY on a
subscription that's already been terminated and a SEGV will occur
down in pjproject's evsub_destroy function.  This is a result of a
race condition between all the paths that can generate a notify
and/or destroy the underlying pjproject evsub object:

 * The client can send a SUBSCRIBE with Expires: 0.
 * The client can send a SUBSCRIBE/refresh.
 * The subscription timer can expire.
 * An extension state can change.
 * An MWI event can be generated.
 * The pjproject transaction timer (timer_b) can expire.

Normally when our pubsub_on_evsub_state is called with a terminate,
we push a task to the serializer and return at which point the dialog
is unlocked.  This is usually not a problem because the task runs
immediately and locks the dialog again.  When the system is heavily
loaded though, there may be a delay between the unlock and relock
during which another event may occur such as the subscription timer
or timer_b expiring, an extension state change, etc.  These may also
cause a terminate to be processed and if so, we could cause pjproject
to try to destroy the evsub structure twice.  There's no way for us to
tell that the evsub was already destroyed and the evsub's group lock
can't tolerate this and SEGVs.

The remedy is twofold.

 * A patch has been submitted to Teluu and added to the bundled
   pjproject which adds add/decrement operations on evsub's group lock.

 * In res_pjsip_pubsub:
   * configure.ac and pjproject-bundled's configure.m4 were updated
     to check for the new evsub group lock APIs.
   * We now add a reference to the evsub group lock when we create
     the subscription and remove the reference when we clean up the
     subscription.  This prevents evsub from being destroyed before
     we're done with it.
   * A state has been added to the subscription tree structure so
     termination progress can be tracked through the asyncronous tasks.
   * The pubsub_on_evsub_state callback has been split so it's not doing
     double duty.  It now only handles the final cleanup of the
     subscription tree.  pubsub_on_rx_refresh now handles both client
     refreshes and client terminates.  It was always being called for
     both anyway.
   * The serialized_on_server_timeout task was removed since
     serialized_pubsub_on_rx_refresh was almost identical.
   * Missing state checks and ao2_cleanups were added.
   * Some debug levels were adjusted to make seeing only off-nominal
     things at level 1 and nominal or progress things at level 2+.

ASTERISK-26099 #close
Reported-by: Ross Beer.

Change-Id: I779d11802cf672a51392e62a74a1216596075ba1
2016-06-21 12:47:36 -06:00
Alexander Traud
ef97911a1c res_rtp_asterisk: Use latest DTLS version available by underlying platform.
Do not use DTLSv1_method() but DTLS_method() when available in OpenSSL of the
underlying platform. This change enables DTLS 1.2 since OpenSSL 1.0.2, for
WebRTC (DTLS-SRTP via SIP-over-WebSockets). This change enables AEAD-based
cipher-suites.

ASTERISK-26130 #close

Change-Id: I41f24448d6d2953e8bdb97c9f4a6bc8a8f055fd0
2016-06-21 13:24:56 -05:00
Scott Griepentrog
69d58a1e37 PJSIP: provide transport type with received messages
The receipt of a SIP MESSAGE may occur over any transport including TCP
and TLS. When the message is received, the original URI is added to the
message in the field PJSIP_RECVADDR, but this is insufficient to ensure
a reply message can reach the originating endpoint. This patch adds the
PJSIP_TRANSPORT field populated with the transport type.

ASTERISK-26132 #close

Change-Id: I28c4b1e40d573a056c81deb213ecf53e968f725e
2016-06-21 10:56:12 -05:00
Alexander Traud
cbfa9f771e BuildSystem: Avoid obsolete warning with HELP_STRING on autoconf.
Some configure scripts used both AC_HELP_STRING and its replacement
AS_HELP_STRING. For consistency and to avoid obsolete warnings, those were
changed to AS_HELP_STRING.

ASTERISK-26046

Change-Id: I8aad4fd2bdee40aa2a31ce3339a1eb33ff4f5b0f
2016-06-21 08:14:19 -05:00
zuul
b0e71c6571 Merge "fix: memory leaks, resource leaks, out of bounds and bugs" into 13 2016-06-21 07:02:17 -05:00
zuul
9856b4afe0 Merge "app_voicemail.c: Fix IMAP compile error." into 13 2016-06-20 15:00:53 -05:00
Joshua Colp
ba0d9e7f7a res_pjsip_session: Handle race condition at shutdown with timer.
When shutting down res_pjsip_session will get unloaded before res_pjsip.
The act of unloading unregisters all the PJSIP services and sets
their module IDs to -1. In some cases it is possible for a timer to
occur after this happens which calls into res_pjsip_session. The
res_pjsip_session module can then try to get the session from the
INVITE session using the module ID. Since the module ID is now -1
this fails.

This change stores a copy of the module ID and uses it for the timer
callback scenario. If the module ID is -1 the callback immediately
returns but if the module ID is valid then it continues as normal.

This works as the original ID of the module is guaranteed to still
be valid when used with the INVITE session.

ASTERISK-26127 #close

Change-Id: I88df72525c4e9ef9f19c13aedddd3ac4a335c573
2016-06-20 16:21:49 -03:00
Richard Mudgett
c1512f4108 app_voicemail.c: Fix IMAP compile error.
Fix compile error introduced by the patch for
ASTERISK-26045

Change-Id: I5b02876266f2824f4cec2b54d6ff4db5de5778d3
2016-06-20 12:17:08 -05:00