Commit Graph

29010 Commits

Author SHA1 Message Date
kkm
e12fb3ffc1 make_build_h: handle backslashes in external strings
LikewiseOpen creates user names with a backslash in them. A gentle
massage with sed(1) allows such strings to be inserted into build.h
properly quoted. I am also adding the same for host name and other
strings used in the script that are more or less user-controlled.

ASTERISK-26754

Change-Id: Iac5ef2b67a68ee58f35ddbf86bb818ba6eabecae
2017-01-26 21:17:11 -06:00
kkm
7eaaa8bedc ast_careful_fwrite to support EPIPE gracefully
When a reading end of the network socket is closed by an AMI manager,
the EPIPE is signaled when writing to our end, resulting in the
spurious log error message

  ast_careful_fwrite: fwrite() returned error: Broken pipe

Previously EPIPE was handled in ast_carefulwrite() a few lines above,
but not in this function.

ASTERISK-26753

Change-Id: I6a67335cd6526608bb9b78f796c626b1677664b8
2017-01-26 21:08:54 -06:00
kkm
4ae2ff5f21 app_queue: Fix queues randomly disappearing on reload
With 500+ queues and a reload every minute, a random queue disappears
upon reload. The cause is mususe of the 'dead' flag. Namely, all queues
were marked dead up front, and then "resurrected" by dropping this flag
for those found in the configuration. But a queue marked dead can be
removed also when control leaves the app entry point on a PBX thread.

With this change, the queue is marked only not found, and at the end of
reload only the queues that are still not found are actually marked as
dead, so the dead flag is never reset, and set only on positively dead
queues.

ASTERISK-26755

Change-Id: I3a4537aec9eb8d8aeeaa0193407e3523feb004bf
2017-01-26 20:20:55 -06:00
zuul
75ef430f2f Merge "PJPROJECT logging: Fix detection of max supported log level." into 14 2017-01-26 18:49:44 -06:00
zuul
cac5ee2517 Merge "ari: Implement 'debug all' and request/response logging" into 14 2017-01-26 18:46:19 -06:00
George Joseph
23e5fd709a Merge "Add notes about embedded ast_frame structs holding a format ref." into 14 2017-01-26 16:07:29 -06:00
George Joseph
3985126a53 Merge "T.140: Fix format ref and memory leaks." into 14 2017-01-26 16:07:02 -06:00
George Joseph
420b10b00e Merge "res_musiconhold.c: Fix format ref leak when parsing MOH config class." into 14 2017-01-26 16:05:31 -06:00
George Joseph
1dd2920ec8 Merge "frame.c: Fix off-nominal format ref leaks." into 14 2017-01-26 16:04:53 -06:00
Joshua Colp
66bed4cc84 res_pjsip_endpoint_identifier_ip: Fix memory leak of hosts when resolving.
This change adds a missing unreference of the hostname when resolving and
also cleans up the iterator.

ASTERISK-26735

Change-Id: Ic012ebaf3d89e714eec340b7b0c5e63c66af857a
2017-01-26 10:59:06 -06:00
Joshua Colp
b331cb84d5 Merge "res_pjsip_endpoint_identifier_ip: Ensure error defaults to 0." into 14 2017-01-26 07:48:25 -06:00
George Joseph
0cdd2f120e Merge "astobj2.c: Add excessive ref count trap." into 14 2017-01-26 07:28:11 -06:00
Mark Michelson
e9ae110c1c Add reload options to CLI/AMI stale object commands.
Marking an object as stale in a memory cache is supposed to prime the
cache so that the next time the item is retrieved, the stale item is
deleted from the cache and a background task is run to re-populate the
cache with a fresh version of the object.

The problem is, there are some object types out there for which there is
no natural reason that they would be retrieved from the backend with any
regularity. Outbound PJSIP registrations are a good example of this. At
startup, they are read, and an object-specific state is created that
refers to the initially-retrieved object for all time.

Adding the "reload" option to the CLI/AMI commands gives the cache the
opportunity to manually re-retrieve the object from the backend, both
storing the new object in the cache and applying the new object's
configuration to the module that uses that object.

