9 years agoPrevent exhaustion of system resources through exploitation of event cache
Joshua Colp [Thu, 3 Jan 2013 15:40:21 +0000 (15:40 +0000)]
Prevent exhaustion of system resources through exploitation of event cache

This patch changes res_xmpp to no longer cache events under certain circumstances.

(issue ASTERISK-20175)
Reported by: Russell Bryant, Leif Madsen, Joshua Colp
Tested by: kmoore

Merged revisions 378411 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoPrevent crashes in res_xmpp when receiving large messages
Matthew Jordan [Thu, 3 Jan 2013 15:37:31 +0000 (15:37 +0000)]
Prevent crashes in res_xmpp when receiving large messages

Similar to r378287, res_xmpp was marshaling data read from an external source
onto the stack. For a sufficiently large message, this could cause a stack
overflow. This patch modifies res_xmpp in a similar fashion to res_jabber by
removing the stack allocation, as it was unnecessary.

(issue ASTERISK-20658)
Reported by: wdoekes

Merged revisions 378409 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoClean up app_mysql's application entry points to properly parse arguments
Matthew Jordan [Wed, 2 Jan 2013 22:19:32 +0000 (22:19 +0000)]
Clean up app_mysql's application entry points to properly parse arguments

When parsing arguments, application entry points should not attempt to
directly modify the parameters to the function. This patch properly duplicates
the passed in parameters before attempting to parse them.

(issue ASTERISK-20658)
Reported by: wdoekes
  issueA20658_sanitize_app_mysql.patch uploaded by wdoekes (license 5674)

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoPrevent crashes from occurring when reading from data sources with large values
Matthew Jordan [Wed, 2 Jan 2013 22:10:32 +0000 (22:10 +0000)]
Prevent crashes from occurring when reading from data sources with large values

When reading configuration data from an Asterisk .conf file or when pulling
data from an Asterisk RealTime backend, Asterisk was copying the data on the
stack for manipulation. Unfortunately, it is possible to read configuration
data or realtime data from some data source that provides a large blob of
characters. This could potentially cause a crash via a stack overflow.

This patch prevents large sets of data from being read from an ARA backend or
from an Asterisk conf file.

(issue ASTERISK-20658)
Reported by: wdoekes
Tested by: wdoekes, mmichelson
 * issueA20658_dont_process_overlong_config_lines.patch uploaded by wdoekes (license 5674)
 * issueA20658_func_realtime_limit.patch uploaded by wdoekes (license 5674)

Merged revisions 378375 from

Merged revisions 378376 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix AMI redirect action with two channels failing to redirect both channels.
Richard Mudgett [Wed, 2 Jan 2013 21:23:16 +0000 (21:23 +0000)]
Fix AMI redirect action with two channels failing to redirect both channels.

The AMI redirect action can fail to redirect two channels that are bridged
together.  There is a race between the AMI thread redirecting the two
channels and the bridge thread noticing that a channel is hungup from the

* Made the bridge wait for both channels to be redirected before exiting.

* Made the AMI redirect check that all required headers are present before
proceeding with the redirection.

* Made the AMI redirect require that any supplied ExtraChannel exist
before proceeding.  Previously the code fell back to a single channel
redirect operation.

(closes issue ASTERISK-18975)
Reported by: Ben Klang