Change-Id: Ieb1fe7270ceed491f057ec5cbf0e097bde96c5c8
2017-01-25 17:43:48 -06:00
zuul
4a6f5fa595 Merge "main/app.c: Memory corruption from early format destruction." into 14 2017-01-25 15:01:37 -06:00
George Joseph
37a4260ffe Merge "chan_oss.c: Fix format ref leak in oss_read()." into 14 2017-01-25 13:50:34 -06:00
Richard Mudgett
89221a6628 T.140: Fix format ref and memory leaks.
* channel.c:ast_sendtext(): Fix T.140 SendText memory leak.

* format_compatibility.c: T.140 RED and T.140 were swapped.

* res_rtp_asterisk.c:rtp_red_init(): Fix ast_format_t140_red ref leak.

* res_rtp_asterisk.c:rtp_red_init(): Fix data race after starting periodic
scheduled red_write().

* res_rtp_asterisk.c: Some other minor misc tweaks.

Change-Id: Ifa27a2e0f8a966b1cf628607c86fc4374b0b88cb
2017-01-25 13:46:34 -06:00
zuul
3837e994d9 Merge "stasis_bridge.c: Fix off-nominal stasis control ref leak." into 14 2017-01-25 13:39:21 -06:00
George Joseph
330d468e55 Merge "pjproject_bundled: Fix setting max log level" into 14 2017-01-24 22:29:45 -06:00
George Joseph
e6957f561c Merge "res_pjsip_pubsub.c: Implement "pjsip show subscriptions" commands." into 14 2017-01-24 15:47:25 -06:00
Joshua Colp
60e54d69b9 res_pjsip_endpoint_identifier_ip: Ensure error defaults to 0.
When configuring a match using a netmask the error variable was
not defaulting to 0. For some people this would cause the code
to think an error occurred when adding the match when in reality
it added perfectly fine.

ASTERISK-26693

Change-Id: I850c250813742bddde65c84e739093c9e01dfe56
2017-01-24 15:41:27 -06:00
Richard Mudgett
ebb78c5b24 astobj2.c: Add excessive ref count trap.
Change-Id: I32e6a589cf9009450e4ff7cb85c07c9d9ef7fe4a
2017-01-24 14:15:03 -06:00
Richard Mudgett
5db078273d main/app.c: Memory corruption from early format destruction.
* make_silence() created a malloced silence slin frame without adding a
slin format ref.  When the frame is destroyed it will unref the slin
format that never had a ref added.  Memory corruption is expected to
follow.

* Simplified and fixed counting the number of samples in a frame list for
make_silence().

* Eliminated an unnecessary RAII_VAR associated with the make_silence()
frame.

Change-Id: I47de3f9b92635b7f8b4d72309444d6c0aee6f747
2017-01-24 14:04:51 -06:00
Richard Mudgett
d73fed119d frame.c: Fix off-nominal format ref leaks.
* ast_frisolate() could leak frame format refs on allocation
failures.

* Similified code in ast_frisolate() and code used by
ast_frisolate().

Change-Id: I79566d4d36b3d7801bf0c8294fcd3e9a86a2ed6d
2017-01-24 14:02:39 -06:00
Richard Mudgett
7206f5acd8 stasis_bridge.c: Fix off-nominal stasis control ref leak.
Change-Id: Ib17218343a6596832060180e19386da9df150ac8
2017-01-24 13:59:20 -06:00
Richard Mudgett
c5713081f4 res_musiconhold.c: Fix format ref leak when parsing MOH config class.
Change-Id: Ica8e8e2ce7604c2c61ec55bef07dc675361d2ea5
2017-01-24 13:55:12 -06:00
Richard Mudgett
7f21d12d2d chan_oss.c: Fix format ref leak in oss_read().
Change-Id: I0a5d56c7dcf327d60f86a4c25a23571733709fd0
2017-01-24 13:39:15 -06:00
Richard Mudgett
890bd1febf Add notes about embedded ast_frame structs holding a format ref.
mod_format.h: Note ast_filestream.fr holds a format ref.

translate.h: Note ast_trans_pvt.f holds a format ref.

Change-Id: I86bda354d725207b41e08920355d7c31b2d7f749
2017-01-24 13:37:36 -06:00
Joshua Colp
3ddf7da3a7 Merge "Free endpoint ACLs when destroying PJSIP endpoints." into 14 2017-01-24 12:45:11 -06:00
Richard Mudgett
b43cb30d7b PJPROJECT logging: Fix detection of max supported log level.
The mechanism used for detecting the maximum log level compiled into the
linked pjproject did not work.  The API call simply stores the requested
level into an integer and does no range checking.  Asterisk was assuming
that there was range checking and limited the new value to the allowable
range.  To get the actual maximum log level compiled into the linked
pjproject we need to get and save off the initial set log level from
pjproject.  This is the maximum log level supported.

* Get and save off the initial log level setting before altering it to the
desired level on startup.  This has to be done by a macro rather than
calling a core function to avoid incorrectly linking pjproject.

* Split the initial log level warning messages to warn if the linked
pjproject cannot support the requested startup level and if it is too low
to get the pjproject buildopts for "pjproject show buildopts".

* Adjust the CLI "pjproject set log level" to check the saved max log
level and to generate normal output messages instead of a warning message.

ASTERISK-26743 #close

Change-Id: I40aa76653e2a1dece66c3f8734594b4f0471cfb4
2017-01-24 11:25:11 -06:00
Tzafrir Cohen
c06d9d7717 tests: use datadir for sound files
Some (voicemail-related) tests API symlinks beep.gsm and other files
from ast_config_AST_VAR_DIR. It should use ast_config_AST_DATA_DIR.

ASTERISK-26740 #close

Change-Id: Id49c56fb9e16df64b1a2b829693ca7601252df89
2017-01-24 08:35:07 -06:00
Tzafrir Cohen
568b349930 test_voicemail_api: order of params to VERIFY macros
Fix order of parameters in calls to VM_API_INT_VERIFY and
VM_API_STRING_VERIFY

ASTERISK-26739 #close

Change-Id: I30dc6b36893aadad6012be3f16f93aa5720870d6
Note: status: builds. Not tested any further.
2017-01-24 08:34:28 -06:00
George Joseph
6f688fd0e9 Merge "res_pjsip_endpoint_identifier_ip: Read settings before resolving." into 14 2017-01-24 07:06:34 -06:00
Richard Mudgett
5d6469b209 res_pjsip_pubsub.c: Implement "pjsip show subscriptions" commands.
ASTERISK-23828 #close

Change-Id: Ifb8a3b61f447aedc58a8e6b36a810f7566018567
2017-01-23 18:06:55 -06:00
Mark Michelson
27c7d6d644 Free endpoint ACLs when destroying PJSIP endpoints.
If endpoint ACLs were specified, they were not being freed
when endpoints were destroyed. On systems with realtime endpoints, this
could add up quickly since each DB lookup would allocate the ACL without
freeing it.

ASTERISK-26731 #close
Reported by Ustinov Artem

Change-Id: Ie1f8bf5b7a0de628c975beba01e69c56893331ad
2017-01-23 16:22:45 -06:00
George Joseph
6c7dd69755 Merge "LISTFILTER: Remove outdated ERROR message." into 14 2017-01-23 15:05:39 -06:00
George Joseph
0a60bd8dd9 Merge "res_pjsip_pubsub.c: Fix incorrect message string wrapping." into 14 2017-01-23 15:00:50 -06:00
George Joseph
1d890874f3 ari: Implement 'debug all' and request/response logging
The 'ari set debug' command has been enhanced to accept 'all' as an
application name.  This allows dumping of all apps even if an app
hasn't registered yet.  To accomplish this, a new global_debug global
variable was added to res/stasis/app.c and new APIs were added to
set and query the value.

'ari set debug' now displays requests and responses as well as events.
This required refactoring the existing debug code.

* The implementation for 'ari set debug' was moved from stasis/cli.{c,h}
  to ari/cli.{c,h}, and stasis/cli.{c,h} were deleted.
* In order to print the body of incoming requests even if a request
  failed, the consumption of the body was moved from the ari stubs
  to ast_ari_callback in res_ari.c and the moustache templates were
  then regenerated.  The body is now passed to ast_ari_invoke and then
  on to the handlers.  This results in code savings since that template
  was inserted multiple times into all the stubs.

An additional change was made to the ao2_str_container implementation
to add partial key searching and a sort function.  The existing cli
code assumed it was already there when it wasn't so the tab completion
was never working.