(closes issue ASTERISK-19948)
Reported by: Brent Dalgleish
      jira_asterisk_19948_v11.patch (license #5621) patch uploaded by rmudgett
Tested by: rmudgett, Thomas Sevestre, Deepak Lohani, Kayode


Merged revisions 378356 from

Merged revisions 378358 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoPrevent exhaustion of system resources through exploitation of event cache
Matthew Jordan [Wed, 2 Jan 2013 18:11:59 +0000 (18:11 +0000)]
Prevent exhaustion of system resources through exploitation of event cache

Asterisk maintains an internal cache for devices in the event subsystem. The
device state cache holds the state of each device known to Asterisk, such that
consumers of device state information can query for the last known state for
a particular device, even if it is not part of an active call. The concept of
a device in Asterisk can include entities that do not have a physical
representation. One way that this occurred was when anonymous calls are allowed
in Asterisk. A device was automatically created and stored in the cache for
each anonymous call that occurred; this was possible in the SIP and IAX2
channel drivers and through channel drivers that utilized the
res_jabber/res_xmpp resource modules (Gtalk, Jingle, and Motif). These devices
are never removed from the system, allowing anonymous calls to potentially
exhaust a system's resources.

This patch changes the event cache subsystem and device state management to
no longer cache devices that are not associated with a physical entity.

(issue ASTERISK-20175)
Reported by: Russell Bryant, Leif Madsen, Joshua Colp
Tested by: kmoore
  event-cachability-3.diff uploaded by jcolp (license 5000)

Merged revisions 378303 from

Merged revisions 378320 from

Merged revisions 378321 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoResolve crashes due to large stack allocations when using TCP
Matthew Jordan [Wed, 2 Jan 2013 15:39:42 +0000 (15:39 +0000)]
Resolve crashes due to large stack allocations when using TCP

Asterisk had several places where messages received over various network
transports may be copied in a single stack allocation. In the case of TCP,
since multiple packets in a stream may be concatenated together, this can
lead to large allocations that overflow the stack.

This patch modifies those portions of Asterisk using TCP to either
favor heap allocations or use an upper bound to ensure that the stack will not
 * For SIP, the allocation now has an upper limit
 * For HTTP, the allocation is now a heap allocation instead of a stack
 * For XMPP (in res_jabber), the allocation has been eliminated since it was

Note that the HTTP portion of this issue was independently found by Brandon
Edwards of Exodus Intelligence.

(issue ASTERISK-20658)
Reported by: wdoekes, Brandon Edwards
Tested by: mmichelson, wdoekes
  ASTERISK-20658_res_jabber.c.patch uploaded by mmichelson (license 5049)
  issueA20658_http_postvars_use_malloc2.patch uploaded by wdoekes (license 5674)
  issueA20658_limit_sip_packet_size3.patch uploaded by wdoekes (license 5674)

Merged revisions 378269 from

Merged revisions 378286 from

Merged revisions 378287 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAdd UUID packages now required to configure
Andrew Latham [Tue, 1 Jan 2013 19:02:52 +0000 (19:02 +0000)]
Add UUID packages now required to configure

In ASTERISK-20726 UUID was added to Asterisk.  This commit is to add the dependancies to the install script

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoRevert 378248. I changed the logic of this function unitentionally, pointed out...
Sean Bright [Tue, 1 Jan 2013 17:10:42 +0000 (17:10 +0000)]
Revert 378248.  I changed the logic of this function unitentionally, pointed out by file.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoBail out early when building an ast_trans_pvt and the translator doesn't supply a...
Sean Bright [Tue, 1 Jan 2013 17:03:59 +0000 (17:03 +0000)]
Bail out early when building an ast_trans_pvt and the translator doesn't supply a 'newpvt'

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoEnsure chan_sip rejects encrypted streams without crypto info
Kinsey Moore [Mon, 31 Dec 2012 14:46:06 +0000 (14:46 +0000)]
Ensure chan_sip rejects encrypted streams without crypto info

This ensures that Asterisk rejects encrypted media streams (RTP/SAVP
audio and video) that are missing cryptographic keys and ensures that
the incoming SDP is consistent with RFC4568 as far as having a crypto
attribute present for any SAVP streams.


Merged revisions 378217 from

Merged revisions 378218 from

Merged revisions 378219 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoGive the causes[] a struct name.
Richard Mudgett [Thu, 20 Dec 2012 21:51:03 +0000 (21:51 +0000)]
Give the causes[] a struct name.

Merged revisions 378164 from

Merged revisions 378165 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAdd test events for time limit-related hangups
Kinsey Moore [Tue, 18 Dec 2012 17:48:36 +0000 (17:48 +0000)]
Add test events for time limit-related hangups

This patch adds hangup-related test events in order to support testing
of time-limited bridges. This aids in testing the S() and L() bridge

(issue SWP-4713)

Merged revisions 378119 from

Merged revisions 378120 from

Merged revisions 378121 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix potential double free when unloading a module.
Richard Mudgett [Mon, 17 Dec 2012 23:10:42 +0000 (23:10 +0000)]
Fix potential double free when unloading a module.

Merged revisions 378092 from

Merged revisions 378093 from

Merged revisions 378094 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoMake chan_local module references tied to local_pvt lifetime.
Richard Mudgett [Mon, 17 Dec 2012 23:02:54 +0000 (23:02 +0000)]
Make chan_local module references tied to local_pvt lifetime.

The chan_local module references were manually tied to the existence of
the ;1 and ;2 channel links.

* Made chan_local module references tied to the existence of the local_pvt
structure as well as automatically take care of the module references.

* Tweaked the wording of the local_fixup() failure warning message to make


Merged revisions 378088 from

Merged revisions 378089 from

Merged revisions 378090 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agochan_local: Parse dial string consistently.
Richard Mudgett [Mon, 17 Dec 2012 21:22:21 +0000 (21:22 +0000)]
chan_local: Parse dial string consistently.

* Fix local_alloc() unexpected limitation of exten and context length from
a combined length of 80 characters to a normal 80 characters each.

* Made local_alloc() and local_devicestate() parse the same way.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoMake symlink use a relative path.
Jason Parker [Mon, 17 Dec 2012 20:59:51 +0000 (20:59 +0000)]
Make symlink use a relative path.

This was causing issues when using DESTDIR, since the path to which the link
pointed is not likely to exist (and not useful to exist) on the target system.

(issue ASTNOW-284)

Merged revisions 378073 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agochan_local: Misc lock and ref tweaks.
Richard Mudgett [Mon, 17 Dec 2012 20:34:25 +0000 (20:34 +0000)]
chan_local: Misc lock and ref tweaks.

* awesome_locking() does not need to thrash the pvt lock as much.

* local_setoption() does not need to check for NULL pvt on cleanup since
it will never be NULL.

* Made ref the pvt before locking for consistency.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agochan_agent: Remove some duplicated code.
Richard Mudgett [Fri, 14 Dec 2012 22:45:03 +0000 (22:45 +0000)]
chan_agent: Remove some duplicated code.

No need to check for an agent twice.  Santa does that.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFeatures: BRIDGE_FEATURES variable automixmonitor support and use proper party
Jonathan Rose [Fri, 14 Dec 2012 22:34:18 +0000 (22:34 +0000)]
Features: BRIDGE_FEATURES variable automixmonitor support and use proper party

BRIDGE_FEATURES did not previously support the automixmonitor feature. Now it
does. In addition, the BRIDGE_FEATURES variable would not apply features to
the proper party based on whether the feature option letter was in caps or
in lowercase (both ways would apply it to the caller). Now uppercase applies
to the caller while lowercase applies to the callee (like with the dial option)

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoapp_queue: Revert bad ringinuse=no patch.
Richard Mudgett [Fri, 14 Dec 2012 21:35:44 +0000 (21:35 +0000)]
app_queue: Revert bad ringinuse=no patch.

With the option ringinuse=no set, the patch committed for ASTERISK-16115
causes non-SIP queue members to never be called because the device state
is checked after a channel is created to determine if the member is busy.
These queue members always get the "Member %s is busy, cannot dial"

Most channel drivers other than chan_sip use the default device state
handling.  The default device-state state is considered in use or unknown
if the channel exists or not respectively.

(closes issue ASTERISK-20801)
Reported by: rmudgett
      jira_asterisk_16115_revert_r370418_v1.8.patch (license #5621) patch uploaded by rmudgett

Merged revisions 378036 from

Merged revisions 378037 from

Merged revisions 378038 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoapp_queue: Make update_status() not return anything.
Richard Mudgett [Fri, 14 Dec 2012 20:22:36 +0000 (20:22 +0000)]
app_queue: Make update_status() not return anything.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix skinny to recognise vmexten in general section of conf
Damien Wedhorn [Fri, 14 Dec 2012 01:55:43 +0000 (01:55 +0000)]
Fix skinny to recognise vmexten in general section of conf

Fixup the vmexten so if globally set in general section will be honored by
chan_skinny. Also get rid of the 'global_' part of variable name to match

(closes issue ASTERISK-20790)
Reported by: snuffy
Tested by: snuffy, myself
    skinny-vm.diff uploaded by snuffy (license 5024)

Merged revisions 378010 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAdd g722 codec support to skinny
Damien Wedhorn [Fri, 14 Dec 2012 01:02:15 +0000 (01:02 +0000)]
Add g722 codec support to skinny

(closes issue ASTERISK-20788)
Reported by: snuffy
Tested by: snuffy, myself
    skinny-g722.diff uploaded by snuffy (license 5024)

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoconfbridge: Fix MOH on simultaneous user entry to a new conference.
Richard Mudgett [Thu, 13 Dec 2012 21:28:15 +0000 (21:28 +0000)]
confbridge: Fix MOH on simultaneous user entry to a new conference.

When two users entered a new conference simultaneously, one of the callers
hears MOH.  This happened if two unmarked users entered simultaneously and
also if a waitmarked and a marked user entered simultaneously.

* Created a confbridge internal MOH API to eliminate the inlined MOH
handling code.  Note that the conference mixing bridge needs to be locked
when actually starting/stopping MOH because there is a small window
between the conference join unsuspend MOH and actually joining the mixing

* Created the concept of suspended MOH so it can be interrupted while
conference join announcements to the user and DTMF features can operate.

* Suspend any MOH until the user is about to actually join the mixing
bridge of the conference.  This way any pre-join file playback does not
need to worry about MOH.

* Made post-join actions only play deferred entry announcement files.
Changing the user/conference state during that time is not protected or
controlled by the state machine.

(closes issue ASTERISK-20606)
Reported by: Eugenia Belova
Tested by: rmudgett


Merged revisions 377992 from

Merged revisions 377993 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoMinor fixes for chan_skinny
Damien Wedhorn [Thu, 13 Dec 2012 21:25:31 +0000 (21:25 +0000)]
Minor fixes for chan_skinny

Whitespace, change SUBSTATE_ONHOOK to correct SKINNY_ONHOOK and
correct len of 2 strcmp in skinny_setdebug(). (see opticron's review

Merged revisions 377991 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoMake generate_exchange_uuid() always return the passed ast_str pointer.
Sean Bright [Thu, 13 Dec 2012 21:20:32 +0000 (21:20 +0000)]
Make generate_exchange_uuid() always return the passed ast_str pointer.

I changed this code earlier to return NULL if it wasn't able to generate a UUID,
whereas the earlier code would always return the ast_str that was passed in.
Switch back to returning the ast_str, only set it to the empty string instead if
UUID generation fails.  We still do a validity check later which will catch this
and blow up if necessary.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFixed svn merge property breakage from r377986
David M. Lee [Thu, 13 Dec 2012 21:15:44 +0000 (21:15 +0000)]
Fixed svn merge property breakage from r377986

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix skinny debug tab completion
Damien Wedhorn [Thu, 13 Dec 2012 18:28:41 +0000 (18:28 +0000)]
Fix skinny debug tab completion

Review the syntax of the 'skinny debug' command to show more than
just 'show' for options to 'skinny debug' command.

(closes issue ASTERISK-20789)
Reported by: snuffy
Tested by: snuffy, myself
    skinny-debug.diff uploaded by snuffy (license 5024)

Merged revisions 377985 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoBail configure if it can't find libuuid.
David M. Lee [Thu, 13 Dec 2012 16:43:40 +0000 (16:43 +0000)]
Bail configure if it can't find libuuid.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoRemove compile time check HAVE_DEV_URANDOM.
Russell Bryant [Thu, 13 Dec 2012 16:18:52 +0000 (16:18 +0000)]
Remove compile time check HAVE_DEV_URANDOM.

The code was doing a runtime check, anyway.  The compile time check isn't
always valid (cross-compiling, packages).


git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoRe-add taskprocessor cleanup code that was removed by the UUID merge.
Mark Michelson [Thu, 13 Dec 2012 15:40:03 +0000 (15:40 +0000)]
Re-add taskprocessor cleanup code that was removed by the UUID merge.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoUse the UUID API to generate and validate UUIDs for res_calendar_exchange.
Sean Bright [Thu, 13 Dec 2012 15:37:55 +0000 (15:37 +0000)]
Use the UUID API to generate and validate UUIDs for res_calendar_exchange.

Currently the res_calendar_exchange module uses its own method of generating
UUIDs using ast_random().  Now that we have a UUID API we should use that

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoThe UUID commit removed changes made in res_clialiases.c
Mark Michelson [Thu, 13 Dec 2012 15:37:45 +0000 (15:37 +0000)]
The UUID commit removed changes made in res_clialiases.c

This puts back in the changes that are designed to work
around a memory leak fix in the CLI code.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFixed to look for proper uuid.h file
David M. Lee [Thu, 13 Dec 2012 15:24:22 +0000 (15:24 +0000)]
Fixed to look for proper uuid.h file

Introduced in r377846, the configure script was looking for uuid.h instead
of uuid/uuid.h.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoThis change adds a SIP peer configuration feature to allow the peer's
Brent Eagles [Thu, 13 Dec 2012 15:22:27 +0000 (15:22 +0000)]
This change adds a SIP peer configuration feature to allow the peer's
configured codecs to take precedence on an outgoing call.

This change introduces a new peer configuration property named
'ignore_requested_pref' that causes the requested codec to be ignored when
determining the preferred codec for an outgoing call leg. The consequence is
that Asterisk's usual efforts to prefer avoiding transcoding can be overridden
on a peer-by-peer basis where appropriate.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoEnsure Min-SE is included in outbound INVITEs
Kinsey Moore [Thu, 13 Dec 2012 14:28:57 +0000 (14:28 +0000)]
Ensure Min-SE is included in outbound INVITEs

Asterisk now includes Min-SE in outbound INVITEs when the value is not
90 (the default) and session timers are not disabled. This has the
effect of Asterisk following RFC4028 more closely with regard to 422
responses and preventing situations in which Asterisk would be forced
to temporarily accept a call to tear it down based on a Session-Expires
below the locally configured Min-SE.

(issue SWP-5051)
Reported-by: Kinsey Moore
Patch-by: Kinsey Moore

Merged revisions 377946 from

Merged revisions 377947 from

Merged revisions 377948 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoIncremented EXTRA_SOUNDS_VERSION in sounds/Makefile to 1.4.12 for new Extra Sounds...
Rusty Newton [Wed, 12 Dec 2012 22:43:40 +0000 (22:43 +0000)]
Incremented EXTRA_SOUNDS_VERSION in sounds/Makefile to 1.4.12 for new Extra Sounds releases

See CHANGES-* files in English extra 1.4.12 tarballs for new sound prompts added.

(closes ASTERISK-20328)
Reported by: Matt Jordan
(closes AST-755)
Reported by: John Bigelow

Merged revisions 377922 from

Merged revisions 377923 from

Merged revisions 377924 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoConvert Dynamic Features Buffer To Use ast_str
Michael L. Young [Wed, 12 Dec 2012 04:43:18 +0000 (04:43 +0000)]
Convert Dynamic Features Buffer To Use ast_str

Currently, the buffer for the dynamic features list is set to a fixed size of
128.  If the list is bigger than that, it results in the dynamic feature(s) not
being recognized.

This patch changes the buffer from a fixed size to a dynamic one.

(closes issue ASTERISK-20680)
Reported by: Clod Patry
Tested by: Michael L. Young
                                     uploaded by Michael L. Young (license 5026)


git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix a potential deadlock in chan_sip during transfers.
Mark Michelson [Wed, 12 Dec 2012 00:02:31 +0000 (00:02 +0000)]
Fix a potential deadlock in chan_sip during transfers.

The issue comes from the fact that transfers may perform
a redirecting update on a channel. The issue is that lock
inversion between the channel and its tech_pvt occurs since
the channel lock is released during the transfer process.

The fix is to move when the redirecting update occurs to a
place where neither the tech_pvt or the channel is locked so
that the two can be locked in the proper order.

(closes issue ASTERISK-20708)
reported by Mark Michelson
ASTERISK-20708-3.patch uploaded by Mark Michelson (License #5049)

Tested by:
Tim Ringenbach at Asteria Solutions Group

Merged revisions 377910 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAdd test events necessary for bridging tests to be able to properly run.
Mark Michelson [Tue, 11 Dec 2012 22:42:11 +0000 (22:42 +0000)]
Add test events necessary for bridging tests to be able to properly run.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup CLI commands on exit for several files.
Richard Mudgett [Tue, 11 Dec 2012 22:03:23 +0000 (22:03 +0000)]
Cleanup CLI commands on exit for several files.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      unregister-cli-multiple-all.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377881 from

Merged revisions 377882 from

Merged revisions 377883 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAnd remove svnmerge-integrated property.
Mark Michelson [Tue, 11 Dec 2012 21:53:06 +0000 (21:53 +0000)]
And remove svnmerge-integrated property.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoRemove automerge properties.
Mark Michelson [Tue, 11 Dec 2012 21:47:53 +0000 (21:47 +0000)]
Remove automerge properties.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup udptl on exit.
Richard Mudgett [Tue, 11 Dec 2012 21:22:45 +0000 (21:22 +0000)]
Cleanup udptl on exit.

* Cleanup CLI commands on exit.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      udptl-shutdown-1_8-10.patch (license #5909) patch uploaded by Corey Farrell
      udptl-shutdown-11-trunk.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377847 from

Merged revisions 377848 from

Merged revisions 377849 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAdd UUID support to Asterisk.
Mark Michelson [Tue, 11 Dec 2012 21:04:45 +0000 (21:04 +0000)]
Add UUID support to Asterisk.

This provides a common API for dealing with unique identifiers.
The API provides methods to create, parse, copy, and stringify UUIDs.

An accompanying unit test is provided that tests all operations.

(closes issue ASTERISK-20726)
reported by Matt Jordan


git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix crash that can occur if CLI registration fails for an aliased command.
Mark Michelson [Tue, 11 Dec 2012 20:53:34 +0000 (20:53 +0000)]
Fix crash that can occur if CLI registration fails for an aliased command.

A recent memory leak fix in main/cli.c causes an ast_cli_entry's command
field to be freed and NULLed if ast_cli_register() fails. res_clialiases
was ignoring the return value of ast_cli_register() and was then passing
the NULL command off to a a hash function. This resulted in a crash.

The fix is not to ignore the erroneous return value. If ast_cli_register()
fails, then we do not continue trying to process the current alias.

Merged revisions 377840 from

Merged revisions 377842 from

Merged revisions 377843 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup taskprocessor on exit.
Richard Mudgett [Tue, 11 Dec 2012 20:46:23 +0000 (20:46 +0000)]
Cleanup taskprocessor on exit.

* Cleanup CLI commands on exit.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      taskprocessor-cleanup-1_8-11-trunk.patch (license #5909) patch uploaded by Corey Farrell
      taskprocessor-cleanup-10-only.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377837 from

Merged revisions 377838 from

Merged revisions 377839 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup pbx on exit.
Richard Mudgett [Tue, 11 Dec 2012 20:05:32 +0000 (20:05 +0000)]
Cleanup pbx on exit.

* Cleanup CLI commands on exit.

* Unreference hints and statecbs containers on exit.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      pbx-cleanup-1_8.patch (license #5909) patch uploaded by Corey Farrell
      pbx-cleanup-10.patch (license #5909) patch uploaded by Corey Farrell
      pbx-cleanup-11-trunk.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377806 from

Merged revisions 377807 from

Merged revisions 377808 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup logger on exit.
Richard Mudgett [Tue, 11 Dec 2012 02:44:53 +0000 (02:44 +0000)]
Cleanup logger on exit.

* Cleanup CLI commands, destroy verbosers and logchannels lists on exit.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      logger-cleanup-all.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377771 from

Merged revisions 377772 from

Merged revisions 377773 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup indications on exit.
Richard Mudgett [Tue, 11 Dec 2012 02:13:37 +0000 (02:13 +0000)]
Cleanup indications on exit.

* Made ast_unregister_indication_country() unlink the found tone zone
before selecting a new default_tone_zone to make it impossible to select
the tone zone being unregistered again.

* Ringcadence is no longer parsed twice in store_config_tone_zone().

* Cleanup CLI commands and destroy default_tone_zone on exit.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      indications-cleanup-all.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377740 from

Merged revisions 377741 from

Merged revisions 377742 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup event on exit.
Richard Mudgett [Tue, 11 Dec 2012 01:04:50 +0000 (01:04 +0000)]
Cleanup event on exit.

* Cleanup CLI commands on exit.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      event_shutdown-10-only.patch (license #5909) patch uploaded by Corey Farrell
      event_shutdown-1_8-11-trunk.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377708 from

Merged revisions 377709 from

Merged revisions 377710 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup dnsmgr on exit.
Richard Mudgett [Tue, 11 Dec 2012 00:37:01 +0000 (00:37 +0000)]
Cleanup dnsmgr on exit.

* Cleanup dnsmgr thread and CLI commands on exit.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      dnsmgr-cleanup-1_8.patch (license #5909) patch uploaded by Corey Farrell
      dnsmgr-cleanup-10-11-trunk.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377704 from

Merged revisions 377705 from

Merged revisions 377706 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoEnsure ReceiveFax provides a CED tone via T.38
Kinsey Moore [Mon, 10 Dec 2012 16:56:37 +0000 (16:56 +0000)]
Ensure ReceiveFax provides a CED tone via T.38

When using res_fax_digium, the T.38 CED tone was not being provided
properly which would cause some incoming faxes to fail. This was not an
issue with res_fax_spandsp since it does not strictly honor the
send_ced flag and sends the CED tone whenever receiving a T.38 fax.

(closes issue FAX-343)
Reported-by: Benjamin Tietz
Patch-by: Kinsey Moore

Merged revisions 377655 from

Merged revisions 377656 from

Merged revisions 377657 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoHandle Session-Expires less than local Min-SE in 200 OK
Kinsey Moore [Mon, 10 Dec 2012 14:45:52 +0000 (14:45 +0000)]
Handle Session-Expires less than local Min-SE in 200 OK

Ensure that a call is immediately torn down if a Session-Expires value
received in a 200 OK is less than the local Min-SE. This also prevents
Asterisk from allowing calls with Session-Expires below the
RFC4028-mandated minimum (90s).

(closes issue ASTERISK-20653)
Patch-by: Kinsey Moore

Merged revisions 377623 from

Merged revisions 377624 from

Merged revisions 377625 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAdd firmware information to CLI devices listing
Igor Goncharovskiy [Mon, 10 Dec 2012 07:03:48 +0000 (07:03 +0000)]
Add firmware information to CLI devices listing

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix codec mismatch
Igor Goncharovskiy [Mon, 10 Dec 2012 06:56:04 +0000 (06:56 +0000)]
Fix codec mismatch

Fix code to send in both rx and tx open stream messages correct codecs. Found that on phase 0/1 phones wrong codecs cause to no audio in some situations.

(issue ASTERISK-20183)

Merged revisions 377591 from

Merged revisions 377592 from

Merged revisions 377593 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoRemove trailing whitespaces in number from incoming redial list.
Igor Goncharovskiy [Mon, 10 Dec 2012 05:29:04 +0000 (05:29 +0000)]
Remove trailing whitespaces in number from incoming redial list.

Reported by: Igor Olhovskiy

Merged revisions 377577 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoImprove documentation by making all of the colors used readable,
Tilghman Lesher [Mon, 10 Dec 2012 01:41:50 +0000 (01:41 +0000)]
Improve documentation by making all of the colors used readable,
no matter what the background color is.

Dark blue on a black background is unreadable, as is yellow on a
light background.  This patch turns on the bright attribute for
colors when on a dark background and turns *off* the bright
attribute when the -W command line option is used (indicating a
_light_ background).  This ensures that text is readable in both

Patch by: tilghman

Merged revisions 377509 from

Merged revisions 377510 from

Merged revisions 377511 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoRemove some dead code and additionally handle a case that wasn't handled.
Tilghman Lesher [Mon, 10 Dec 2012 01:29:32 +0000 (01:29 +0000)]
Remove some dead code and additionally handle a case that wasn't handled.

Merged revisions 377487 from

Merged revisions 377504 from

Merged revisions 377505 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAdd missing support for "who hung up" to chan_motif.
Joshua Colp [Sun, 9 Dec 2012 01:23:44 +0000 (01:23 +0000)]
Add missing support for "who hung up" to chan_motif.

(closes issue ASTERISK-20671)
Reported by: Matt Jordan

Merged revisions 377462 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix order of SIP allow/disallow in MySQL contrib script.
Richard Mudgett [Sat, 8 Dec 2012 00:30:40 +0000 (00:30 +0000)]
Fix order of SIP allow/disallow in MySQL contrib script.

Using the contrib sippeers.sql script to create the sippeers MySQL table
would result in being unable to place calls if you set the disallow value
to all.

(closes issue ASTERISK-20756)
Reported by: Andre Luis
      sippeers.patch patch uploaded by Andre Luis

Merged revisions 377431 from

Merged revisions 377432 from

Merged revisions 377433 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoMALLOC_DEBUG: Only wait if we want atexit allocation dumps.
Richard Mudgett [Fri, 7 Dec 2012 23:45:15 +0000 (23:45 +0000)]
MALLOC_DEBUG: Only wait if we want atexit allocation dumps.

Merged revisions 377398 from

Merged revisions 377399 from

Merged revisions 377401 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agocodec_dahdi: Fix output of "transcoder show" CLI command.
Kinsey Moore [Fri, 7 Dec 2012 22:08:48 +0000 (22:08 +0000)]
codec_dahdi: Fix output of "transcoder show" CLI command.

In r306010 "Asterisk media architecture conversion - no more format
bitfields", the logic for incrementing encoders and decoders when
opening transcoder channels was changed without making the corresponding
change when decrementing encoder / decoder channels.  The result being
that when a channel was destroyed, codec_dahdi couldn't properly tell if
it was an encoder or decoder, and the default case is to assume it was a

This could result in negative numbers for decoders in use like in:
  VOIP6*CLI> transcoder show
  2/-2 encoders/decoders of 92 channels are in use.

(closes issue ASTERISK-19921)
Patch-by: Shaun Ruffell

Merged revisions 377382 from

Merged revisions 377383 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoconfbridge: Fix some resource leaks on conference teardown.
Richard Mudgett [Fri, 7 Dec 2012 00:00:39 +0000 (00:00 +0000)]
confbridge: Fix some resource leaks on conference teardown.

* Made destroy_conference_bridge() destroy a missed ast_mutex_t and ast_cond_t.

* Made join_conference_bridge() init the ast_mutex_t's and ast_cond_t so
destroy_conference_bridge() can destroy them unconditionally.

* Made join_conference_bridge() abort if the new conference could not be
added to the conferences container.

* Made leave_conference() discard any post-join actions if
join_conference_bridge() had to abort early.

* Made the join_conference_bridge() diagnostic messages better describe
what happened.

* Renamed leave_conference_bridge() to leave_conference() and made it only
take a conference user pointer.  The conference pointer was redundant.

* Made conf_bridge_profile_copy() use struct copy instead of memcpy().

* No need to lock the conference in start_conf_record_thread() since all
of the callers already have it locked.

Merged revisions 377354 from

Merged revisions 377355 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoRecorded merge of revisions 377340 from
Russell Bryant [Thu, 6 Dec 2012 17:29:13 +0000 (17:29 +0000)]
Recorded merge of revisions 377340 from

Add CLI tab completion to 'acl show'.

The 'acl show' CLI command allows you to show the details about a specific
named ACL in acl.conf.  This patch adds tab completion to the command.


git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoMinor code cleanup in named_acl.c.
Russell Bryant [Thu, 6 Dec 2012 15:13:37 +0000 (15:13 +0000)]
Minor code cleanup in named_acl.c.

This patch makes a few little cleanups to named_acl.c.  A couple non-public
functions were made static and an opening brace for a function was moved to
its own line, per the coding guidelines.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAdd CLI tab completion to 'acl show'.
Russell Bryant [Thu, 6 Dec 2012 15:06:47 +0000 (15:06 +0000)]
Add CLI tab completion to 'acl show'.

The 'acl show' CLI command allows you to show the details about a specific
named ACL in acl.conf.  This patch adds tab completion to the command.


git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix memory leak in 'manager show event' when command entered incorrectly
Matthew Jordan [Thu, 6 Dec 2012 14:26:13 +0000 (14:26 +0000)]
Fix memory leak in 'manager show event' when command entered incorrectly

When the CLI command 'manager show event' was run incorrectly and its usage
instructions returned, a reference to the event container was leaked. This
would prevent the container from being reclaimed when Asterisk exits. We now
properly decrement the count on the ao2 object using the nifty RAII_VAR macro.

Thanks to Russell for helping me stumble on this, and Terry for writing that
ridiculously helpful macro.

Merged revisions 377319 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agores_srtp: Fix a crash caused by srtp_dealloc on an already dealloced session
Jonathan Rose [Wed, 5 Dec 2012 17:17:06 +0000 (17:17 +0000)]
res_srtp: Fix a crash caused by srtp_dealloc on an already dealloced session

When srtp_create fails, the session may be dealloced or just not alloced. At
the same time though, the session pointer might not be set to NULL in this
process and attempting to srtp_dealloc it again will cause a segfault. This
patch checks for failure of srtp_create and sets the session pointer to NULL
if it fails.

(closes issue ASTERISK-20499)
Reported by: tootai

Merged revisions 377256 from

Merged revisions 377261 from

Merged revisions 377262 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix a SIP request memory leak with TLS connections.
Joshua Colp [Wed, 5 Dec 2012 16:51:58 +0000 (16:51 +0000)]
Fix a SIP request memory leak with TLS connections.

During the TLS re-work in chan_sip some TLS specific code was moved
into a separate function. This function operates on a copy of the
incoming SIP request. This copy was never deinitialized causing a
memory leak for each request processed.

This function is now given a SIP request structure which it can use
to copy the incoming request into. This reduces the amount of memory
allocations done since the internal allocated components are reused
between packets and also ensures the SIP request structure is
deinitialized when the TLS connection is torn down.

(closes issue ASTERISK-20763)
Reported by: deti

Merged revisions 377257 from

Merged revisions 377258 from

Merged revisions 377259 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoRemove init_framer(). It no longer does anything.
Richard Mudgett [Wed, 5 Dec 2012 02:23:10 +0000 (02:23 +0000)]
Remove init_framer(). It no longer does anything.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix registering core show codecs/codec CLI commands twice.
Richard Mudgett [Wed, 5 Dec 2012 02:20:57 +0000 (02:20 +0000)]
Fix registering core show codecs/codec CLI commands twice.

Merged revisions 377241 from

Merged revisions 377244 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoconfbridge: Fix several small issues.
Richard Mudgett [Wed, 5 Dec 2012 01:11:26 +0000 (01:11 +0000)]
confbridge: Fix several small issues.

* Made func_confbridge_helper() allow an empty value when setting options.
You previously could not Set(CONFBRIDGE(user,pin)=) and clear the
configured pin from the dialplan.

* Made func_confbridge_helper() handle its datastore better if multiple
threads attempt to set the first CONFBRIDGE option value on the channel.

* Made the func_confbridge_helper() only output one diagnostic message
concerning the option.

* Made the bridge video_mode able to repeatedly change in the config file
and CONFBRIDGE dialplan function.  The video_mode option values are an
enum and not independent of each other.

* Made handle_cli_confbridge_show_bridge_profile() better handle the
video_mode option.

* Simplified datastore handling code in conf_find_user_profile() and

(closes issue ASTERISK-20655)
Reported by: Birger "WIMPy" Harzenetter

Merged revisions 377227 from

Merged revisions 377228 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoconfbridge: Update online XML documentation.
Richard Mudgett [Tue, 4 Dec 2012 22:34:05 +0000 (22:34 +0000)]
confbridge: Update online XML documentation.

Merged revisions 377212 from

Merged revisions 377213 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAdd libuuid to install_prereq for Fedora.
Russell Bryant [Tue, 4 Dec 2012 13:01:23 +0000 (13:01 +0000)]
Add libuuid to install_prereq for Fedora.

I ran this script and my build failed.  pjproject requires this.

Merged revisions 377195 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup ast_run_atexits() atexits list.
Richard Mudgett [Mon, 3 Dec 2012 23:00:08 +0000 (23:00 +0000)]
Cleanup ast_run_atexits() atexits list.

* Convert atexits list to a mutex instead of a rd/wr lock.  The lock is
only write locked.

* Move CLI verbose Asterisk ending message to where AMI message is output
in really_quit() to avoid further surprises about using stuff already

(issue ASTERISK-20649)
Reported by: Corey Farrell

Merged revisions 377165 from

Merged revisions 377166 from

Merged revisions 377167 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup core main on exit.
Richard Mudgett [Mon, 3 Dec 2012 20:46:11 +0000 (20:46 +0000)]
Cleanup core main on exit.

* Cleanup time zones on exit.

* Make exit clean/unclean report consistent for AMI and CLI in

(issue ASTERISK-20649)
Reported by: Corey Farrell
      core-cleanup-1_8-10.patch (license #5909) patch uploaded by Corey Farrell
      core-cleanup-11-trunk.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377135 from

Merged revisions 377136 from

Merged revisions 377137 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup config cache on exit.
Richard Mudgett [Mon, 3 Dec 2012 19:33:06 +0000 (19:33 +0000)]
Cleanup config cache on exit.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      config-cleanup-all.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377104 from

Merged revisions 377105 from

Merged revisions 377106 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup CLI resources on exit and CLI command registration errors.
Richard Mudgett [Mon, 3 Dec 2012 19:17:24 +0000 (19:17 +0000)]
Cleanup CLI resources on exit and CLI command registration errors.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      cli-leaks-1_8-10.patch (license #5909) patch uploaded by Corey Farrell
      cli-leaks-11-trunk.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377073 from

Merged revisions 377074 from

Merged revisions 377075 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoCleanup CDR resources on exit.
Richard Mudgett [Mon, 3 Dec 2012 18:45:18 +0000 (18:45 +0000)]
Cleanup CDR resources on exit.

* Simplify do_reload() return handling since it never returned anything
other than 0.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      cdr-cleanup-1_8.patch (license #5909) patch uploaded by Corey Farrell
      cdr-cleanup-10-11-trunk.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377069 from

Merged revisions 377070 from

Merged revisions 377071 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix CCSS CLI commands and logger level not unregistered.
Richard Mudgett [Mon, 3 Dec 2012 17:10:40 +0000 (17:10 +0000)]
Fix CCSS CLI commands and logger level not unregistered.

(issue ASTERISK-20649)
Reported by: Corey Farrell
      ccss-cleanup-all.patch (license #5909) patch uploaded by Corey Farrell

Merged revisions 377037 from

Merged revisions 377038 from

Merged revisions 377039 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFormatting fixes
Olle Johansson [Mon, 3 Dec 2012 16:45:49 +0000 (16:45 +0000)]
Formatting fixes

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix an RTP instance reference count leak in chan_motif.
Joshua Colp [Mon, 3 Dec 2012 14:56:36 +0000 (14:56 +0000)]
Fix an RTP instance reference count leak in chan_motif.

When setting up an RTP instance the RTCP portion of the instance
keeps a reference to the instance itself. In order to release this
reference and stop RTCP the stop API call must be called before
destroying the instance.

(closes issue ASTERISK-20751)
Reported by: joshoa

Merged revisions 377021 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoMove functions to AFTER the block of forward declarations of functions.
Olle Johansson [Mon, 3 Dec 2012 14:46:02 +0000 (14:46 +0000)]
Move functions to AFTER the block of forward declarations of functions.

It was a mess. The first part of chan_sip.c is constants, declarations, structures and stuff,
then forward declarations and then actual code. It's still a mess, but a bit less messy ;-)

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFormatting changes
Olle Johansson [Mon, 3 Dec 2012 09:35:55 +0000 (09:35 +0000)]
Formatting changes

Found a large amount of missing {} in the code before patching in another branch

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoTweak extension used for incoming calls received on Motif.
Joshua Colp [Sat, 1 Dec 2012 00:47:42 +0000 (00:47 +0000)]
Tweak extension used for incoming calls received on Motif.

Based on feedback from numerous individuals this patch tweaks incoming calls
to first look for an extension with the name of the endpoint. If no such extension
exists the call will silently fall back to the "s" extension as it previously

Merged revisions 376983 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agochan_misdn: Fix sending RELEASE_COMPLETE in response to SETUP.
Richard Mudgett [Fri, 30 Nov 2012 21:38:01 +0000 (21:38 +0000)]
chan_misdn: Fix sending RELEASE_COMPLETE in response to SETUP.

Fix sending a RELEASE_COMPLETE in response to a SETUP if chan_misdn does
not have a B channel available to assign to the call.

(closes issue ABE-2869)
Reported by: Guenther Kelleter
      setup-reject_2.diff (license #6372) patch uploaded by Guenther Kelleter


Merged revision 376949 from

Merged revisions 376950 from

Merged revisions 376951 from

Merged revisions 376952 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoMinor spelling fix to the VOLUME documentation.
Sean Bright [Fri, 30 Nov 2012 17:08:41 +0000 (17:08 +0000)]
Minor spelling fix to the VOLUME documentation.

Merged revisions 376919 from

Merged revisions 376920 from

Merged revisions 376921 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix potential crashes during SIP attended transfers.
Mark Michelson [Fri, 30 Nov 2012 16:56:53 +0000 (16:56 +0000)]
Fix potential crashes during SIP attended transfers.

The principal behind this patch is simple. During a transfer,
we manipulate channels that are owned by a separate thread than
the one we currently are running in, so it makes sense that we
need to grab a reference to the channels so that they cannot
disappear out from under us.

In the wild, crashes were sometimes seen when the transferring
party would hang up the call before the transfer target answered
the call. The most common place to see the crash occur was when
attempting to send a connected line update to the transferer

(closes issue ASTERISK-20226)
Reported by Jared Smith
ASTERISK-20226.patch uploaded by Mark Michelson (License #5049)
Tested by: Jared Smith

Merged revisions 376901 from

Merged revisions 376916 from

Merged revisions 376917 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agochan_local: Fix local_pvt ref leak in local_devicestate().
Richard Mudgett [Thu, 29 Nov 2012 23:01:16 +0000 (23:01 +0000)]
chan_local: Fix local_pvt ref leak in local_devicestate().

Regression introduced by ASTERISK-20390 fix.

(closes issue ASTERISK-20769)
Reported by: rmudgett
Tested by: rmudgett

Merged revisions 376868 from

Merged revisions 376869 from

Merged revisions 376870 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix compile error.
Richard Mudgett [Thu, 29 Nov 2012 22:34:24 +0000 (22:34 +0000)]
Fix compile error.

(issue ASTERISK-20724)

Merged revisions 376864 from

Merged revisions 376865 from

Merged revisions 376866 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoImprove Code Readability And Fix Setting natdetected Flag
Michael L. Young [Thu, 29 Nov 2012 21:58:41 +0000 (21:58 +0000)]
Improve Code Readability And Fix Setting natdetected Flag

For 1.8, 10, 11 and trunk we are are improving the code readability.

For 11 and trunk, auto nat detection was added.  The natdetected flag was being
set to 1 when the host address in the VIA header did not specifiy a port.  This
patch fixes this by setting the port on the temporary sock address used to
SIP_STANDARD_PORT in order for the sock address comparison to work properly.

(closes issue ASTERISK-20724)
Reported by: Michael L. Young
    asterisk-20724-set-port-v2.diff uploaded by Michael L. Young (license 5026)


Merged revisions 376834 from

Merged revisions 376835 from

Merged revisions 376836 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFixed ast_random's comment about locking.
David M. Lee [Thu, 29 Nov 2012 17:16:50 +0000 (17:16 +0000)]
Fixed ast_random's comment about locking.

The original comment was separated from the code at some point, and didn't
reflect the use of libc's other than glibc for Linux.

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix chan_sip websocket payload handling
Pedro Kiefer [Thu, 29 Nov 2012 16:44:42 +0000 (16:44 +0000)]
Fix chan_sip websocket payload handling

Websocket by default doesn't return an ast_str for the payload received. When
converting it to an ast_str on chan_sip the last character was being omitted,
because ast_str functions expects that the given length includes the trailing
0x00. payload_len only has the actual string length without counting the
trailing zero.

For most cases this passed unnoticed as most of SIP messages ends with \r\n.

(closes issue ASTERISK-20745)
Reported by: IƱaki Baz Castillo

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoAdd MALLOC_DEBUG atexit unreleased malloc memory summary.
Richard Mudgett [Thu, 29 Nov 2012 00:48:12 +0000 (00:48 +0000)]
Add MALLOC_DEBUG atexit unreleased malloc memory summary.

* Adds the following CLI commands to control MALLOC_DEBUG reporting of
unreleased malloc memory when Asterisk is shut down.
memory atexit list on
memory atexit list off
memory atexit summary byline
memory atexit summary byfunc
memory atexit summary byfile
memory atexit summary off

* Made check all remaining allocated region blocks atexit for fence

* Increased the allocated region hash table size by about three times.  It
still isn't large enough considering the number of malloced blocks
Asterisk uses.

* Made CLI "memory show allocations anomalies" use


Merged revisions 376788 from

Merged revisions 376789 from

Merged revisions 376790 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoEnhance MALLOC_DEBUG CLI commands.
Richard Mudgett [Thu, 29 Nov 2012 00:07:55 +0000 (00:07 +0000)]
Enhance MALLOC_DEBUG CLI commands.

* Fixed CLI "memory show allocations" misspelling of anomalies option.
The command will still accept the original misspelling.

* Miscellaneous tweaks to CLI "memory show allocations" command output

* Made CLI "memory show summary" summarize by line number instead of by
function if a filename is given.

* Made CLI "memory show summary" sort its output by filename or
function-name/line-number depending upon request.

* Miscellaneous tweaks to CLI "memory show summary" command output format.

Merged revisions 376758 from

Merged revisions 376759 from

Merged revisions 376760 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agomanager: Make challenge work with allowmultiplelogin=no
Jonathan Rose [Wed, 28 Nov 2012 16:47:44 +0000 (16:47 +0000)]
manager: Make challenge work with allowmultiplelogin=no

Prior to this patch, challenge would yield a multiple logins error if used
without providing the username (which isn't really supposed to be an argument
to challenge) if allowmultiplelogin was set to no because allowmultiplelogin
finds a user with a zero length login name. This check is simply disabled for
the challenge action when the username is empty by this patch.

(closes issue ASTERISK-20677)
Reported by: Vladimir
    challenge_action_nomultiplelogin.diff uploaded by Jonathan Rose (license 6182)

Merged revisions 376725 from

Merged revisions 376726 from

Merged revisions 376727 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoFix extension matching with the '-' char.
Richard Mudgett [Wed, 28 Nov 2012 00:13:10 +0000 (00:13 +0000)]
Fix extension matching with the '-' char.

The '-' char is supposed to be ignored by the dialplan extension matching.
Unfortunately, it's treatment is not handled consistently throughout the
extension matching code.

* Made the old exten matching code consistently ignore '-' chars.

* Made the old exten matching code consistently handle case in the

* Made ignore empty character sets.

* Fixed ast_extension_cmp() to return -1, 0, or 1 as documented.  The only
user of it in pbx_lua.c was testing for -1.  It was originally returning
the strcmp() value for less than which is not usually going to be -1.

* Fix character set sorting if the sets have the same number of characters
and start with the same character.  Character set [0-9] now sorts before
[02-9a] as originally intended.

* Updated some extension label and priority already in use warnings to
also indicate if the extension is aliased.

(closes issue ASTERISK-19205)
Reported by: Philippe Lindheimer, Birger "WIMPy" Harzenetter
Tested by: rmudgett


Merged revisions 376688 from

Merged revisions 376689 from

Merged revisions 376690 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3

9 years agoRemove unnecessary channel module references.
Richard Mudgett [Tue, 27 Nov 2012 20:39:51 +0000 (20:39 +0000)]
Remove unnecessary channel module references.

* Removed call to ast_module_user_hangup_all() in res_config_mysql.c since
it is effectively a noop.  No channels can attach a reference to that

* Removed call to ast_module_user_hangup_all() in app_celgenuserevent.c.
The caller of unload_module() has already called it.

* Removed redundant channel module references in pbx_dundi.c.  The
registered dialplan function callback dispatchers for the read/read2/write
callbacks already reference the module before calling.

* pbx_dundi: Moved unregistering CLI commands, DUNDi switch, and dialplan
functions to the first thing the unload_module() does.  This will reduce
the chance of new channels using DUNDi services while the module is being
torn down.

Merged revisions 376657 from

Merged revisions 376658 from

Merged revisions 376659 from

git-svn-id: 65c4cc65-6c06-0410-ace0-fbb531ad65f3