Change-Id: Ief936f747ce47f1fb14035fbe61152cf766406bf
2017-01-23 10:23:23 -07:00
Joshua Colp
2974c83bcc Merge "res_pjsip_pubsub.c: Fix AMI event list counts." into 14 2017-01-23 11:09:37 -06:00
George Joseph
da5e8b177c pjproject_bundled: Fix setting max log level
An earlier attempt to prevent pjsua from spitting out an extra 6795
lines of debug output every time the testsuite called it was also
turning off the ability for asterisk to output debug info when it
needed to.  This patch reverts the earlier fix and instead adds
a pjproject patch that sets the startup log level to 1 for pjsua
pjsystest and the pjsua python binding.  This is an asterisk-only
patch that does not affect pjproject functionality and will not be
submitted upstream.

Change-Id: I347a8b58b2626f2906ccfc1d339e907627a0c9e8
2017-01-23 10:32:19 -06:00
Joshua Colp
74577cf32d res_pjsip_endpoint_identifier_ip: Read settings before resolving.
An option has been added, srv_lookups, which controls whether
SRV lookups are performed on the provided match hosts or not.
It was possible for this option to be applied after resolution
had already happened.

This change makes it so hosts are stored away, settings are read
and applied, and then resolution is done. This ensures that no
matter the ordering the srv_lookups option is in effect.

ASTERISK-26735

Change-Id: I750378cb277be0140f8c5539450270afbfc43388
2017-01-23 10:10:18 -06:00
zuul
dd92feb7fd Merge "res_pjsip_pubsub.c: Eliminate trivial SCOPED_LOCK usage." into 14 2017-01-23 10:04:49 -06:00
Joshua Colp
4b59025003 Merge "res_pjsip: alloca can never fail." into 14 2017-01-23 06:37:53 -06:00
Richard Mudgett
d0c508d53e LISTFILTER: Remove outdated ERROR message.
Feeding LISTFILTER an empty variable results in an invalid ERROR message.
Earlier changes made the message useless because we can no longer tell if
the variable is empty or does not exist.  It is valid to try to remove a
value from an empty list just as it is valid to try to remove a value that
is not in a non-empty list.

* Removed the outdated ERROR message.

* Added more test cases to the LISTFILTER unit test.

Change-Id: Ided9040e6359c44a335ef54e02ef5950a1863134
2017-01-22 17:56:00 -06:00
zuul
eef750d129 Merge "debug_utilities: Create ast_loggrabber" into 14 2017-01-20 14:24:34 -06:00
Richard Mudgett
93fcb615ba res_pjsip_pubsub.c: Fix AMI event list counts.
Fix the AMI PJSIPShowSubscriptionsInbound, PJSIPShowSubscriptionsOutbound,
and PJSIPShowResourceLists actions event counts.  The reported counts may
not necessarily be accurate depending on what happens.

The subscriptions count would be wrong if Asterisk ever has outbound
subscriptions.

The resource list count could be wrong if a list were added or removed
during the AMI action being processed.

Change-Id: I4344301827523fa174960a42c413fd19abe4aed5
2017-01-20 12:39:29 -06:00
Richard Mudgett
33c3d3c9dd res_pjsip_pubsub.c: Fix incorrect message string wrapping.
Change-Id: Id771e6fe56d89ce365ddcbb423f820af97211120
2017-01-20 12:37:07 -06:00
Richard Mudgett
dc42c1ffff res_pjsip_pubsub.c: Eliminate trivial SCOPED_LOCK usage.
Change-Id: Ie0b69a830385452042fa19e7d267c6790ec6b6be
2017-01-20 12:33:41 -06:00
Richard Mudgett
f9be81fc32 res_pjsip: alloca can never fail.
Change-Id: Ia2a6158e5fdf311bc2a1c0c43417978de504b1f1
2017-01-20 12:30:54 -06:00
Joshua Colp
997d71f1ca Merge "abstract/fixed/adpative jitter buffer: disallow frame re-inserts" into 14 2017-01-20 12:19:58 -06:00
George Joseph
84aadd4e81 debug_utilities: Create ast_loggrabber
ast_loggrabber gathers log files from customizable search patterns,
optionally converts POSIX timestamps to a readable format and
tarballs the results.

Also a few tweaks were made to ast_coredumper.

Change-Id: I8bfe1468ada24c1344ce4abab7b002a59a659495
(cherry picked from commit c709152878)
2017-01-20 11:21:05 -06:00