Voicemail: Remove mailbox identifier format (box@context) assumptions in the system.
[asterisk/asterisk.git] / CHANGES
1 ==============================================================================
2 ===
3 === This file documents the new and/or enhanced functionality added in
4 === the Asterisk versions listed below. This file does NOT include
5 === changes in behavior that would not be backwards compatible with
6 === previous versions; for that information see the UPGRADE.txt file
7 === and the other UPGRADE files for older releases.
8 ===
9 ==============================================================================
10
11 ------------------------------------------------------------------------------
12 --- Functionality changes from Asterisk 12 to Asterisk 13 --------------------
13 ------------------------------------------------------------------------------
14
15 Applications
16 --------------------------
17
18 ConfBridge
19 --------------------------
20  * CONFBRIDGE dialplan function is now capable of creating/modifying dynamic
21    conference user menus.
22
23  * CONFBRIDGE dialplan function is now capable of removing dynamic conference
24    menus, bridge settings, and user settings that have been applied by the
25    CONFBRIDGE dialplan function.
26
27  * The ConfBridge dialplan application now sets a channel variable,
28    CONFBRIGE_RESULT, upon exiting. This variable can be used to determine
29    how a channel exited the conference.
30
31  * Added conference user option 'announce_join_leave_review'. This option
32    implies 'announce_join_leave' with the added effect that the user will
33    be asked if they want to confirm or re-record the recording of their
34    name when entering the conference
35
36 Directory
37 --------------------------
38  * At exit, the Directory application now sets a channel variable
39    DIRECTORY_RESULT to one of the following based on the reason for exiting:
40      OPERATOR    user requested operator by pressing '0' for operator
41      ASSISTANT   user requested assistant by pressing '*' for assistant
42      TIMEOUT     user pressed nothing and Directory stopped waiting
43      HANGUP      user's channel hung up
44      SELECTED    user selected a user from the directory and is routed
45      USEREXIT    user pressed '#' from the selection prompt to exit
46      FAILED      directory failed in a way that wasn't accounted for. Dang.
47
48 Page
49 --------------------------
50  * Added options 'b' and 'B' to apply predial handlers for outgoing calls
51    and for the channel executing Page respectively.
52
53 PickupChan
54 --------------------------
55  * PickupChan now accepts channel uniqueids of channels to pickup.
56
57 Say
58 --------------------------
59  * If a channel variable SAY_DTMF_INTERRUPT is present on a channel and set
60    to 'true' (case insensitive), then any Say application (SayNumber,
61    SayDigits, SayAlpha, SayAlphaCase, SayUnixTime, and SayCounted) will
62    anticipate DTMF. If DTMF is received, these applications will behave like
63    the background application and jump to the received extension once a match
64    is established or after a short period of inactivity.
65
66 MixMonitor
67 -------------------------
68  * A new function, MIXMONITOR, has been added to allow access to individual
69    instances of MixMonitor on a channel.
70
71 ------------------------------------------------------------------------------
72 --- Functionality changes from Asterisk 11 to Asterisk 12 --------------------
73 ------------------------------------------------------------------------------
74
75 Overview
76 ------------------
77
78 Asterisk 12 is a standard release of the Asterisk project. As such, the
79 focus of development for this release was on core architectural changes and
80 major new features. This includes:
81  * A more flexible bridging core based on the Bridging API
82  * A new internal message bus, Stasis
83  * Major standardization and consistency improvements to AMI
84  * Addition of the Asterisk RESTful Interface (ARI)
85  * A new SIP channel driver, chan_pjsip
86 In addition, as the vast majority of bridging in Asterisk was migrated to the
87 Bridging API used by ConfBridge, major changes were made to most of the
88 interfaces in Asterisk. This includes not only AMI, but also CDRs and CEL.
89
90 Specifications have been written for the affected interfaces. These
91 specifications are available on the Asterisk wiki:
92  * AMI - https://wiki.asterisk.org/wiki/x/dAFRAQ
93  * CEL - https://wiki.asterisk.org/wiki/x/4ICLAQ
94  * CDRs - https://wiki.asterisk.org/wiki/x/pwpRAQ
95
96 It is *highly* recommended that anyone migrating to Asterisk 12 read the
97 information regarding its release both in this file and in the accompanying
98 UPGRADE.txt file. More detailed information on the major changes can be found
99 on the Asterisk wiki at https://wiki.asterisk.org/wiki/x/0YCLAQ.
100
101
102 Build System
103 ------------------
104  * Added build option DISABLE_INLINE. This option can be used to work around a
105    bug in gcc. For more information, see
106    http://gcc.gnu.org/bugzilla/show_bug.cgi?id=47816
107
108  * Removed the CHANNEL_TRACE development mode build option. Certain aspects of
109    the CHANNEL_TRACE build option were incompatible with the new bridging
110    architecture.
111
112  * Asterisk now optionally uses libxslt to improve XML documentation generation
113    and maintainability. If libxslt is not available on the system, some XML
114    documentation will be incomplete.
115
116  * Asterisk now depends on libjansson. If a package of libjansson is not
117    available on your distro, please see http://www.digip.org/jansson/.
118
119  * Asterisk now depends on libuuid and, optionally, uriparser. It is
120    recommended that you install uriparser, even if it is optional.
121
122  * The new SIP stack and channel driver uses a particular version of PJSIP.
123    Please see https://wiki.asterisk.org/wiki/x/J4GLAQ for more information on
124    configuring and installing PJSIP for usage with Asterisk.
125
126  * Optional API was re-implemented to be more portable, and no longer requires
127    weak reference support from the compiler. The build option OPTIONAL_API may
128    be disabled to disable Optional API support.
129
130 Applications
131 ------------------
132
133 AgentLogin
134 ------------------
135  * Along with AgentRequest, this application has been modified to be a
136    replacement for chan_agent. The act of a channel calling the AgentLogin
137    application places the channel into a pool of agents that can be
138    requested by the AgentRequest application. Note that this application, as
139    well as all other agent related functionality, is now provided by the
140    app_agent_pool module. See chan_agent and AgentRequest for more information.
141
142  * This application no longer performs agent authentication. If authentication
143    is desired, the dialplan needs to perform this function using the
144    Authenticate or VMAuthenticate application or through an AGI script before
145    running AgentLogin.
146
147  * If this application is called and the agent is already logged in, the
148    dialplan will continue exection with the AGENT_STATUS channel variable set
149    to ALREADY_LOGGED_IN.
150
151  * The agents.conf schema has changed. Rather than specifying agents on a
152    single line in comma delineated fashion, each agent is defined in a separate
153    context. This allows agents to use the power of context templates in their
154    definition.
155
156  * A number of parameters from agents.conf have been removed. This includes
157    maxloginretries, autologoffunavail, updatecdr, goodbye, group, recordformat,
158    urlprefix, and savecallsin. These options were obsoleted by the move from
159    a channel driver model to the bridging/application model provided by
160    app_agent_pool.
161
162 AgentRequest
163 ------------------
164  * A new application, this will request a logged in agent from the pool and
165    bridge the requested channel with the channel calling this application.
166    Logged in agents are those channels that called the AgentLogin application.
167    If an agent cannot be requested from the pool, the AGENT_STATUS dialplan
168    application will be set with an appropriate error value.
169
170 AgentMonitorOutgoing
171 ------------------
172  * This application has been removed. It was a holdover from when
173    AgentCallbackLogin was removed.
174
175 AlarmReceiver
176 ------------------
177  * Added support for additional Ademco DTMF signalling formats, including
178    Express 4+1, Express 4+2, High Speed and Super Fast.
179
180  * Added channel variable ALARMRECEIVER_CALL_LIMIT. This sets the maximum
181    call time, in milliseconds, to run the application.
182
183  * Added channel variable ALARMRECEIVER_RETRIES_LIMIT. This sets the
184    maximum number of times to retry the call.
185
186  * Added a new configuration option answait. If set, the AlarmReceiver
187    application will wait the number of milliseconds specified by answait
188    after the channel has answered. Valid values range between 500
189    milliseconds and 10000 milliseconds.
190
191  * Added configuration option no_group_meta. If enabled, grouping of metadata
192    information in the AlarmReceiver log file will be skipped.
193
194 Answer
195 ------------------
196  * It is now no longer possible to bypass updating the CDR on the channel
197    when answering. CDRs reflect the state of the channel and will always
198    reflect the time they were Answered.
199
200 BridgeWait
201 ------------------
202  * A new application in Asterisk, this will place the calling channel
203    into a holding bridge, optionally entertaining them with some form of
204    media. Channels participating in a holding bridge do not interact with
205    other channels in the same holding bridge. Optionally, however, a channel
206    may join as an announcer. Any media passed from an announcer channel is
207    played to all channels in the holding bridge. Channels leave a holding
208    bridge either when an optional timer expires, or via the ChannelRedirect
209    application or AMI Redirect action.
210
211 ConfBridge
212 ------------------
213  * All participants in a bridge can now be kicked out of a conference room
214    by specifying the channel parameter as 'all' in the ConfBridge kick CLI
215    command, i.e., 'confbridge kick <conference> all'
216
217  * CLI output for the 'confbridge list' command has been improved. When
218    displaying information about a particular bridge, flags will now be shown
219    for the participating users indicating properties of that user.
220
221  * The ConfbridgeList event now contains the following fields: WaitMarked,
222    EndMarked, and Waiting. This displays additional properties about the
223    user's profile, as well as whether or not the user is waiting for a
224    Marked user to enter the conference.
225
226  * Added a new option for conference recording, record_file_append. If enabled,
227    when the recording is stopped and then re-started, the existing recording
228    will be used and appended to.
229
230  * ConfBridge now has the ability to set the language of announcements to the
231    conference.  The language can be set on a bridge profile in confbridge.conf
232    or by the dialplan function CONFBRIDGE(bridge,language)=en.
233
234 ControlPlayback
235 ------------------
236  * The channel variable CPLAYBACKSTATUS may now return the value
237    'REMOTESTOPPED'. This occurs when playback is stopped by a remote interface,
238    such as AMI. See the AMI action ControlPlayback for more information.
239
240 Directory
241 ------------------
242  * Added the 'a' option, which allows the caller to enter in an additional
243    alias for the user in the directory. This option must be used in conjunction
244    with the 'f', 'l', or 'b' options. Note that the alias for a user can be
245    specified in voicemail.conf.
246
247 DumpChan
248 ------------------
249  * The output of DumpChan no longer includes the DirectBridge or IndirectBridge
250    fields. Instead, if a channel is in a bridge, it includes a BridgeID field
251    containing the unique ID of the bridge that the channel happens to be in.
252
253 ForkCDR
254 ------------------
255  * ForkCDR no longer automatically resets the forked CDR. See the 'r' option
256    for more information.
257
258  * Variables are no longer purged from the original CDR. See the 'v' option for
259    more information.
260
261  * The 'A' option has been removed. The Answer time on a CDR is never updated
262    once set.
263
264  * The 'd' option has been removed. The disposition on a CDR is a function of
265    the state of the channel and cannot be altered.
266
267  * The 'D' option has been removed. Who the Party B is on a CDR is a function
268    of the state of the respective channels involved in the CDR and cannot be
269    altered.
270
271  * The 'r' option has been changed. Previously, ForkCDR always reset the CDR
272    such that the start time and, if applicable, the answer time was updated.
273    Now, by default, ForkCDR simply forks the CDR, maintaining any times. The
274    'r' option now triggers the Reset, setting the start time (and answer time
275    if applicable) to the current time. Note that the 'a' option still sets
276    the answer time to the current time if the channel was already answered.
277
278  * The 's' option has been removed. A variable can be set on the original CDR
279    if desired using the CDR function, and removed from a forked CDR using the
280    same function.
281
282  * The 'T' option has been removed. The concept of DONT_TOUCH and LOCKED no
283    longer applies in the CDR engine.
284
285  * The 'v' option now prevents the copy of the variables from the original CDR
286    to the forked CDR. Previously the variables were always copied but were
287    removed from the original. This was changed as removing variables from a CDR
288    can have unintended side effects - this option allows the user to prevent
289    propagation of variables from the original to the forked without modifying
290    the original.
291
292 MeetMe
293 -------------------
294  * Added the 'n' option to MeetMe to prevent application of the DENOISE
295    function to a channel joining a conference. Some channel drivers that vary
296    the number of audio samples in a voice frame will experience significant
297    quality problems if a denoiser is attached to the channel; this option gives
298    them the ability to remove the denoiser without having to unload func_speex.
299
300 MixMonitor
301 ------------------
302  * The 'b' option now includes conferences as well as sounds played to the
303    participants.
304
305  * The AUDIOHOOK_INHERIT function is no longer needed to keep a MixMonitor
306    running during a transfer. If a MixMonitor is started on a channel,
307    the MixMonitor will continue to record the audio passing through the
308    channel even in the presence of transfers.
309
310 NoCDR
311 ------------------
312  * The NoCDR application is deprecated. Please use the CDR_PROP function to
313    disable CDRs.
314
315  * While the NoCDR application will prevent CDRs for a channel from being
316    propagated to registered CDR backends, it will not prevent that data from
317    being collected. Hence, a subsequent call to ResetCDR or the CDR_PROP
318    function that enables CDRs on a channel will restore those records that have
319    not yet been finalized.
320
321 ParkAndAnnounce
322 -------------------
323  * The app_parkandannounce module has been removed. The application
324    ParkAndAnnounce is now provided by the res_parking module. See the
325    res_parking changes for more information.
326
327 Queue
328 -------------------
329  * Added queue available hint. The hint can be added to the dialplan using the
330    following syntax: exten,hint,Queue:{queue_name}_avail
331    For example, if the name of the queue is 'markq':
332         exten => 8501,hint,Queue:markq_avail
333    This will report 'InUse' if there are no logged in agents or no free agents.
334    It will report 'Idle' when an agent is free.
335
336  * Queues now support a hint for member paused state. The hint uses the form
337    'Queue:{queue_name}_pause_{member_name}', where {queue_name} and {member_name}
338    are the name of the queue and the name of the member to subscribe to,
339    respectively. For example: exten => 8501,hint,Queue:sales_pause_mark.
340    Members will show as In Use when paused.
341
342  * The configuration options eventwhencalled and eventmemberstatus have been
343    removed.  As a result, the AMI events QueueMemberStatus, AgentCalled,
344    AgentConnect, AgentComplete, AgentDump, and AgentRingNoAnswer will always be
345    sent.  The "Variable" fields will also no longer exist on the Agent* events.
346    These events can be filtered out from a connected AMI client using the
347    eventfilter setting in manager.conf.
348
349  * The queue log now differentiates between blind and attended transfers. A
350    blind transfer will result in a BLINDTRANSFER message with the destination
351    context and extension. An attended transfer will result in an
352    ATTENDEDTRANSFER message. This message will indicate the method by which
353    the attended transfer was completed: "BRIDGE" for a bridge merge, "APP"
354    for running an application on a bridge or channel, or "LINK" for linking
355    two bridges together with local channels. The queue log will also now detect
356    externally initiated blind and attended transfers and record the transfer
357    status accordingly.
358
359  * When performing queue pause/unpause on an interface without specifying an
360    individual queue, the PAUSEALL/UNPAUSEALL event will only be logged if at
361    least one member of any queue exists for that interface.
362
363  * Added the 'queue_log_realtime_use_gmt' option to have timestamps in GMT
364    for realtime queue log entries.
365
366 ResetCDR
367 ------------------
368  * The 'e' option has been deprecated. Use the CDR_PROP function to re-enable
369    CDRs when they were previously disabled on a channel.
370
371  * The 'w' and 'a' options have been removed. Dispatching CDRs to registered
372    backends occurs on an as-needed basis in order to preserve linkedid
373    propagation and other needed behavior.
374
375 SayAlphaCase
376 ------------------
377  * A new application, this is similar to SayAlpha except that it supports
378    case sensitive playback of the specified characters. For example,
379    SayAlphaCase(u,aBc) will result in 'a uppercase b c'.
380
381 SetAMAFlags
382 ------------------
383  * This application is deprecated in favor of CHANNEL(amaflags).
384
385 SendDTMF
386 ------------------
387  * The SendDTMF application will now accept 'W' as valid input. This will cause
388    the application to delay one second while streaming DTMF.
389
390 Stasis
391 ------------------
392  * A new application in Asterisk 12, this hands control of the channel calling
393    the application over to an external system. Currently, external systems
394    manipulate channels in Stasis through the Asterisk RESTful Interface (ARI).
395
396 UserEvent
397 ------------------
398  * UserEvent will now handle duplicate keys by overwriting the previous value
399    assigned to the key.
400
401  * In addition to AMI, UserEvent invocations will now be distributed to any
402    interested Stasis applications.
403
404 VoiceMail
405 ------------------
406  * Mailboxes defined by app_voicemail MUST be referenced by the rest of the
407    system as mailbox@context.  The rest of the system cannot add @default
408    to mailbox identifiers for app_voicemail that do not specify a context
409    any longer.  It is a mailbox identifier format that should only be
410    interpreted by app_voicemail.
411
412  * The voicemail.conf configuration file now has an 'alias' configuration
413    parameter for use with the Directory application. The voicemail realtime
414    database table schema has also been updated with an 'alias' column.
415
416
417 Codecs
418 ------------------
419  * Pass through support has been added for both VP8 and Opus.
420
421  * Added format attribute negotiation for the Opus codec. Format attribute
422    negotiation is provided by the res_format_attr_opus module.
423
424
425 Core
426 ------------------
427  * Masquerades as an operation inside Asterisk have been effectively hidden
428    by the migration to the Bridging API. As such, many 'quirks' of Asterisk
429    no longer occur. This includes renaming of channels, "<ZOMBIE>" channels,
430    dropping of frame/audio hooks, and other internal implementation details
431    that users had to deal with. This fundamental change has large implications
432    throughout the changes documented for this version. For more information
433    about the new core architecture of Asterisk, please see the Asterisk wiki.
434
435  * Multiple parties in a bridge may now be transferred. If a participant in a
436    multi-party bridge initiates a blind transfer, a Local channel will be used
437    to execute the dialplan location that the transferer sent the parties to. If
438    a participant in a multi-party bridge initiates an attended transfer,
439    several options are possible. If the attended transfer results in a transfer
440    to an application, a Local channel is used. If the attended transfer results
441    in a transfer to another channel, the resulting channels will be merged into
442    a single bridge.
443
444  * The channel variable ATTENDED_TRANSFER_COMPLETE_SOUND is no longer channel
445    driver specific.  If the channel variable is set on the transferrer channel,
446    the sound will be played to the target of an attended transfer.
447
448  * The channel variable BRIDGEPEER becomes a comma separated list of peers in
449    a multi-party bridge.  The BRIDGEPEER value can have a maximum of 10 peers
450    listed.  Any more peers in the bridge will not be included in the list.
451    BRIDGEPEER is not valid in holding bridges like parking since those channels
452    do not talk to each other even though they are in a bridge.
453
454  * The channel variable BRIDGEPVTCALLID is only valid for two party bridges
455    and will contain a value if the BRIDGEPEER's channel driver supports it.
456
457  * A channel variable ATTENDEDTRANSFER is now set which indicates which channel
458    was responsible for an attended transfer in a similar fashion to
459    BLINDTRANSFER.
460
461  * Modules using the Configuration Framework or Sorcery must have XML
462    configuration documentation. This configuration documentation is included
463    with the rest of Asterisk's XML documentation, and is accessible via CLI
464    commands. See the CLI changes for more information.
465
466 AMI (Asterisk Manager Interface)
467 ------------------
468  * Major changes were made to both the syntax as well as the semantics of the
469    AMI protocol. In particular, AMI events have been substantially improved
470    in this version of Asterisk. For more information, please see the AMI
471    specification at https://wiki.asterisk.org/wiki/x/dAFRAQ
472
473  * AMI events that reference a particular channel or bridge will now always
474    contain a standard set of fields. When multiple channels or bridges are
475    referenced in an event, fields for at least some subset of the channels
476    and bridges in the event will be prefixed with a descriptive name to avoid
477    name collisions. See the AMI event documentation on the Asterisk wiki for
478    more information.
479
480  * The CLI command 'manager show commands' no longer truncates command names
481    longer than 15 characters and no longer shows authorization requirement
482    for commands. 'manager show command' now displays the privileges needed
483    for using a given manager command instead.
484
485  * The SIPshowpeer action will now include a 'SubscribeContext' field for a
486    peer in its response if the peer has a subscribe context set.
487
488  * The SIPqualifypeer action now acknowledges the request once it has
489    established that the request is against a known peer. It also issues a new
490    event, 'SIPQualifyPeerDone', once the qualify action has been completed.
491
492  * The PlayDTMF action now supports an optional 'Duration' parameter.  This
493    specifies the duration of the digit to be played, in milliseconds.
494
495  * Added VoicemailRefresh action to allow an external entity to trigger mailbox
496    updates when changes occur instead of requiring the use of pollmailboxes.
497
498  * Added a new action 'ControlPlayback'. The ControlPlayback action allows an
499    AMI client to manipulate audio currently being played back on a channel. The
500    supported operations depend on the application being used to send audio to
501    the channel. When the audio playback was initiated using the ControlPlayback
502    application or CONTROL STREAM FILE AGI command, the audio can be paused,
503    stopped, restarted, reversed, or skipped forward. When initiated by other
504    mechanisms (such as the Playback application), the audio can be stopped,
505    reversed, or skipped forward.
506
507  * Channel related events now contain a snapshot of channel state, adding new
508    fields to many of these events.
509
510  * The AMI event 'Newexten' field 'Extension' is deprecated, and may be removed
511    in a future release. Please use the common 'Exten' field instead.
512
513  * The AMI event 'UserEvent' from app_userevent now contains the channel state
514    fields. The channel state fields will come before the body fields.
515
516  * The AMI events 'ParkedCall', 'ParkedCallTimeOut', 'ParkedCallGiveUp', and
517    'UnParkedCall' have changed significantly in the new res_parking module.
518
519    The 'Channel' and 'From' headers are gone. For the channel that was parked
520    or is coming out of parking, a 'Parkee' channel snapshot is issued and it
521    has a number of fields associated with it. The old 'Channel' header relayed
522    the same data as the new 'ParkeeChannel' header.
523
524    The 'From' field was ambiguous and changed meaning depending on the event.
525    for most of these, it was the name of the channel that parked the call
526    (the 'Parker'). There is no longer a header that provides this channel name,
527    however the 'ParkerDialString' will contain a dialstring to redial the
528    device that parked the call.
529
530    On UnParkedCall events, the 'From' header would instead represent the
531    channel responsible for retrieving the parkee. It receives a channel
532    snapshot labeled 'Retriever'. The 'from' field is is replaced with
533    'RetrieverChannel'.
534
535    Lastly, the 'Exten' field has been replaced with 'ParkingSpace'.
536
537  * The AMI event 'Parkinglot' (response to 'Parkinglots' command) in a similar
538    fashion has changed the field names 'StartExten' and 'StopExten' to
539    'StartSpace' and 'StopSpace' respectively.
540
541  * The deprecated use of | (pipe) as a separator in the channelvars setting in
542    manager.conf has been removed.
543
544  * Channel Variables conveyed with a channel no longer contain the name of the
545    channel as part of the key field, i.e., ChanVariable(SIP/foo): bar=baz is now
546    ChanVariable: bar=baz. When multiple channels are present in a single AMI
547    event, the various ChanVariable fields will contain a suffix that specifies
548    which channel they correspond to.
549
550  * The NewPeerAccount AMI event is no longer raised. The NewAccountCode AMI
551    event always conveys the AMI event for a particular channel.
552
553  * All 'Reload' events have been consolidated into a single event type. This
554    event will always contain a Module field specifying the name of the module
555    and a Status field denoting the result of the reload. All modules now issue
556    this event when being reloaded.
557
558  * The 'ModuleLoadReport' event has been removed. Most AMI connections would
559    fail to receive this event due to being connected after modules have loaded.
560    AMI connections that want to know when Asterisk is ready should listen for
561    the 'FullyBooted' event.
562
563  * app_fax now sends the same send fax/receive fax events as res_fax. The
564    'FaxSent' event is now the 'SendFAX' event, and the 'FaxReceived' event is
565    now the 'ReceiveFAX' event.
566
567  * The 'MusicOnHold' event is now two events: 'MusicOnHoldStart' and
568    'MusicOnHoldStop'. The sub type field has been removed.
569
570  * The 'JabberEvent' event has been removed. It is not AMI's purpose to be a
571    carrier for another protocol.
572
573  * The Bridge Manager action's 'Playtone' header now accepts more fine-grained
574    options. 'Channel1' and 'Channel2' may be specified in order to play a tone
575    to the specific channel. 'Both' may be specified to play a tone to both
576    channels. The old 'yes' option is still accepted as a way of playing the
577    tone to Channel2 only.
578
579  * The AMI 'Status' response event to the AMI Status action replaces the
580    'BridgedChannel' and 'BridgedUniqueid' headers with the 'BridgeID' header to
581    indicate what bridge the channel is currently in.
582
583  * The AMI 'Hold' event has been moved out of individual channel drivers, into
584    core, and is now two events: 'Hold' and 'Unhold'.  The status field has been
585    removed.
586
587  * The AMI events in app_queue have been made more consistent with each other.
588    Events that reference channels (QueueCaller* and Agent*) will show
589    information about each channel.  The (infamous) 'Join' and 'Leave' AMI
590    events have been changed to 'QueueCallerJoin' and 'QueueCallerLeave'.
591
592  * The 'MCID' AMI event now publishes a channel snapshot when available and
593    its non-channel-snapshot parameters now use either the "MCallerID" or
594    'MConnectedID' prefixes with Subaddr*, Name*, and Num* suffixes instead
595    of 'CallerID' and 'ConnectedID' to avoid confusion with similarly named
596    parameters in the channel snapshot.
597
598  * The AMI events 'Agentlogin' and 'Agentlogoff' have been renamed
599    'AgentLogin' and 'AgentLogoff' respectively.
600
601  * The 'Channel' key used in the 'AlarmClear', 'Alarm', and 'DNDState' has been
602    renamed "DAHDIChannel" since it does not convey an Asterisk channel name.
603
604  * 'ChannelUpdate' events have been removed.
605
606  * All AMI events now contain a 'SystemName' field, if available.
607
608  * Local channel optimization is now conveyed in two events:
609    'LocalOptimizationBegin' and 'LocalOptimizationEnd'. The Begin event is sent
610    when the Local channel driver begins attempting to optimize itself out of
611    the media path; the End event is sent after the channel halves have
612    successfully optimized themselves out of the media path.
613
614  * Local channel information in events is now prefixed with 'LocalOne' and
615    'LocalTwo'. This replaces the suffix of '1' and '2' for the two halves of
616    the Local channel. This affects the 'LocalBridge', 'LocalOptimizationBegin',
617    and 'LocalOptimizationEnd' events.
618
619  * The option 'allowmultiplelogin' can now be set or overriden in a particular
620    account. When set in the general context, it will act as the default
621    setting for defined accounts.
622
623  * The 'BridgeAction' event was removed. It technically added no value, as the
624    Bridge Action already receives confirmation of the bridge through a
625    successful completion Event.
626
627  * The 'BridgeExec' events were removed. These events duplicated the events that
628    occur in the Briding API, and are conveyed now through BridgeCreate,
629    BridgeEnter, and BridgeLeave events.
630
631  * The 'RTCPSent'/'RTCPReceived' events have been significantly modified from
632    previous versions. They now report all SR/RR packets sent/received, and
633    have been restructured to better reflect the data sent in a SR/RR. In
634    particular, the event structure now supports multiple report blocks.
635
636  * Added 'BlindTransfer' and 'AttendedTransfer' events. These events are
637    raised when a blind transfer/attended transfer completes successfully.
638    They contain information about the transfer that just completed, including
639    the location of the transfered channel.
640
641  * Added a 'security' class to AMI which outputs the required fields for
642    security messages similar to the log messages from res_security_log
643
644 CDR (Call Detail Records)
645 ------------------
646  * Significant changes have been made to the behavior of CDRs. The CDR engine
647    was effectively rewritten and built on the Stasis message bus. For a full
648    definition of CDR behavior in Asterisk 12, please read the specification
649    on the Asterisk wiki (wiki.asterisk.org).
650
651  * CDRs will now be created between all participants in a bridge. For each
652    pair of channels in a bridge, a CDR is created to represent the path of
653    communication between those two endpoints. This lets an end user choose who
654    to bill for what during bridge operations with multiple parties.
655
656  * The duration, billsec, start, answer, and end times now reflect the times
657    associated with the current CDR for the channel, as opposed to a cumulative
658    measurement of all CDRs for that channel.
659
660  * When a CDR is dispatched, user defined CDR variables from both parties are
661    included in the resulting CDR. If both parties have the same variable, only
662    the Party A value is provided.
663
664  * Added a new option to cdr.conf, 'debug'. When enabled, significantly more
665    information regarding the CDR engine is logged as verbose messages. This
666    option should only be used if the behavior of the CDR engine needs to be
667    debugged.
668
669  * Added CLI command 'cdr set debug {on|off}'. This toggles the 'debug' setting
670    normally configured in cdr.conf.
671
672  * Added CLI command 'cdr show active {channel}'. When {channel} is not
673    specified, this command provides a summary of the channels with CDR
674    information and their statistics. When {channel} is specified, it shows
675    detailed information about all records associated with {channel}.
676
677 CEL (Channel Event Logging)
678 ------------------
679  * CEL has undergone significant rework in Asterisk 12, and is now built on the
680    Stasis message bus. Please see the specification for CEL on the Asterisk
681    wiki at https://wiki.asterisk.org/wiki/x/4ICLAQ for more detailed
682    information.
683
684  * The 'extra' field of all CEL events that use it now consists of a JSON blob
685    with key/value pairs which are defined in the Asterisk 12 CEL documentation.
686
687  * BLINDTRANSFER events now report the transferee bridge unique
688    identifier, extension, and context in a JSON blob as the extra string
689    instead of the transferee channel name as the peer.
690
691  * ATTENDEDTRANSFER events now report the peer as NULL and additional
692    information in the 'extra' string as a JSON blob. For transfers that occur
693    between two bridged channels, the 'extra' JSON blob contains the primary
694    bridge unique identifier, the secondary channel name, and the secondary
695    bridge unique identifier. For transfers that occur between a bridged channel
696    and a channel running an app, the 'extra' JSON blob contains the primary
697    bridge unique identifier, the secondary channel name, and the app name.
698
699  * LOCAL_OPTIMIZE events have been added to convey local channel
700    optimizations with the record occurring for the semi-one channel and
701    the semi-two channel name in the peer field.
702
703  * BRIDGE_START, BRIDGE_END, BRIDGE_UPDATE, 3WAY_START, 3WAY_END, CONF_ENTER,
704    CONF_EXIT, CONF_START, and CONF_END events have all been removed. These
705    events have been replaced by BRIDGE_ENTER/BRIDGE_EXIT. The BRIDGE_ENTER
706    and BRIDGE_EXIT events are raised when a channel enters/exits any bridge,
707    regardless of whether or not that bridge happens to contain multiple
708    parties.
709
710 CLI
711 -------------------
712  * When compiled with '--enable-dev-mode', the astobj2 library will now add
713    several CLI commands that allow for inspection of ao2 containers that
714    register themselves with astobj2. The CLI commands are 'astobj2 container
715    dump', 'astobj2 container stats', and 'astobj2 container check'.
716
717  * Added specific CLI commands for bridge inspection. This includes 'bridge
718    show all', which lists all bridges in the system, and 'bridge show {id}',
719    which provides specific information about a bridge.
720
721  * Added CLI command 'bridge destroy'. This will destroy the specified bridge,
722    ejecting the channels currently in the bridge. If the channels cannot
723    continue in the dialplan or application that put them in the bridge, they
724    will be hung up.
725
726  * Added command 'bridge kick'. This will eject a single channel from a bridge.
727
728  * Added commands to inspect and manipulate the registered bridge technologies.
729    This include 'bridge technology show', which lists the registered bridge
730    technologies, as well as 'bridge technology {suspend|unsuspend} {tech}',
731    which controls whether or not a registered bridge technology can be used
732    during smart bridge operations. If a technology is suspended, it will not
733    be used when a bridge technology is picked for channels; when unsuspended,
734    it can be used again.
735
736  * The command 'config show help {module} {type} {option}' will show
737    configuration documentation for modules with XML configuration
738    documentation. When {module}, {type}, and {option} are omitted, a listing
739    of all modules with registered documentation is displayed. When {module}
740    is specified, a listing of all configuration types for that module is
741    displayed, along with their synopsis. When {module} and {type} are
742    specified, a listing of all configuration options for that type are
743    displayed along with their synopsis. When {module}, {type}, and {option}
744    are specified, detailed information for that configuration option is
745    displayed.
746
747  * Added 'core show sounds' and 'core show sound' CLI commands. These display
748    a listing of all installed media sounds available on the system and
749    detailed information about a sound, respectively.
750
751  * 'xmldoc dump' has been added. This CLI command will dump the XML
752    documentation DOM as a string to the specified file. The Asterisk core
753    will populate certain XML elements pulled from the source files with
754    additional run-time information; this command lets a user produce the
755    XML documentation with all information.
756
757 Features
758 -------------------
759  * Parking has been pulled from core and placed into a separate module called
760    res_parking. See Parking changes below for more details. Configuration for
761    parking should now be performed in res_parking.conf. Configuration for
762    parking in features.conf is now unsupported.
763
764  * Core attended transfers now have several new options. While performing an
765    attended transfer, the transferer now has the following options:
766    - *1 - cancel the attended transfer (configurable via atxferabort)
767    - *2 - complete the attended transfer, dropping out of the call
768           (configurable via atxfercomplete)
769    - *3 - complete the attended transfer, but stay in the call. This will turn
770           the call into a multi-party bridge (configurable via atxferthreeway)
771    - *4 - swap to the other party. Once an attended transfer has begun, this
772           options may be used multiple times (configurable via atxferswap)
773
774  * For DTMF blind and attended transfers, the channel variable TRANSFER_CONTEXT
775    must be on the channel initiating the transfer to have any effect.
776
777  * The BRIDGE_FEATURES channel variable would previously only set features for
778    the calling party and would set this feature regardless of whether the
779    feature was in caps or in lowercase. Use of a caps feature for a letter
780    will now apply the feature to the calling party while use of a lowercase
781    letter will apply that feature to the called party.
782
783  * Add support for automixmon to the BRIDGE_FEATURES channel variable.
784
785  * The channel variable DYNAMIC_PEERNAME is redundant with BRIDGEPEER and is
786    removed.  The more useful DYNAMIC_WHO_ACTIVATED gives the channel name that
787    activated the dynamic feature.
788
789  * The channel variables DYNAMIC_FEATURENAME and DYNAMIC_WHO_ACTIVATED are set
790    only on the channel executing the dynamic feature.  Executing a dynamic
791    feature on the bridge peer in a multi-party bridge will execute it on all
792    peers of the activating channel.
793
794  * You can now have the settings for a channel updated using the FEATURE()
795    and FEATUREMAP() functions inherited to child channels by setting
796    FEATURE(inherit)=yes.
797
798  * automixmon now supports additional channel variables from automon including:
799    TOUCH_MIXMONITOR_PREFIX, TOUCH_MIXMONITOR_MESSAGE_START,
800    and TOUCH_MIXMONITOR_MESSAGE_STOP
801
802  * A new general features.conf option 'recordingfailsound' has been added which
803    allowssetting a failure sound for a user tries to invoke a recording feature
804    such as automon or automixmon and it fails.
805
806  * It is no longer necessary (or possible) to define the ATXFER_NULL_TECH in
807    features.c for atxferdropcall=no to work properly. This option now just
808    works.
809
810 Logging
811 -------------------
812  * Added log rotation strategy 'none'. If set, no log rotation strategy will
813    be used. Given that this can cause the Asterisk log files to grow quickly,
814    this option should only be used if an external mechanism for log management
815    is preferred.
816
817 Realtime
818 ------------------
819  * Dynamic realtime tables for SIP Users can now include a 'path' field. This
820    will store the path information for that peer when it registers. Realtime
821    tables can also use the 'supportpath' field to enable Path header support.
822
823  * LDAP realtime configurations for SIP Users now have the AstAccountPathSupport
824    objectIdentifier. This maps to the supportpath option in sip.conf.
825
826 Sorcery
827 ------------------
828  * Sorcery is a new data abstraction and object persistence API in Asterisk. It
829    provides modules a useful abstraction on top of the many storage mechanisms
830    in Asterisk, including the Asterisk Database, static configuration files,
831    static Realtime, and dynamic Realtime. It also provides a caching service.
832    Users can configure a hierarchy of data storage layers for specific modules
833    in sorcery.conf.
834
835  * All future modules which utilize Sorcery for object persistence must have a
836    column named "id" within their schema when using the Sorcery realtime module.
837    This column must be able to contain a string of up to 128 characters in length.
838
839 Security Events Framework
840 ------------------
841  * Security Event timestamps now use ISO 8601 formatted date/time instead of
842    the "seconds-microseconds" format that it was using previously.
843
844 Stasis Message Bus
845 ------------------
846  * The Stasis message bus is a publish/subscribe message bus internal to
847    Asterisk. Many services in Asterisk are built on the Stasis message bus,
848    including AMI, ARI, CDRs, and CEL. Parameters controlling the operation of
849    Stasis can be configured in stasis.conf. Note that these parameters operate
850    at a very low level in Asterisk, and generally will not require changes.
851
852 Channel Drivers
853 ------------------
854  * When a channel driver is configured to enable jiterbuffers, they are now
855    applied unconditionally when a channel joins a bridge. If a jitterbuffer
856    is already set for that channel when it enters, such as by the JITTERBUFFER
857    function, then the existing jitterbuffer will be used and the one set by
858    the channel driver will not be applied.
859
860 chan_agent
861 ------------------
862  * chan_agent has been removed and replaced with AgentLogin and AgentRequest
863    dialplan applications provided by the app_agent_pool module. Agents are
864    connected with callers using the new AgentRequest dialplan application.
865    The Agents:<agent-id> device state is available to monitor the status of an
866    agent. See agents.conf.sample for valid configuration options.
867
868  * The updatecdr option has been removed. Altering the names of channels on a
869    CDR is not supported - the name of the channel is the name of the channel,
870    and pretending otherwise helps no one. The AGENTUPDATECDR channel variable
871    has also been removed, for the same reason.
872
873  * The endcall and enddtmf configuration options are removed.  Use the
874    dialplan function CHANNEL(dtmf-features) to set DTMF features on the agent
875    channel before calling AgentLogin.
876
877 chan_bridge
878 ------------------
879  * chan_bridge has been removed. Its functionality has been incorporated
880    directly into the ConfBridge application itself.
881
882 chan_dahdi
883 ------------------
884  * Added the CLI command 'pri destroy span'. This will destroy the D-channel
885    of the specified span and its B-channels. Note that this command should
886    only be used if you understand the risks it entails.
887
888  * The CLI command 'dahdi destroy channel' is now 'dahdi destroy channels'.
889    A range of channels can be specified to be destroyed. Note that this command
890    should only be used if you understand the risks it entails.
891
892  * Added the CLI command 'dahdi create channels'. A range of channels can be
893    specified to be created, or the keyword 'new' can be used to add channels
894    not yet created.
895
896  * Added mwi_vm_boxes that also must be configured for ISDN MWI to be enabled.
897
898 chan_iax2
899 ------------------
900  * IPv6 support has been added.  We are now able to bind to and
901    communicate using IPv6 addresses.
902
903 chan_local
904 ------------------
905  * The /b option has been removed.
906
907  * chan_local moved into the system core and is no longer a loadable module.
908
909 chan_mobile
910 ------------------
911  * Added general support for busy detection.
912
913  * Added ECAM command support for Sony Ericsson phones.
914
915 chan_pjsip
916 ------------------
917  * A new SIP channel driver for Asterisk, chan_pjsip is built on the PJSIP
918    SIP stack. A collection of resource modules provides the bulk of the SIP
919    functionality. For more information on the new SIP channel driver, see
920    https://wiki.asterisk.org/wiki/x/JYGLAQ
921
922 chan_sip
923 ------------------
924  * Added support for RFC 3327 "Path" headers. This can be enabled in sip.conf
925    using the 'supportpath' setting, either on a global basis or on a peer basis.
926    This setting enables Asterisk to route outgoing out-of-dialog requests via a
927    set of proxies by using a pre-loaded route-set defined by the Path headers in
928    the REGISTER request. See Realtime updates for more configuration information.
929
930  * The SIP_CODEC family of variables may now specify more than one codec. Each
931    codec must be separated by a comma. The first codec specified is the
932    preferred codec for the offer. This allows a dialplan writer to specify both
933    audio and video codecs, e.g., Set(SIP_CODEC=ulaw,h264)
934
935  * The 'callevents' parameter has been removed. Hold AMI events are now raised
936    in the core, and can be filtered out using the 'eventfilter' parameter
937    in manager.conf.
938
939  * Added 'ignore_requested_pref'. When enabled, this will use the preferred
940    codecs configured for a peer instead of the requested codec.
941
942  * The option "register_retry_403" has been added to chan_sip to work around
943    servers that are known to erroneously send 403 in response to valid
944    REGISTER requests and allows Asterisk to continue attepmting to connect.
945
946 chan_skinny
947 ------------------
948  * Added the 'immeddialkey' parameter. If set, when the user presses the
949    configured key the already entered number will be immediately dialed. This
950    is useful when the dialplan allows for variable length pattern matching.
951    Valid options are '*' and '#'.
952
953  * Added the 'callfwdtimeout' parameter. This configures the amount of time (in
954    milliseconds) before a call forward is considered to not be answered.
955
956  * The 'serviceurl' parameter allows Service URLs to be attached to line
957    buttons.
958
959
960 Functions
961 ------------------
962
963 AGENT
964 ------------------
965  * The password option has been disabled, as the AgentLogin application no
966    longer provides authentication.
967
968 AUDIOHOOK_INHERIT
969 ------------------
970  * Due to changes in the Asterisk core, this function is no longer needed to
971    preserve a MixMonitor on a channel during transfer operations and dialplan
972    execution. It is effectively obsolete.
973
974 CDR (function)
975 ------------------
976  * The 'amaflags' and 'accountcode' attributes for the CDR function are
977    deprecated. Use the CHANNEL function instead to access these attributes.
978
979  * The 'l' option has been removed. When reading a CDR attribute, the most
980    recent record is always used. When writing a CDR attribute, all non-finalized
981    CDRs are updated.
982
983  * The 'r' option has been removed, for the same reason as the 'l' option.
984
985  * The 's' option has been removed, as LOCKED semantics no longer exist in the
986    CDR engine.
987
988 CDR_PROP
989 ------------------
990  * A new function CDR_PROP has been added. This function lets you set properties
991    on a channel's active CDRs. This function is write-only. Properties accept
992    boolean values to set/clear them on the channel's CDRs. Valid properties
993    include:
994    - 'party_a' - make this channel the preferred Party A in any CDR between two
995      channels. If two channels have this property set, the creation time of the
996      channel is used to determine who is Party A. Note that dialed channels are
997      never Party A in a CDR.
998    - 'disable' - disable CDRs on this channel. This is analogous to the NoCDR
999      application when set to True, and analogous to the 'e' option in ResetCDR
1000      when set to False.
1001
1002 CHANNEL
1003 ------------------
1004  * Added the argument 'dtmf_features'. This sets the DTMF features that will be
1005    enabled on a channel when it enters a bridge. Allowed values are 'T', 'K',
1006    'H', 'W', and 'X', and are analogous to the parameters passed to the Dial
1007    application.
1008
1009  * Added the argument 'after_bridge_goto'. This can be set to a parseable Goto
1010    string, i.e., [[context],extension],priority. If set on a channel, if a
1011    channel leaves a bridge but is not hung up it will resume dialplan execution
1012    at that location.
1013
1014 JITTERBUFFER
1015 ------------------
1016  * JITTERBUFFER now accepts an argument of 'disabled' which can be used
1017    to remove jitterbuffers previously set on a channel with JITTERBUFFER.
1018    The value of this setting is ignored when disabled is used for the argument.
1019
1020 PJSIP_DIAL_CONTACTS
1021 ------------------
1022  * A new function provided by chan_pjsip, this function can be used in
1023    conjunction with the Dial application to construct a dial string that will
1024    dial all contacts on an Address of Record associated with a chan_pjsip
1025    endpoint.
1026
1027 PJSIP_MEDIA_OFFER
1028 ------------------
1029  * Provided by chan_pjsip, this function sets the codecs to be offerred on the
1030    outbound channel prior to dialing.
1031
1032 REDIRECTING
1033 ------------------
1034  * Redirecting reasons can now be set to arbitrary strings. This means
1035    that the REDIRECTING dialplan function can be used to set the redirecting
1036    reason to any string. It also allows for custom strings to be read as the
1037    redirecting reason from SIP Diversion headers.
1038
1039 SPEECH_ENGINE
1040 ------------------
1041  * The SPEECH_ENGINE function now supports read operations. When read from, it
1042    will return the current value of the requested attribute.
1043
1044 VMCOUNT:
1045 ------------------
1046  * Mailboxes defined by app_voicemail MUST be referenced by the rest of the
1047    system as mailbox@context.  The rest of the system cannot add @default
1048    to mailbox identifiers for app_voicemail that do not specify a context
1049    any longer.  It is a mailbox identifier format that should only be
1050    interpreted by app_voicemail.
1051
1052
1053 Resources
1054 ------------------
1055
1056 res_agi (Asterisk Gateway Interface)
1057 ------------------
1058  * The manager event AGIExec has been split into AGIExecStart and AGIExecEnd.
1059
1060  * The manager event AsyncAGI has been split into AsyncAGIStart, AsyncAGIExec,
1061    and AsyncAGIEnd.
1062
1063  * The CONTROL STREAM FILE command now accepts an offsetms parameter. This
1064    will start the playback of the audio at the position specified. It will
1065    also return the final position of the file in 'endpos'.
1066
1067  * The CONTROL STREAM FILE command will now populate the CPLAYBACKSTATUS
1068    channel variable if the user stopped the file playback or if a remote
1069    entity stopped the playback. If neither stopped the playback, it will
1070    indicate the overall success/failure of the playback. If stopped early,
1071    the final offset of the file will be set in the CPLAYBACKOFFSET channel
1072    variable.
1073
1074  * The SAY ALPHA command now accepts an additional parameter to control
1075    whether it specifies the case of uppercase, lowercase, or all letters to
1076    provide functionality similar to SayAlphaCase.
1077
1078 res_ari (Asterisk RESTful Interface) (and others)
1079 ------------------
1080  * The Asterisk RESTful Interface (ARI) provides a mechanism to expose and
1081    control telephony primitives in Asterisk by remote client. This includes
1082    channels, bridges, endpoints, media, and other fundamental concepts. Users
1083    of ARI can develop their own communications applications, controlling
1084    multiple channels using an HTTP RESTful interface and receiving JSON events
1085    about the objects via a WebSocket connection. ARI can be configured in
1086    Asterisk via ari.conf. For more information on ARI, see
1087    https://wiki.asterisk.org/wiki/x/0YCLAQ
1088
1089 res_parking
1090 -------------------
1091  * Parking has been extracted from the Asterisk core as a loadable module,
1092    res_parking. Configuration for parking is now provided by res_parking.conf.
1093    Configuration through features.conf is no longer supported.
1094
1095  * res_parking uses the configuration framework. If an invalid configuration is
1096    supplied, res_parking will fail to load or fail to reload. Previously,
1097    invalid configurations would generally be accepted, with certain errors
1098    resulting in individually disabled parking lots.
1099
1100  * Parked calls are now placed in bridges. While this is largely an
1101    architectural change, it does have implications on how channels in a parking
1102    lot are viewed. For example, commands that display channels in bridges will
1103    now also display the channels in a parking lot.
1104
1105  * The order of arguments for the new parking applications have been modified.
1106    Timeout and return context/exten/priority are now implemented as options,
1107    while the name of the parking lot is now the first parameter. See the
1108    application documentation for Park, ParkedCall, and ParkAndAnnounce for more
1109    in-depth information as well as syntax.
1110
1111  * Extensions are by default no longer automatically created in the dialplan to
1112    park calls or pickup parked calls. Generation of dialplan extensions can be
1113    enabled using the 'parkext' configuration option.
1114
1115  * ADSI functionality for parking is no longer supported. The 'adsipark'
1116    configuration option has been removed as a result.
1117
1118  * The PARKINGSLOT channel variable has been deprecated in favor of
1119    PARKING_SPACE to match the naming scheme of the new system.
1120
1121  * PARKING_SPACE and PARKEDLOT channel variables will now be set for a parked
1122    channel even when the configuration option 'comebactoorigin' is enabled.
1123
1124  * A new CLI command 'parking show' has been added. This allows a user to
1125    inspect the parking lots that are currently in use.
1126    'parking show <parkinglot>' will also show the parked calls in a specific
1127    parking lot.
1128
1129  * The CLI command 'parkedcalls' is now deprecated in favor of
1130    'parking show <parkinglot>'.
1131
1132  * The AMI command 'ParkedCalls' will now accept a 'ParkingLot' argument which
1133    can be used to get a list of parked calls for a specific parking lot.
1134
1135  * The AMI command 'Park' field 'Channel2' has been deprecated and replaced
1136    with 'TimeoutChannel'. If both 'Channel2' and 'TimeoutChannel' are
1137    specified, 'TimeoutChannel' will be used. The field 'TimeoutChannel' is no
1138    longer a required argument.
1139
1140  * The ParkAndAnnounce application is now provided through res_parking instead
1141    of through the separate app_parkandannounce module.
1142
1143  * ParkAndAnnounce will no longer go to the next position in dialplan on timeout
1144    by default. Instead, it will follow the timeout rules of the parking lot. The
1145    old behavior can be reproduced by using the 'c' option.
1146
1147  * Dynamic parking lots will now fail to be created under the following
1148    conditions:
1149    - if the parking lot specified by PARKINGDYNAMIC does not exist
1150    - if they require exclusive park and parkedcall extensions which overlap
1151      with existing parking lots.
1152
1153  * Dynamic parking lots will be cleared on reload for dynamic parking lots that
1154    currently contain no calls. Dynamic parking lots containing parked calls
1155    will persist through the reloads without alteration.
1156
1157  * If 'parkext_exclusive' is set for a parking lot and that extension is
1158    already in use when that parking lot tries to register it, this is now
1159    considered a parking system configuration error. Configurations which do
1160    this will be rejected.
1161
1162  * Added channel variable PARKER_FLAT. This contains the name of the extension
1163    that would be used if 'comebacktoorigin' is enabled. This can be useful when
1164    comebacktoorigin is disabled, but the dialplan or an external control
1165    mechanism wants to use the extension in the park-dial context that was
1166    generated to re-dial the parker on timeout.
1167
1168 res_pjsip (and many others)
1169 ------------------
1170  * A large number of resource modules make up the SIP stack based on pjsip.
1171    The chan_pjsip channel driver users these resource modules to provide
1172    various SIP functionality in Asterisk. The majority of configuration for
1173    these modules is performed in pjsip.conf. Other modules may use their
1174    own configuration files.
1175
1176 res_rtp_asterisk
1177 ------------------
1178  * ICE/STUN/TURN support in res_rtp_asterisk has been made optional.  To enable
1179    them, an Asterisk-specific version of PJSIP needs to be installed.
1180    Tarballs are available from https://github.com/asterisk/pjproject/tags/.
1181
1182 res_statsd/res_chan_stats
1183 ------------------
1184  * A new resource module, res_statsd, has been added, which acts as a statsd
1185    client. This module allows Asterisk to publish statistics to a statsd
1186    server. In conjunction with res_chan_stats, it will publish statistics about
1187    channels to the statsd server. It can be configured via res_statsd.conf.
1188
1189 res_xmpp
1190 ------------------
1191  * Device state for XMPP buddies is now available using the following format:
1192    XMPP/<client name>/<buddy address>
1193    If any resource is available the device state is considered to be not in use.
1194    If no resources exist or all are unavailable the device state is considered
1195    to be unavailable.
1196
1197
1198 Scripts
1199 ------------------
1200
1201 Realtime/Database Scripts
1202 ------------------
1203  * Asterisk previously included example db schemas in the contrib/realtime/
1204    directory of the source tree.  This has been replaced by a set of database
1205    migrations using the Alembic framework.  This allows you to use alembic to
1206    initialize the database for you.  It will also serve as a database migration
1207    tool when upgrading Asterisk in the future.
1208
1209    See contrib/ast-db-manage/README.md for more details.
1210
1211 sip_to_res_pjsip.py
1212 -------------------
1213  * A new script has been added in the contrib/scripts/sip_to_res_pjsip folder.
1214    This python script will convert an existing sip.conf file to a
1215    pjsip.conf file, for use with the chan_pjsip channel driver. This script
1216    is meant to be an aid in converting an existing chan_sip configuration to
1217    a chan_pjsip configuration, but it is expected that configuration beyond
1218    what the script provides will be needed.
1219
1220
1221 ------------------------------------------------------------------------------
1222 --- Functionality changes from Asterisk 10 to Asterisk 11 --------------------
1223 ------------------------------------------------------------------------------
1224
1225 Build System
1226 -------------------
1227  * The Asterisk build system will now build and install a shared library
1228    (libasteriskssl.so) used to wrap various initialization and shutdown functions
1229    from the libssl and libcrypto libraries provided by OpenSSL. This is done so
1230    that Asterisk can ensure that these functions do *not* get called by any
1231    modules that are loaded into Asterisk, since they should only be called once
1232    in any single process. If desired, this feature can be disabled by supplying
1233    the "--disable-asteriskssl" option to the configure script.
1234
1235  * A new make target, 'full', has been added to the Makefile.  This performs
1236    the same compilation actions as make all, but will also scan the entirety of
1237    each source file for documentation.  This option is needed to generate AMI
1238    event documentation.  Note that your system must have Python in order for
1239    this make target to succeed.
1240
1241  * The optimization portion of the build system has been reworked to avoid
1242    broken builds on certain architectures.  All architecture-specific
1243    optimization has been removed in favor of using -march=native to allow gcc
1244    to detect the environment in which it is running when possible.  This can
1245    be toggled as BUILD_NATIVE under "Compiler Flags" in menuselect.
1246
1247  * BUILD_CFLAGS and BUILD_LDFLAGS can now be passed to menuselect, e.g.,
1248    make BUILD_CFLAGS="whatever" BUILD_LDFLAGS="whatever"
1249
1250  * Remove "asterisk/version.h" in favor of "asterisk/ast_version.h".  If you
1251    previously parsed the header file to obtain the version of Asterisk, you
1252    will now have to go through Asterisk to get the version information.
1253
1254
1255 Applications
1256 -------------------
1257
1258 Bridge
1259 -------------------
1260  * Added 'F()' option. Similar to the dial option, this can be supplied with
1261    arguments indicating where the callee should go after the caller is hung up,
1262    or without options specified, the priority after the Queue will be used.
1263
1264
1265 ConfBridge
1266 -------------------
1267  * Added menu action admin_toggle_mute_participants.  This will mute / unmute
1268    all non-admin participants on a conference.  The confbridge configuration
1269    file also allows for the default sounds played to all conference users when
1270    this occurs to be overriden using sound_participants_unmuted and
1271    sound_participants_muted.
1272
1273  * Added menu action participant_count.  This will playback the number of
1274    current participants in a conference.
1275
1276  * Added announcement configuration option to user profile. If set the sound
1277    file will be played to the user, and only the user, upon joining the
1278    conference bridge.
1279
1280  * Added record_file_append option that defaults to "yes", but if set to no
1281    will create a new file between each start/stop recording.
1282
1283
1284 Dial
1285 -------------------
1286  * Added 'b' and 'B' options to Dial that execute a Gosub on callee and caller
1287    channels respectively before the callee channels are called.
1288
1289
1290 ExternalIVR
1291 -------------------
1292  * Added support for IPv6.
1293
1294  * Add interrupt ('I') command to ExternalIVR.  Sending this command from an
1295    external process will cause the current playlist to be cleared, including
1296    stopping any audio file that is currently playing.  This is useful when you
1297    want to interrupt audio playback only when specific DTMF is entered by the
1298    caller.
1299
1300
1301 FollowMe
1302 -------------------
1303  * A new option, 'I' has been added to app_followme. By setting this option,
1304    Asterisk will not update the caller with connected line changes when they
1305    occur.  This is similar to app_dial and app_queue.
1306
1307  * The 'N' option is now ignored if the call is already answered.
1308
1309  * Added 'b' and 'B' options to FollowMe that execute a Gosub on callee
1310    and caller channels respectively before the callee channels are called.
1311
1312  * The winning FollowMe outgoing call is now put on hold if the caller put it on
1313    hold.
1314
1315
1316 MixMonitor
1317 ------------------
1318  * MixMonitor hooks now have IDs associated with them which can be used to
1319    assign a target to StopMixMonitor. Use of MixMonitor's i(variable) option
1320    will allow storage of the MixMontior ID in a channel variable. StopMixmonitor
1321    now accepts that ID as an argument.
1322
1323  * Added 'm' option, which stores a copy of the recording as a voicemail in the
1324    indicated mailboxes.
1325
1326
1327 MySQL
1328 -------------------
1329  * The connect action in app_mysql now allows you to specify a port number to
1330    connect to.  This is useful if you run a MySQL server on a non-standard
1331    port number.
1332
1333
1334 OSP Applications
1335 -------------------
1336  * Increased the default number of allowed destinations from 5 to 12.
1337
1338
1339 Page
1340 -------------------
1341  * The app_page application now no longer depends on DAHDI or app_meetme.  It
1342    has been re-architected to use app_confbridge internally.
1343
1344
1345 Queue
1346 -------------------
1347  * Added queue options autopausebusy and autopauseunavail for automatically
1348    pausing a queue member when their device reports busy or congestion.
1349
1350  * The 'ignorebusy' option for queue members has been deprecated in favor of
1351    the option 'ringinuse. Also a 'queue set ringinuse' CLI command has been
1352    added as well as an AMI action 'QueueMemberRingInUse' to set this variable on a
1353    per interface basis. Individual ringinuse values can now be set in
1354    queues.conf via an argument to member definitions. Lastly, the queue
1355    'ringinuse' setting now only determines defaults for the per member
1356    'ringinuse' setting and does not override per member settings like it does
1357    in earlier versions.
1358
1359  * Added 'F()' option. Similar to the dial option, this can be supplied with
1360    arguments indicating where the callee should go after the caller is hung up,
1361    or without options specified, the priority after the Queue will be used.
1362
1363  * Added new option log_member_name_as_agent, which will cause the membername to
1364    be logged in the agent field for ADDMEMBER and REMOVEMEMBER queue events if a
1365    state_interface has been set.
1366
1367  * Add queue monitoring hints.  exten => 8501,hint,Queue:markq.
1368
1369  * App_queue will now play periodic announcements for the caller that
1370    holds the first position in the queue while waiting for answer.
1371
1372 SayUnixTime
1373 ------------------
1374  * Added 'j' option to SayUnixTime. SayUnixTime no longer auto jumps to extension
1375    when receiving DTMF.  Use the 'j' option to enable extension jumping. Also
1376    changed arguments to SayUnixTime so that every option is truly optional even
1377    when using multiple options (so that j option could be used without having to
1378    manually specify timezone and format) There are other benefits, e.g., format
1379    can now be used without specifying time zone as well.
1380
1381
1382 Voicemail
1383 ------------------
1384  * Addition of the VM_INFO function - see Function changes.
1385
1386  * The imapserver, imapport, and imapflags configuration options can now be
1387    overriden on a user by user basis.
1388
1389  * When voicemail plays a message's envelope with saycid set to yes, when
1390    reaching the caller id field it will play a recording of a file with the same
1391    base name as the sender's callerid if there is a similarly named file in
1392    <astspooldir>/recordings/callerids/
1393
1394  * Voicemails now contains a unique message identifier "msg_id", which is stored
1395    in the message envelope with the sound files.  IMAP backends will now store
1396    the message identifiers with a header of "X-Asterisk-VM-Message-ID".  ODBC
1397    backends will store the message identifier in a "msg_id" column.  See
1398    UPGRADE.txt for more information.
1399
1400  * Added VoiceMailPlayMsg application.  This application will play a single
1401    voicemail message from a mailbox.  The result of the application, SUCCESS or
1402    FAILED, is stored in the channel variable VOICEMAIL_PLAYBACKSTATUS.
1403
1404
1405 Functions
1406 ------------------
1407  * Hangup handlers can be attached to channels using the CHANNEL() function.
1408    Hangup handlers will run when the channel is hung up similar to the h
1409    extension. The hangup_handler_push option will push a GoSub compatible
1410    location in the dialplan onto the channel's hangup handler stack.  The
1411    hangup_handler_pop option will remove the last added location, and optionally
1412    replace it with a new GoSub compatible location.  The hangup_handler_wipe
1413    option will remove all locations on the stack, and optionally add a new
1414    location.
1415
1416  * The expression parser now recognizes the ABS() absolute value function,
1417    which will convert negative floating point values to positive values.
1418
1419  * FAXOPT(faxdetect) will enable a generic fax detect framehook for dialplan
1420    control of faxdetect.
1421
1422  * Addition of the VM_INFO function that can be used to retrieve voicemail
1423    user information, such as the email address and full name.
1424    The MAILBOX_EXISTS dialplan function has been deprecated in favour of
1425    VM_INFO.
1426
1427  * The REDIRECTING function now supports the redirecting original party id
1428    and reason.
1429
1430  * Two new functions have been added: FEATURE() and FEATUREMAP().  FEATURE()
1431    lets you set some of the configuration options from the [general] section
1432    of features.conf on a per-channel basis.  FEATUREMAP() lets you customize
1433    the key sequence used to activate built-in features, such as blindxfer,
1434    and automon.  See the built-in documentation for details.
1435
1436  * MESSAGE(from) for incoming SIP messages now returns "display-name" <uri>
1437    instead of simply the uri.  This is the format that MessageSend() can use
1438    in the from parameter for outgoing SIP messages.
1439
1440  * Added the PRESENCE_STATE function.  This allows retrieving presence state
1441    information from any presence state provider.  It also allows setting
1442    presence state information from a CustomPresence presence state provider.
1443    See AMI/CLI changes for related commands.
1444
1445  * Added the AMI_CLIENT function to make manager account attributes available
1446    to the dialplan. It currently supports returning the current number of
1447    active sessions for a given account.
1448
1449  * Added support for private party ID information to CALLERID, CONNECTEDLINE,
1450    and the REDIRECTING functions.
1451
1452
1453 Channel Drivers
1454 ------------------
1455
1456 chan_local
1457 ------------------
1458  * Added a manager event "LocalBridge" for local channel call bridges between
1459    the two pseudo-channels created.
1460
1461
1462 chan_dahdi
1463 ------------------
1464  * Added dialtone_detect option for analog ports to disconnect incoming
1465    calls when dialtone is detected.
1466
1467  * Added option colp_send to send ISDN connected line information.  Allowed
1468    settings are block, to not send any connected line information; connect, to
1469    send connected line information on initial connect; and update, to send
1470    information on any update during a call.  Default is update.
1471
1472  * Add options namedcallgroup and namedpickupgroup to support installations
1473    where a higher number of groups (>64) is required.
1474
1475  * Added support to use private party ID information with PRI calls.
1476
1477
1478 chan_motif
1479 ------------------
1480  * A new channel driver named chan_motif has been added which provides support for
1481    Google Talk and Jingle in a single channel driver. This new channel driver includes
1482    support for both audio and video, RFC2833 DTMF, all codecs supported by Asterisk,
1483    hold, unhold, and ringing notification. It is also compliant with the current Jingle
1484    specification, current Google Jingle specification, and the original Google Talk
1485    protocol.
1486
1487
1488 chan_ooh323
1489 ------------------
1490  * Added NAT support for RTP.  Setting in config is 'nat', which can be set
1491    globally and overriden on a peer by peer basis.
1492
1493  * Direct media functionality has been added. Options in config are:
1494    directmedia (directrtp) and directrtpsetup (earlydirect)
1495
1496  * ChannelUpdate events now contain a CallRef header.
1497
1498
1499 chan_sip
1500 ------------------
1501  * Asterisk will no longer substitute CID number for CID name in the display
1502    name field if CID number exists without a CID name. This change improves
1503    compatibility with certain device features such as Avaya IP500's directory
1504    lookup service.
1505
1506  * A new setting for autocreatepeer (autocreatepeer=persistent) allows peers
1507    created using that setting to not be removed during SIP reload.
1508
1509  * Added settings recordonfeature and recordofffeature.  When receiving an INFO
1510    request with a "Record:" header, this will turn the requested feature on/off.
1511    Allowed values are 'automon', 'automixmon', and blank to disable.  Note that
1512    dynamic features must be enabled and configured properly on the requesting
1513    channel for this to function properly.
1514
1515  * Add support to realtime for the 'callbackextension' option.
1516
1517  * When multiple peers exist with the same address, but differing
1518    callbackextension options, incoming requests that are matched by address
1519    will be matched to the peer with the matching callbackextension if it is
1520    available.
1521
1522  * Two new NAT options, auto_force_rport and auto_comedia, have been added
1523    which set the force_rport and comedia options automatically if Asterisk
1524    detects that an incoming SIP request crossed a NAT after being sent by
1525    the remote endpoint.
1526
1527  * The default global nat setting in sip.conf has been changed from force_rport
1528    to auto_force_rport.
1529
1530  * NAT settings are now a combinable list of options. The equivalent of the
1531    deprecated nat=yes is nat=force_rport,comedia. nat=no behaves as before.
1532
1533  * Adds an option send_diversion which can be disabled to prevent
1534    diversion headers from automatically being added to INVITE requests.
1535
1536  * Add support for lightweight NAT keepalive. If enabled a blank packet will
1537    be sent to the remote host at a given interval to keep the NAT mapping open.
1538    This can be enabled using the keepalive configuration option.
1539
1540  * Add option 'tonezone' to specify country code for indications.  This option
1541    can be set both globally and overridden for specific peers.
1542
1543  * The SIP Security Events Framework now supports IPv6.
1544
1545  * Add a new setting for directmedia, 'outgoing', to alleviate INVITE glares
1546    between multiple user agents. When set, for directmedia reinvites,
1547    Asterisk will not send an immediate reinvite on an incoming call leg. This
1548    option is useful when peered with another SIP user agent that is known to
1549    send immediate direct media reinvites upon call establishment.
1550
1551  * Add support for WebSocket transport. This can be configured using 'ws' or 'wss'
1552    as the transport.
1553
1554  * Add options subminexpiry and submaxexpiry to set limits of subscription
1555    timer independently from registration timer settings. The setting of the
1556    registration timer limits still is done by options minexpiry, maxexpiry
1557    and defaultexpiry. For backwards compatibility the setting of minexpiry
1558    and maxexpiry also is used to configure the subscription timer limits if
1559    subminexpiry and submaxexpiry are not set in sip.conf.
1560
1561  * Set registration timer limits to default values when reloading sip
1562    configuration and values are not set by configuration.
1563
1564  * Add options namedcallgroup and namedpickupgroup to support installations
1565    where a higher number of groups (>64) is required.
1566
1567  * When a MESSAGE request is received, the address the request was received from
1568    is now saved in the SIP_RECVADDR variable.
1569
1570  * Add ANI2/OLI parsing for SIP.  The "From" header in INVITE requests is now
1571    parsed for the presence of "isup-oli", "ss7-oli", or "oli" tags.  If present,
1572    the ANI2/OLI information is set on the channel, which can be retrieved using
1573    the CALLERID function.
1574
1575  * Peers can now be configured to support negotiation of ICE candidates using
1576    the setting icesupport.  See res_rtp_asterisk changes for more information.
1577
1578  * Added support for format attribute negotiation.  See the Codecs changes for
1579    more information.
1580
1581  * Extra headers specified with SIPAddHeader are sent with the REFER message
1582    when using Transfer application. See refer_addheaders in sip.conf.sample.
1583
1584  * Added support to use private party ID information with calls.
1585
1586  * Adds an option discard_remote_hold_retrieval that when set stops telling
1587    the peer to start music on hold.
1588
1589
1590 chan_skinny
1591 ------------------
1592  * Added skinny version 17 protocol support.
1593
1594
1595 chan_unistim
1596 --------------------
1597  * Added ability to use multiple lines for a single phone.  This allows multiple
1598    calls to occur on a single phone, using callwaiting and switching between calls.
1599
1600  * Added option 'sharpdial' allowing end dialing by pressing # key
1601
1602  * Added option 'interdigit_timer' to control phone dial timeout
1603
1604  * Added options 'cwstyle', 'cwvolume' controlling callwaiting appearance
1605
1606  * Added global 'debug' option, that enables debug in channel driver
1607
1608  * Added ability to translate on-screen menu in multiple languages. Tested on
1609    Russian languages.  Supported encodings: ISO 8859-1, ISO 8859-2, ISO 8859-4,
1610    ISO 8859-5, ISO 2022-JP. Language controlled by 'language' and on-screen
1611    menu of phone
1612
1613  * In addition to English added French and Russian languages for on-screen menus
1614
1615  * Reworked dialing number input: added dialing by timeout, immediate dial on
1616    on dialplan compare, phone number length now not limited by screen size
1617
1618  * Added ability to pickup a call using features.conf defined value and
1619    on-screen key
1620
1621
1622 chan_mISDN:
1623 ------------------
1624  * Add options namedcallgroup and namedpickupgroup to support installations
1625    where a higher number of groups (>64) is required.
1626
1627  * Added support to use private party ID information with calls.
1628
1629
1630 Core
1631 ------------------
1632  * The minimum DTMF duration can now be configured in asterisk.conf
1633    as "mindtmfduration". The default value is (as before) set to 80 ms.
1634    (previously it was only available in source code)
1635
1636  * Named ACLs can now be specified in acl.conf and used in configurations that
1637    use ACLs. As a general rule, if some derivative of 'permit' or 'deny' is
1638    used to specify an ACL, a similar form of 'acl' will add a named ACL to the
1639    working ACL. In addition, some CLI commands have been added to provide
1640    show information and allow for module reloading - see CLI Changes.
1641
1642  * Rules in ACLs (specified using 'permit' and 'deny') can now contain multiple
1643    items (separated by commas), and items in the rule can be negated by prefixing
1644    them with '!'. This simplifies Asterisk Realtime configurations, since it is no
1645    longer necessray to control the order that the 'permit' and 'deny' columns are
1646    returned from queries.
1647
1648  * DUNDi now allows the built in variables ${NUMBER}, ${IPADDR} and ${SECRET} to
1649    be used within the dynamic weight attribute when specifying a mapping.
1650
1651  * CEL backends can now be configured to show "USER_DEFINED" in the EventName
1652    header, instead of putting the user defined event name there.  When enabled
1653    the UserDefType header is added for user defined events.  This feature is
1654    enabled with the setting show_user_defined.
1655
1656  * Macro has been deprecated in favor of GoSub.  For redirecting and connected
1657    line purposes use the following variables instead of their macro equivalents:
1658    REDIRECTING_SEND_SUB, REDIRECTING_SEND_SUB_ARGS, CONNECTED_LINE_SEND_SUB,
1659    CONNECTED_LINE_SEND_SUB_ARGS.  For CCSS, use cc_callback_sub instead of
1660    cc_callback_macro in channel configurations.
1661
1662  * Asterisk can now use a system-provided NetBSD editline library (libedit) if it
1663    is available.
1664
1665  * Call files now support the "early_media" option to connect with an outgoing
1666    extension when early media is received.
1667
1668  * Added support to use private party ID information with calls.
1669
1670
1671 AGI
1672 ------------------
1673  * A new channel variable, AGIEXITONHANGUP, has been added which allows
1674    Asterisk to behave like it did in Asterisk 1.4 and earlier where the
1675    AGI application would exit immediately after a channel hangup is detected.
1676
1677  * IPv6 addresses are now supported when using FastAGI (agi://).  Hostnames
1678    are resolved and each address is attempted in turn until one succeeds or
1679    all fail.
1680
1681
1682 AMI (Asterisk Manager Interface)
1683 ------------------
1684  * The originate action now has an option "EarlyMedia" that enables the
1685    call to bridge when we get early media in the call. Previously,
1686    early media was disregarded always when originating calls using AMI.
1687
1688  * Added setvar= option to manager accounts (much like sip.conf)
1689
1690  * Originate now generates an error response if the extension given is not found
1691    in the dialplan
1692
1693  * MixMonitor will now show IDs associated with the mixmonitor upon creating
1694    them if the i(variable) option is used. StopMixMonitor will accept
1695    MixMonitorID as an option to close specific MixMonitors.
1696
1697  * The SIPshowpeer manager action response field "SIP-Forcerport" has been
1698    updated to include information about peers configured with
1699    nat=auto_force_rport by returning "A" if auto_force_rport is set and nat is
1700    detected, and "a" if it is set and nat is not detected. "Y" and "N" are still
1701    returned if auto_force_rport is not enabled.
1702
1703  * Added SIPpeerstatus manager command which will generate PeerStatus events
1704    similar to the existing PeerStatus events found in chan_sip on demand.
1705
1706  * Hangup now can take a regular expression as the Channel option.  If you want
1707    to hangup multiple channels, use /regex/ as the Channel option.  Existing
1708    behavior to hanging up a single channel is unchanged, but if you pass a regex,
1709    the manager will send you a list of channels back that were hung up.
1710
1711  * Support for IPv6 addresses has been added.
1712
1713  * AMI Events can now be documented in the Asterisk source. Note that AMI event
1714    documentation is only generated when Asterisk is compiled using 'make full'.
1715    See the CLI section for commands to display AMI event information.
1716
1717  * The AMI Hangup event now includes the AccountCode header so you can easily
1718    correlate with AMI Newchannel events.
1719
1720  * The QueueMemberStatus, QueueMemberAdded, and QueueMember events now include
1721    the StateInterface of the queue member.
1722
1723  * Added AMI event SessionTimeout in the Call category that is issued when a
1724    call is terminated due to either RTP stream inactivity or SIP session timer
1725    expiration.
1726
1727  * CEL events can now contain a user defined header UserDefType.  See core
1728    changes for more information.
1729
1730  * OOH323 ChannelUpdate events now contain a CallRef header.
1731
1732  * Added PresenceState command.  This command will report the presence state for
1733    the given presence provider.
1734
1735  * Added Parkinglots command.  This will list all parking lots as a series of
1736    AMI Parkinglot events.
1737
1738  * Added MessageSend command.  This behaves in the same manner as the
1739    MessageSend application, and is a technolgoy agnostic mechanism to send out
1740    of call text messages.
1741
1742  * Added "message" class authorization.  This grants an account permission to
1743    send out of call messages.  Write-only.
1744
1745
1746 CLI
1747 -------------------
1748  * The "dialplan add include" command has been modified to create context a context
1749    if one does not already exist. For instance, "dialplan add include foo into bar"
1750    will create context "bar" if it does not already exist.
1751
1752  * A  "dialplan remove context" command has been added to remove a context from
1753    the dialplan
1754
1755  * The "mixmonitor list <channel>" command will now show MixMonitor ID, and the
1756    filenames of all running mixmonitors on a channel.
1757
1758  * The debug level of "pri set debug" is now a bitmask ranging from 0 to 15 if
1759    numeric instead of 0, 1, or 2.
1760
1761  * "stun show status" will show a table describing how the STUN client is
1762    behaving.
1763
1764  * "acl show [named acl]" will show information regarding a Named ACL.  The
1765    acl module can be reloaded with "reload acl".
1766
1767  * Added CLI command to display AMI event information - "manager show events",
1768    which shows a list of all known and documented AMI events, and "manager show
1769    event [event name]", which shows detail information about a specific AMI
1770    event.
1771
1772  * The result of the CLI command "queue show" now includes the state interface
1773    information of the queue member.
1774
1775  * The command "core set verbose" will now set a separate level of logging for
1776    each remote console without affecting any other console.
1777
1778  * Added command "cdr show pgsql status" to check connection status
1779
1780  * "sip show channel" will now display the complete route set.
1781
1782  * Added "presencestate list" command.  This command will list all custom
1783    presence states that have been set by using the PRESENCE_STATE dialplan
1784    function.
1785
1786  * Added "presencestate change <entity> <state>[,<subtype>[,message[,options]]]"
1787    command.  This changes a custom presence to a new state.
1788
1789
1790 Codecs
1791 -------------------
1792  * Codec lists may now be modified by the '!' character, to allow succinct
1793    specification of a list of codecs allowed and disallowed, without the
1794    requirement to use two different keywords.  For example, to specify all
1795    codecs except g729 and g723, one need only specify allow=all,!g729,!g723.
1796
1797  * Add support for parsing SDP attributes, generating SDP attributes, and
1798    passing it through. This support includes codecs such as H.263, H.264, SILK,
1799    and CELT. You are able to set up a call and have attribute information pass.
1800    This should help considerably with video calls.
1801
1802  * The iLBC codec can now use a system-provided iLBC library if one is installed,
1803    just like the GSM codec.
1804
1805 DUNDi changes
1806 -------------
1807  * Added CLI commands dundi show hints and dundi show cache which will list DUNDi
1808    'DONTASK' hints in the cache and list all DUNDi cache entires respectively.
1809
1810 Logging
1811 -------------------
1812  * Asterisk version and build information is now logged at the beginning of a
1813    log file.
1814
1815  * Threads belonging to a particular call are now linked with callids which get
1816    added to any log messages produced by those threads. Log messages can now be
1817    easily identified as involved with a certain call by looking at their call id.
1818    Call ids may also be attached to log messages for just about any case where
1819    it can be determined to be related to a particular call.
1820
1821  * Each logging destination and console now have an independent notion of the
1822    current verbosity level.  Logger.conf now allows an optional argument to
1823    the 'verbose' specifier, indicating the level of verbosity sent to that
1824    particular logging destination.  Additionally, remote consoles now each
1825    have their own verbosity level.  The command 'core set verbose' will now set
1826    a separate level for each remote console without affecting any other
1827    console.
1828
1829
1830 Music On Hold
1831 -------------------
1832  * Added 'announcement' option which will play at the start of MOH and between
1833    songs in modes of MOH that can detect transitions between songs (eg.
1834    files, mp3, etc).
1835
1836
1837 Parking
1838 -------------------
1839  * New per parking lot options: comebackcontext and comebackdialtime. See
1840    configs/features.conf.sample for more details.
1841
1842  * Channel variable PARKER is now set when comebacktoorigin is disabled in
1843    a parking lot.
1844
1845  * Channel variable PARKEDCALL is now set with the name of the parking lot
1846    when a timeout occurs.
1847
1848
1849 CDRs
1850 -------------------
1851
1852 CDR Postgresql Driver
1853 -------------------
1854  * Added command "cdr show pgsql status" to check connection status
1855
1856
1857 CDR Adaptive ODBC Driver
1858 -------------------
1859  * Added schema option for databases that support specifying a schema.
1860
1861
1862 Resource Modules
1863 -------------------
1864
1865 Calendars
1866 -------------------
1867  * A CALENDAR_SUCCESS=1/0 channel variable is now set to show whether or not
1868    CALENDAR_WRITE has completed successfully.
1869
1870
1871 res_rtp_asterisk
1872 -------------------
1873  * A new option, 'probation' has been added to rtp.conf
1874    RTP in strictrtp mode can now require more than 1 packet to exit learning
1875    mode with a new source (and by default requires 4). The probation option
1876    allows the user to change the required number of packets in sequence to any
1877    desired value. Use a value of 1 to essentially restore the old behavior.
1878    Also, with strictrtp on, Asterisk will now drop all packets until learning
1879    mode has successfully exited. These changes are based on how pjmedia handles
1880    media sources and source changes.
1881
1882  * Add support for ICE/STUN/TURN in res_rtp_asterisk.  This option can be
1883    enabled or disabled using the icesupport setting.  A variety of other
1884    settings have been introduced to configure STUN/TURN connections.
1885
1886
1887 res_corosync
1888 -------------------
1889  * A new module, res_corosync, has been introduced.  This module uses the
1890    Corosync cluster enginer (http://www.corosync.org) to allow a local cluster
1891    of Asterisk servers to both Message Waiting Indication (MWI) and/or
1892    Device State (presence) information.  This module is very similar to, and
1893    is a replacement for the res_ais module that was in previous releases of
1894    Asterisk.
1895
1896
1897 res_xmpp
1898 -------------------
1899  * This module adds a cleaned up, drop-in replacement for res_jabber called
1900    res_xmpp. This provides the same externally facing functionality but is
1901    implemented differently internally.  res_jabber has been deprecated in favor
1902    of res_xmpp; please see the UPGRADE.txt file for more information.
1903
1904
1905 Scripts
1906 -------------------
1907  * The safe_asterisk script has been updated to allow several of its parameters
1908    to be set from environment variables.  This also enables a custom run
1909    directory of Asterisk to be specified, instead of defaulting to /tmp.
1910
1911  * The live_ast script will now look for the LIVE_AST_BASE_DIR variable and use
1912    its value to determine the directory to assume is the top-level directory of
1913    the source tree.  If the variable is not set, it defaults to the current
1914    behavior and uses the current working directory.
1915
1916 ------------------------------------------------------------------------------
1917 --- Functionality changes from Asterisk 1.8 to Asterisk 10 -------------------
1918 ------------------------------------------------------------------------------
1919
1920 Text Messaging
1921 --------------
1922  * Asterisk now has protocol independent support for processing text messages
1923    outside of a call.  Messages are routed through the Asterisk dialplan.
1924    SIP MESSAGE and XMPP are currently supported.  There are options in
1925    jabber.conf and sip.conf to allow enabling these features.
1926      -> jabber.conf: see the "sendtodialplan" and "context" options.
1927      -> sip.conf: see the "accept_outofcall_message", "auth_message_requests"
1928         and "outofcall_message_context" options.
1929    The MESSAGE() dialplan function and MessageSend() application have been
1930    added to go along with this functionality.  More detailed usage information
1931    can be found on the Asterisk wiki (http://wiki.asterisk.org/).
1932  * If real-time text support (T.140) is negotiated, it will be preferred for
1933    sending text via the SendText application. For example, via SIP, messages
1934    that were once sent via the SIP MESSAGE request would be sent via RTP if
1935    T.140 text is negotiated for a call.
1936
1937 Parking
1938 -------
1939  * parkedmusicclass can now be set for non-default parking lots.
1940
1941 Asterisk Manager Interface
1942 --------------------------
1943  * PeerStatus now includes Address and Port.
1944  * Added Hold events for when the remote party puts the call on and off hold
1945    for chan_dahdi ISDN channels.
1946  * Added new action MeetmeListRooms to list active conferences (shows same
1947    data as "meetme list" at the CLI).
1948  * DAHDIShowChannels, SIPshowpeer, SIPpeers, and IAXpeers now contains a
1949    Description field that is set by 'description' in the channel configuration
1950    file.
1951  * Added Uniqueid header to UserEvent.
1952  * Added new action FilterAdd to control event filters for the current session.
1953    This requires the system permission and uses the same filter syntax as
1954    filters that can be defined in manager.conf
1955  * The Unlink event is now a Bridge event with Bridgestatus: Unlink. Previous
1956    versions had some instances of the event converted, but others were left
1957    as-is. All Unlink events should now be converted to Bridge events. The AMI
1958    protocol version number was incremented to 1.2 as a result of this change.
1959
1960 Asterisk HTTP Server
1961 --------------------------
1962  * The HTTP Server can bind to IPv6 addresses.
1963
1964 chan_dahdi
1965 --------------------------
1966  * Busy tone patterns featuring 2 silence and 2 tone lengths can now be used
1967    with busydetect.  usage example: busypattern=200,200,200,600
1968
1969 CLI Changes
1970 --------------------------
1971  * New 'gtalk show settings' command showing the current settings loaded from
1972    gtalk.conf.
1973  * The 'logger reload' command now supports an optional argument, specifying an
1974    alternate configuration file to use.
1975  * 'dialplan add extension' command will now automatically create a context if
1976    the specified context does not exist with a message indicated it did so.
1977  * 'sip show peers', 'iax show peers', and 'dahdi show peers' now contains a
1978    Description field which can be populated with 'description' in the channel
1979    configuration files (sip.conf, iax2.conf, and chan_dahdi.conf).
1980
1981 CDR
1982 --------------------------
1983  * The filter option in cdr_adaptive_odbc now supports negating the argument,
1984    thus allowing records which do NOT match the specified filter.
1985  * Added ability to log CONGESTION calls to CDR
1986
1987 CODECS
1988 --------------------------
1989  * Ability to define custom SILK formats in codecs.conf.
1990  * Addition of speex32 audio format with translation.
1991  * CELT codec pass-through support and ability to define
1992    custom CELT formats in codecs.conf.
1993  * Ability to read raw signed linear files with sample rates
1994    ranging from 8khz - 192khz.  The new file extensions introduced
1995    are .sln12, .sln24, .sln32, .sln44, .sln48, .sln96, .sln192.
1996  * Due to protocol limitations, channel drivers other than SIP (eg. IAX2, MGCP,
1997    Skinny, H.323, etc) can still only support the following codecs:
1998    Audio: ulaw, alaw, slin, slin16, g719, g722, g723, g726, g726aal2, g729, gsm,
1999           siren7, siren14, speex, speex16, ilbc, lpc10, adpcm
2000    Video: h261, h263, h263p, h264, mpeg4
2001    Image: jpeg, png
2002    Text:  red, t140
2003
2004 ConfBridge
2005 --------------------------
2006  * New highly optimized and customizable ConfBridge application capable of
2007    mixing audio at sample rates ranging from 8khz-96khz.
2008  * CONFBRIDGE dialplan function capable of creating dynamic ConfBridge user
2009    and bridge profiles on a channel.
2010  * CONFBRIDGE_INFO dialplan function capable of retrieving information
2011    about a conference such as locked status and number of parties, admins,
2012    and marked users.
2013  * Addition of video_mode option in confbridge.conf for adding video support
2014    into a bridge profile.
2015  * Addition of the follow_talker video_mode in confbridge.conf.  This video
2016    mode dynamically switches the video feed to always display the loudest talker
2017    supplying video in the conference.
2018
2019 Dialplan Variables
2020 ------------------
2021  * Added ASTETCDIR, ASTMODDIR, ASTVARLIBDIR, ASTDBDIR, ASTKEYDIR, ASTDATADIR,
2022    ASTAGIDIR, ASTSPOOLDIR, ASTRUNDIR, ASTLOGDIR which hold the equivalent
2023    variables from asterisk.conf.
2024
2025 Dialplan Functions
2026 ------------------
2027  * Addition of the JITTERBUFFER dialplan function. This function allows
2028    for jitterbuffering to occur on the read side of a channel.  By using
2029    this function conference applications such as ConfBridge and MeetMe can
2030    have the rx streams jitterbuffered before conference mixing occurs.
2031  * Added DB_KEYS, which lists the next set of keys in the Asterisk database
2032    hierarchy.
2033  * Added STRREPLACE function.  This function let's the user search a variable
2034    for a given string to replace with another string as many times as the
2035    user specifies or just throughout the whole string.
2036  * Added option to CHANNEL(pickupgroup) allow reading and setting the pickupgroup of channel.
2037  * Mark VALID_EXTEN() deprecated in favor of DIALPLAN_EXISTS()
2038  * Added extensions to chan_ooh323 in function CHANNEL()
2039
2040 libpri channel driver (chan_dahdi) DAHDI changes
2041 --------------------------
2042  * Added moh_signaling option to specify what to do when the channel's bridged
2043    peer puts the ISDN channel on hold.
2044  * Added display_send and display_receive options to control how the display ie
2045    is handled.  To send display text from the dialplan use the SendText()
2046    application when the option is enabled.
2047  * Added mcid_send option to allow sending a MCID request on a span.
2048
2049 Calendaring
2050 --------------------------
2051  * Added setvar option to calendar.conf to allow setting channel variables on
2052    notification channels.
2053  * Added "calendar show types" CLI command to list registered calendar
2054    connectors.
2055
2056 MixMonitor
2057 --------------------------
2058  * Added two new options, r and t with file name arguments to record
2059    single direction (unmixed) audio recording separate from the bidirectional
2060    (mixed) recording.  The mixed file name argument is optional now as long
2061    as at least one recording option is used.
2062
2063 FollowMe
2064 --------------------------
2065  * Added a new option, l, which will disable local call optimization for
2066    channels involved with the FollowMe thread.  Use this option to improve
2067    compatability for a FollowMe call with certain dialplan apps, options, and
2068    functions.
2069
2070 Meetme
2071 --------------------------
2072  * Added option "k" that will automatically close the conference when there's
2073    only one person left when a user exits the conference.
2074
2075 CEL
2076 --------------------------
2077  * cel_pgsql now supports the 'extra' column for data added using the
2078    CELGenUserEvent() application.
2079
2080 pbx_lua
2081 --------------------------
2082  * Support for defining hints has been added to pbx_lua.  See the 'hints' table
2083    in the sample extensions.lua file for syntax details.
2084  * Applications that perform jumps in the dialplan such as Goto will now
2085    execute properly.  When pbx_lua detects that the context, extension, or
2086    priority we are executing on has changed it will immediately return control
2087    to the asterisk PBX engine.  Currently the engine cannot detect a Goto to
2088    the priority after the currently executing priority.
2089  * An autoservice is now started by default for pbx_lua channels.  It can be
2090    stopped and restarted using the autoservice_stop() and autoservice_start()
2091    functions.
2092
2093 res_fax
2094 --------------------------
2095  * The ReceiveFAXStatus and SendFAXStatus manager events have been consolidated
2096    into a FAXStatus event with an 'Operation' header that will be either
2097    'send', 'receive', and 'gateway'.
2098  * T.38 gateway functionality has been added to res_fax (and res_fax_spandsp).
2099    Set FAXOPT(gateway)=yes to enable this functionality on a channel. This
2100    feature will handle converting a fax call between an audio T.30 fax terminal
2101    and an IFP T.38 fax terminal.
2102
2103 SIP Changes
2104 -----------
2105  * Add T38 support for REJECTED state where T.38 Negotiation is explicitly rejected.
2106  * Add option encryption_taglen to set auth taglen only 32 and 80 are supported currently.
2107  * SIP now generates security events using the Security Events Framework for REGISTER and INVITE.
2108
2109 Queue changes
2110 -------------
2111  * Added general option negative_penalty_invalid default off. when set
2112    members are seen as invalid/logged out when there penalty is negative.
2113    for realtime members when set remove from queue will set penalty to -1.
2114  * Added queue option autopausedelay when autopause is enabled it will be
2115    delayed for this number of seconds since last successful call if there
2116    was no prior call the agent will be autopaused immediately.
2117  * Added member option ignorebusy this when set and ringinuse is not
2118    will allow per member control of multiple calls as ringinuse does for
2119    the Queue.
2120
2121 Applications
2122 ------------
2123  * Added 'v' option to MeetMe to play voicemail greetings when a user joins/leaves
2124    a MeetMe conference
2125  * Added 'k' option to MeetMe to automatically kill the conference when there's only
2126    one participant left (much like a normal call bridge)
2127  * Added extra argument to Originate to set timeout.
2128
2129 Asterisk Database
2130 -----------------
2131  * The internal Asterisk database has been switched from Berkeley DB 1.86 to
2132    SQLite 3. An existing Berkeley astdb file can be converted with the astdb2sqlite3
2133    utility in the UTILS section of menuselect. If an existing astdb is found and no
2134    astdb.sqlite3 exists, astdb2sqlite3 will be compiled automatically. Asterisk will
2135    convert an existing astdb to the SQLite3 version automatically at runtime.
2136
2137 Asterisk Modules
2138 ----------------
2139  * Modules marked as deprecated are no longer marked as building by default. Enabling
2140    these modules is still available via menuselect.
2141
2142 IAX2 Changes
2143 ------------
2144  * authdebug is now disabled by default. To enable this functionaility again
2145    set authdebug = yes in iax.conf.
2146
2147 RTP Changes
2148 -----------
2149  * The rtp.conf setting "strictrtp" is now enabled by default. In previous
2150    releases it was disabled.
2151
2152 PBX Core
2153 --------
2154  * The PBX core previously made a call with a non-existing extension test for
2155    extension s@default and jump there if the extension existed.
2156    This was a bad default behaviour and violated the principle of least surprise.
2157    It has therefore been changed in this release. It may affect some
2158    applications and configurations that rely on this behaviour. Most channel
2159    drivers have avoided this for many releases by testing whether the extension
2160    called exists before starting the PBX and generating a local error.
2161    This behaviour still exists and works as before.
2162
2163    Extension "s" is used when no extension is given in a channel driver,
2164    like immediate answer in DAHDI or calling to a domain with no user part
2165    in a SIP uri.
2166
2167 ------------------------------------------------------------------------------
2168 --- Functionality changes from Asterisk 1.6.2 to Asterisk 1.8 ----------------
2169 ------------------------------------------------------------------------------
2170
2171 SIP Changes
2172 -----------
2173  * Due to potential username discovery vulnerabilities, the 'nat' setting in sip.conf
2174    now defaults to force_rport. It is very important that phones requiring nat=no be
2175    specifically set as such instead of relying on the default setting. If at all
2176    possible, all devices should have nat settings configured in the general section as
2177    opposed to configuring nat per-device.
2178  * Added preferred_codec_only option in sip.conf. This feature limits the joint
2179    codecs sent in response to an INVITE to the single most preferred codec.
2180  * Added SIP_CODEC_OUTBOUND dialplan variable which can be used to set the codec
2181    to be used for the outgoing call. It must be one of the codecs configured
2182    for the device.
2183  * Added tlsprivatekey option to sip.conf.  This allows a separate .pem file
2184    to be used for holding a private key.  If tlsprivatekey is not specified,
2185    tlscertfile is searched for both public and private key.
2186  * Added tlsclientmethod option to sip.conf.  This allows the protocol for
2187    outbound client connections to be specified.
2188  * The sendrpid parameter has been expanded to include the options
2189    'rpid' and 'pai'. Setting sendrpid to 'rpid' will cause Remote-Party-ID
2190    header to be sent (equivalent to setting sendrpid=yes) and setting
2191    sendrpid to 'pai' will cause P-Asserted-Identity header to be sent.
2192  * The 'ignoresdpversion' behavior has been made automatic when the SDP received
2193    is in response to a T.38 re-INVITE that Asterisk initiated. In this situation,
2194    since the call will fail if Asterisk does not process the incoming SDP, Asterisk
2195    will accept the SDP even if the SDP version number is not properly incremented,
2196    but will generate a warning in the log indicating that the SIP peer that sent
2197    the SDP should have the 'ignoresdpversion' option set.
2198  * The 'nat' option has now been been changed to have yes, no, force_rport, and
2199    comedia as valid values. Setting it to yes forces RFC 3581 behavior and enables
2200    symmetric RTP support. Setting it to no only enables RFC 3581 behavior if the
2201    remote side requests it and disables symmetric RTP support. Setting it to
2202    force_rport forces RFC 3581 behavior and disables symmetric RTP support.
2203    Setting it to comedia enables RFC 3581 behavior if the remote side requests it
2204    and enables symmetric RTP support.
2205  * Slave SIP channels now set HASH(SIP_CAUSE,<slave-channel-name>) on each
2206    response.  This permits the master channel to know how each channel dialled
2207    in a multi-channel setup resolved in an individual way. This carries a
2208    performance penalty and can be disabled in sip.conf using the
2209    'storesipcause' option.
2210  * Added 'externtcpport' and 'externtlsport' options to allow custom port
2211    configuration for the externip and externhost options when tcp or tls is used.
2212  * Added support for message body (stored in content variable) to SIP NOTIFY message
2213    accessible via AMI and CLI.
2214  * Added 'media_address' configuration option which can be used to explicitly specify
2215    the IP address to use in the SDP for media (audio, video, and text) streams.
2216  * Added 'unsolicited_mailbox' configuration option which specifies the virtual mailbox
2217    that the new/old count should be stored on if an unsolicited MWI NOTIFY message is
2218    received.
2219  * Added 'use_q850_reason' configuration option for generating and parsing
2220    if available  Reason: Q.850;cause=<cause code> header. It is implemented
2221    in some gateways for better passing PRI/SS7 cause codes via SIP.
2222  * When dialing SIP peers, a new component may be added to the end of the dialstring
2223    to indicate that a specific remote IP address or host should be used when dialing
2224    the particular peer. The dialstring format is SIP/peer/exten/host_or_IP.
2225  * SRTP SDES support for encrypting calls to/from Asterisk over SIP. The
2226    ability to selectively force bridged channels to also be encrypted is also
2227    implemented. Branching in the dialplan can be done based on whether or not
2228    a channel has secure media and/or signaling.
2229  * Added directmediapermit/directmediadeny to limit which peers can send direct media
2230    to each other
2231  * Added the 'snom_aoc_enabled' option to turn on support for sending Advice of
2232    Charge messages to snom phones.
2233  * Added support for G.719 media streams.
2234  * Added support for 16khz signed linear media streams.
2235  * SIP is now able to bind to and communicate with IPv6 addresses. In addition,
2236    RTP has been outfitted with the same abilities.
2237  * Added support for setting the Max-Forwards: header in SIP requests. Setting is
2238    available in device configurations as well as in the dial plan.
2239  * Addition of the 'subscribe_network_change' option for turning on and off
2240    res_stun_monitor module support in chan_sip.
2241  * Addition of the 'auth_options_requests' option for turning on and off
2242    authentication for OPTIONS requests in chan_sip.
2243
2244 Configuration files
2245 -------------------
2246  * Add #tryinclude statement for config files.  This provides the same
2247    functionality as the #include statement however an asterisk module will
2248    still load if the filename does not exist.  Using the #include statement
2249    Asterisk will not allow the module to load.
2250
2251 IAX2 Changes
2252 -----------
2253  * Added rtsavesysname option into iax.conf to allow the systname to be saved
2254    on realtime updates.
2255  * Added the ability for chan_iax2 to inform the dialplan whether or not
2256    encryption is being used. This interoperates with the SIP SRTP implementation
2257    so that a secure SIP call can be bridged to a secure IAX call when the
2258    dialplan requires bridged channels to be "secure".
2259  * Addition of the 'subscribe_network_change' option for turning on and off
2260    res_stun_monitor module support in chan_iax.
2261
2262
2263 MGCP Changes
2264 ------------
2265  * Added ability to preset channel variables on indicated lines with the setvar
2266    configuration option.  Also, clearvars=all resets the list of variables back
2267    to none.
2268  * PacketCable NCS 1.0 support has been added for Docsis/Eurodocsis Networks.
2269    See configs/res_pktccops.conf for more information.
2270
2271 XMPP Google Talk/Jingle changes
2272 -------------------------------
2273   * Added the externip option to gtalk.conf.
2274   * Added the stunaddr option to gtalk.conf which allows for the automatic
2275     retrieval of the external ip from a stun server.
2276
2277 Applications
2278 ------------
2279  * Added 'p' option to PickupChan() to allow for picking up channel by the first
2280    match to a partial channel name.
2281  * Added .m3u support for Mp3Player application.
2282  * Added progress option to the app_dial D() option.  When progress DTMF is
2283    present, those values are sent immediately upon receiving a PROGRESS message
2284    regardless if the call has been answered or not.
2285  * Added functionality to the app_dial F() option to continue with execution
2286    at the current location when no parameters are provided.
2287  * Added the 'a' option to app_dial to answer the calling channel before any
2288    announcements or macros are executed.
2289  * Modified app_dial to set answertime when the called channel answers even if
2290    the called channel hangs up during playback of an announcement.
2291  * Modified app_dial 'r' option to support an additional parameter to play an
2292    indication tone from indications.conf
2293  * Added c() option to app_chanspy. This option allows custom DTMF to be set
2294    to cycle through the next available channel.  By default this is still '*'.
2295  * Added x() option to app_chanspy.  This option allows DTMF to be set to
2296    exit the application.
2297  * The Voicemail application has been improved to automatically ignore messages
2298    that only contain silence.
2299  * If you set maxmsg to 0 in voicemail.conf, Voicemail will consider the
2300    associated mailbox(es) to be greetings-only.
2301  * The ChanSpy application now has the 'S' option, which makes the application
2302    automatically exit once it hits a point where no more channels are available
2303    to spy on.
2304  * The ChanSpy application also now has the 'E' option, which spies on a single
2305    channel and exits when that channel hangs up.
2306  * The MeetMe application now turns on the DENOISE() function by default, for
2307    each participant.  In our tests, this has significantly decreased background
2308    noise (especially noisy data centers).
2309  * Voicemail now permits storage of secrets in a separate file, located in the
2310    spool directory of each individual user.  The control for this is located in
2311    the "passwordlocation" option in voicemail.conf.  Please see the sample
2312    configuration for more information.
2313  * The ChanIsAvail application now exposes the returned cause code using a separate
2314    variable, AVAILCAUSECODE, instead of overwriting the device state in AVAILSTATUS.
2315  * Added 'd' option to app_followme.  This option disables the "Please hold"
2316    announcement.
2317  * Added 'y' option to app_record. This option enables a mode where any DTMF digit
2318    received will terminate recording.
2319  * Voicemail now supports per mailbox settings for folders when using IMAP storage.
2320    Previously the folder could only be set per context, but has now been extended
2321    using the imapfolder option.
2322  * Voicemail now supports per mailbox settings for nextaftercmd and minsecs.
2323  * Voicemail now allows the pager date format to be specified separately from the
2324    email date format.
2325  * New applications JabberJoin, JabberLeave, and JabberSendGroup have been added
2326    to allow joining, leaving, and sending text to group chats.
2327  * MeetMe has a new option 'G' to play an announcement before joining a conference.
2328  * Page has a new option 'A(x)' which will playback an announcement simultaneously
2329    to all paged phones (and optionally excluding the caller's one using the new
2330    option 'n') before the call is bridged.
2331  * The 'f' option to Dial has been augmented to take an optional argument. If no
2332    argument is provided, the 'f' option works as it always has. If an argument is
2333    provided, then the connected party information of all outgoing channels created
2334    during the Dial will be set to the argument passed to the 'f' option.
2335  * Dial now inherits the GOSUB_RETVAL from the peer, when the U() option runs a
2336    Gosub on the peer.
2337  * The OSP lookup application adds in/outbound network ID, optional security,
2338    number portability, QoS reporting, destination IP port, custom info and service
2339    type features.
2340  * Added new application VMSayName that will play the recorded name of the voicemail
2341    user if it exists, otherwise will play the mailbox number.
2342  * Added custom device states to ConfBridge bridges.  Use 'confbridge:<name>' to
2343    retrieve state for a particular bridge, where <name> is the conference name
2344  * app_directory now allows exiting at any time using the operator or pound key.
2345  * Voicemail now supports setting a locale per-mailbox.
2346  * Two new applications are provided for declining counting phrases in multiple
2347    languages.  See the application notes for SayCountedNoun and SayCountedAdj for
2348    more information.
2349  * Voicemail now runs the externnotify script when pollmailboxes is activated and
2350    notices a change.
2351  * Voicemail now includes rdnis within msgXXXX.txt file.
2352  * ExternalIVR now supports IPv6 addresses.
2353  * Added 'D' command to ExternalIVR. Details are available on the Asterisk wiki
2354    at https://wiki.asterisk.org/wiki/x/oQBB
2355  * ParkedCall and Park can now specify the parking lot to use.
2356
2357 Dialplan Functions
2358 ------------------
2359  * SRVQUERY and SRVRESULT functions added. This can be used to query and iterate
2360    over SRV records associated with a specific service. From the CLI, type
2361    'core show function SRVQUERY' and 'core show function SRVRESULT' for more
2362    details on how these may be used.
2363  * PITCH_SHIFT dialplan function added. This function can be used to modify the
2364    pitch of a channel's tx and rx audio streams.
2365  * Added new dialplan functions CONNECTEDLINE and REDIRECTING which permits
2366    setting various connected line and redirecting party information.
2367  * CALLERID and CONNECTEDLINE dialplan functions have been extended to
2368    support ISDN subaddressing.
2369  * The CHANNEL() function now supports the "name" and "checkhangup" options.
2370  * For DAHDI channels, the CHANNEL() dialplan function now allows
2371    the dialplan to request changes in the configuration of the active
2372    echo canceller on the channel (if any), for the current call only.
2373    The syntax is:
2374
2375    exten => s,n,Set(CHANNEL(echocan_mode)=off)
2376
2377    The possible values are:
2378
2379      on - normal mode (the echo canceller is actually reinitialized)
2380      off - disabled
2381      fax - FAX/data mode (NLP disabled if possible, otherwise completely
2382            disabled)
2383      voice - voice mode (returns from FAX mode, reverting the changes that
2384              were made when FAX mode was requested)
2385  * Added new dialplan function MASTER_CHANNEL(), which permits retrieving
2386    and setting variables on the channel which created the current channel.
2387    Administrators should take care to avoid naming conflicts, when multiple
2388    channels are dialled at once, especially when used with the Local channel
2389    construct (which all could set variables on the master channel).  Usage
2390    of the HASH() dialplan function, with the key set to the name of the slave
2391    channel, is one approach that will avoid conflicts.
2392  * Added new dialplan function MUTEAUDIO() for muting inbound and/or outbound
2393    audio in a channel.
2394  * func_odbc now allows multiple row results to be retrieved without using
2395    mode=multirow.  If rowlimit is set, then additional rows may be retrieved
2396    from the same query by using the name of the function which retrieved the
2397    first row as an argument to ODBC_FETCH().
2398  * Added JABBER_RECEIVE, which permits receiving XMPP messages from the
2399    dialplan. This function returns the content of the received message.
2400  * Added REPLACE, which searches a given variable name for a set of characters,
2401    then either replaces them with a single character or deletes them.
2402  * Added PASSTHRU, which literally passes the same argument back as its return
2403    value.  The intent is to be able to use a literal string argument to
2404    functions that currently require a variable name as an argument.
2405  * HASH-associated variables now can be inherited across channel creation, by
2406    prefixing the name of the hash at assignment with the appropriate number of
2407    underscores, just like variables.
2408  * GROUP_MATCH_COUNT has been improved to allow regex matching on category
2409  * CHANNEL(secure_bridge_signaling) and CHANNEL(secure_bridge_media) to set/get
2410    whether or not channels that are bridged to the current channel will be
2411    required to have secure signaling and/or media.
2412  * CHANNEL(secure_signaling) and CHANNEL(secure_media) to get whether or not
2413    the current channel has secure signaling and/or media.
2414  * For DAHDI/ISDN channels, the CHANNEL() dialplan function now supports the
2415    "no_media_path" option.
2416    Returns "0" if there is a B channel associated with the call.
2417    Returns "1" if no B channel is associated with the call.  The call is either
2418    on hold or is a call waiting call.
2419  * Added option to dialplan function CDR(), the 'f' option
2420    allows for high resolution times for billsec and duration fields.
2421  * FILE() now supports line-mode and writing.
2422  * Added FIELDNUM(), which returns the 1-based offset of a field in a list.
2423  * FRAME_TRACE(), for tracking internal ast_frames on a channel.
2424
2425 Dialplan Variables
2426 ------------------
2427  * Added DYNAMIC_FEATURENAME which holds the last triggered dynamic feature.
2428  * Added DYNAMIC_PEERNAME which holds the unique channel name on the other side
2429    and is set when a dynamic feature is triggered.
2430  * Added PARKINGLOT which can be used with parkeddynamic feature.conf option
2431    to dynamically create a new parking lot matching the value this varible is
2432    set to.
2433  * Added PARKINGDYNAMIC which represents the template parkinglot defined in
2434    features.conf that should be the base for dynamic parkinglots.
2435  * Added PARKINGDYNCONTEXT which tells what context a newly created dynamic
2436    parkinglot should have.
2437  * Added PARKINGDYNEXTEN which tells what parking exten a newly created dynamic
2438    parkinglot should have.
2439  * Added PARKINGDYNPOS which holds what parking positions a dynamic parkinglot
2440    should have.
2441
2442 Queue changes
2443 -------------
2444  * Added "ready" option to QUEUE_MEMBER counting to count free agents whose wrap-up
2445    timeout has expired.
2446  * Added 'R' option to app_queue.  This option stops moh and indicates ringing
2447    to the caller when an Agent's phone is ringing.  This can be used to indicate
2448    to the caller that their call is about to be picked up, which is nice when
2449    one has been on hold for an extened period of time.
2450  * A new config option, penaltymemberslimit, has been added to queues.conf.
2451    When set this option will disregard penalty settings when a queue has too
2452    few members.
2453  * A new option, 'I' has been added to both app_queue and app_dial.
2454    By setting this option, Asterisk will not update the caller with
2455    connected line changes or redirecting party changes when they occur.
2456  * A 'relative-periodic-announce' option has been added to queues.conf.  When
2457    enabled, this option will cause periodic announce times to be calculated
2458    from the end of announcements rather than from the beginning.
2459  * The autopause option in queues.conf can be passed a new value, "all." The
2460    result is that if a member becomes auto-paused, he will be paused in all
2461    queues for which he is a member, not just the queue that failed to reach
2462    the member.
2463  * Added dialplan function QUEUE_EXISTS to check if a queue exists
2464  * The queue logger now allows events to optionally propagate to a file,
2465    even when realtime logging is turned on.  Additionally, realtime logging
2466    supports sending the event arguments to 5 individual fields, although it
2467    will fallback to the previous data definition, if the new table layout is
2468    not found.
2469
2470 mISDN channel driver (chan_misdn) changes
2471 ----------------------------------------
2472  * Added display_connected parameter to misdn.conf to put a display string
2473    in the CONNECT message containing the connected name and/or number if
2474    the presentation setting permits it.
2475  * Added display_setup parameter to misdn.conf to put a display string
2476    in the SETUP message containing the caller name and/or number if the
2477    presentation setting permits it.
2478  * Made misdn.conf parameters localdialplan and cpndialplan take a -1 to
2479    indicate the dialplan settings are to be obtained from the asterisk
2480    channel.
2481  * Made misdn.conf parameter callerid accept the "name" <number> format
2482    used by the rest of the system.
2483  * Made use the nationalprefix and internationalprefix misdn.conf
2484    parameters to prefix any received number from the ISDN link if that
2485    number has the corresponding Type-Of-Number.  NOTE:  This includes
2486    comparing the incoming call's dialed number against the MSN list.
2487  * Added the following new parameters: unknownprefix, netspecificprefix,
2488    subscriberprefix, and abbreviatedprefix in misdn.conf to prefix any
2489    received number from the ISDN link if that number has the corresponding
2490    Type-Of-Number.
2491  * Added new dialplan application misdn_command which permits controlling
2492    the CCBS/CCNR functionality.
2493  * Added new dialplan function mISDN_CC which permits retrieval of various
2494    values from an active call completion record.
2495  * For PTP, you should manually send the COLR of the redirected-to party
2496    for an incomming redirected call if the incoming call could experience
2497    further redirects.  Just set the REDIRECTING(to-num,i) = ${EXTEN} and
2498    set the REDIRECTING(to-pres) to the COLR.  A call has been redirected
2499    if the REDIRECTING(from-num) is not empty.
2500  * For outgoing PTP redirected calls, you now need to use the inhibit(i)
2501    option on all of the REDIRECTING statements before dialing the
2502    redirected-to party.  You still have to set the REDIRECTING(to-xxx,i)
2503    and the REDIRECTING(from-xxx,i) values.  The PTP call will update the
2504    redirecting-to presentation (COLR) when it becomes available.
2505  * Added outgoing_colp parameter to misdn.conf to filter outgoing COLP
2506    information.
2507
2508 thirdparty mISDN enhancements
2509 -----------------------------
2510 mISDN has been modified by Digium, Inc. to greatly expand facility message
2511 support to allow:
2512   * Enhanced COLP support for call diversion and transfer.
2513   * CCBS/CCNR support.
2514
2515 The latest modified mISDN v1.1.x based version is available at:
2516 http://svn.digium.com/svn/thirdparty/mISDN/trunk
2517 http://svn.digium.com/svn/thirdparty/mISDNuser/trunk
2518
2519 Tagged versions of the modified mISDN code are available under:
2520 http://svn.digium.com/svn/thirdparty/mISDN/tags
2521 http://svn.digium.com/svn/thirdparty/mISDNuser/tags
2522
2523 libpri channel driver (chan_dahdi) DAHDI changes
2524 -------------------------------------------
2525  * The channel variable PRIREDIRECTREASON is now just a status variable
2526    and it is also deprecated.  Use the REDIRECTING(reason) dialplan function
2527    to read and alter the reason.
2528  * For Q.SIG and ETSI PRI/BRI-PTP, you should manually send the COLR of the
2529    redirected-to party for an incomming redirected call if the incoming call
2530    could experience further redirects.  Just set the
2531    REDIRECTING(to-num,i) = CALLERID(dnid) and set the REDIRECTING(to-pres)
2532    to the COLR.  A call has been redirected if the REDIRECTING(count) is not
2533    zero.
2534  * For outgoing Q.SIG and ETSI PRI/BRI-PTP redirected calls, you need to
2535    use the inhibit(i) option on all of the REDIRECTING statements before
2536    dialing the redirected-to party.  You still have to set the
2537    REDIRECTING(to-xxx,i) and the REDIRECTING(from-xxx,i) values.  The call
2538    will update the redirecting-to presentation (COLR) when it becomes available.
2539  * Added the ability to ignore calls that are not in a Multiple Subscriber
2540    Number (MSN) list for PTMP CPE interfaces.
2541  * Added dynamic range compression support for dahdi channels.  It is
2542    configured via the rxdrc and txdrc parameters in chan_dahdi.conf.
2543  * Added support for ISDN calling and called subaddress with partial support
2544    for connected line subaddress.
2545  * Added support for BRI PTMP NT mode. (Requires latest LibPRI.)
2546  * Added handling of received HOLD/RETRIEVE messages and the optional ability
2547    to transfer a held call on disconnect similar to an analog phone.
2548  * Added CallRerouting/CallDeflection support for Q.SIG, ETSI PTP, ETSI PTMP.
2549    Will reroute/deflect an outgoing call when receive the message.
2550    Can use the DAHDISendCallreroutingFacility to send the message for the
2551    supported switches.
2552  * Added standard location to add options to chan_dahdi dialing:
2553    Dial(DAHDI/g1[/extension[/options]])
2554    Current options:
2555    K(<keypad_digits>)
2556    R Reverse charging indication
2557  * Added Reverse Charging Indication (Collect calls) send/receive option.
2558    Send reverse charging in SETUP message with the chan_dahdi R dialing option.
2559    Dial(DAHDI/g1/extension/R)
2560    Access received reverse charge in SETUP message by: ${CHANNEL(reversecharge)}
2561    (requires latest LibPRI)
2562  * Added ability to send/receive keypad digits in the SETUP message.
2563    Send keypad digits in SETUP message with the chan_dahdi K(<keypad_digits>)
2564    dialing option.  Dial(DAHDI/g1/[extension]/K(<keypad_digits>))
2565    Access any received keypad digits in SETUP message by: ${CHANNEL(keypad_digits)}
2566    (requires latest LibPRI)
2567  * Added ability to send and receive ETSI Explicit Call Transfer (ECT) messages
2568    to eliminate tromboned calls.  A tromboned call goes out an interface and comes
2569    back into the same interface.  Tromboned calls happen because of call routing,
2570    call deflection, call forwarding, and call transfer.
2571  * Added the ability to send and receive ETSI Advice-Of-Charge messages.
2572  * Added the ability to support call waiting calls.  (The SETUP has no B channel
2573    assigned.)
2574  * Added Malicious Call ID (MCID) event to the AMI call event class.
2575  * Added Message Waiting Indication (MWI) support for ISDN PTMP endpoints (phones).
2576
2577 Asterisk Manager Interface
2578 --------------------------
2579  * The Hangup action now accepts a Cause header which may be used to
2580    set the channel's hangup cause.
2581  * sslprivatekey option added to manager.conf and http.conf.  Adds the ability
2582    to specify a separate .pem file to hold a private key.  By default sslcert
2583    is used to hold both the public and private key.
2584  * Options in manager.conf and http.conf with the 'ssl' prefix have been replaced
2585    for options containing the 'tls' prefix.  For example, 'sslenable' is now
2586    'tlsenable'.  This has been done in effort to keep ssl and tls options consistent
2587    across all .conf files. All affected sample.conf files have been modified to
2588    reflect this change.  Previous options such as 'sslenable' still work,
2589    but options with the 'tls' prefix are preferred.
2590  * Added a MuteAudio AMI action for muting inbound and/or outbound audio
2591    in a channel. (res_mutestream.so)
2592  * The configuration file manager.conf now supports a channelvars option, which
2593    specifies a list of channel variables to include in each channel-oriented
2594    event.
2595  * The redirect command now has new parameters ExtraContext, ExtraExtension,
2596    and ExtraPriority to allow redirecting the second channel to a different
2597    location than the first.
2598  * Added new event "JabberStatus" in the Jabber module to monitor buddies
2599    status.
2600  * Added a "MixMonitorMute" AMI action for muting inbound and/or outbound audio
2601    in a MixMonitor recording.
2602  * The 'iax2 show peers' output is now similar to the expected output of
2603    'sip show peers'.
2604  * Added Advice-Of-Charge events (AOC-S, AOC-D, and AOC-E) in the new
2605    aoc event class.
2606  * Added Advice-Of-Charge manager action, AOCMessage, for generating AOC-D and
2607    AOC-E messages on a channel.
2608  * A DBGetComplete event now follows a DBGetResponse, to make the DBGet action
2609    conform more closely to similar events.
2610  * Added a new eventfilter option per user to allow whitelisting and blacklisting
2611    of events.
2612  * Added optional parkinglot variable for park command.
2613  * Added ConnectedLineNum and ConnectedLineName headers to AMI events/responses
2614    if CallerIDNum and CallerIDName headers are also present.
2615
2616 Channel Event Logging
2617 ---------------------
2618  * A new interface, CEL, is introduced here. CEL logs single events, much like
2619    the AMI, but it differs from the AMI in that it logs to db backends much
2620    like CDR does; is based on the event subsystem introduced by Russell, and
2621    can share in all its benefits; allows multiple backends to operate like CDR;
2622    is specialized to event data that would be of concern to billing sytems,
2623    like CDR. Backends for logging and accounting calls have been produced,
2624    but a new CDR backend is still in development.
2625
2626 CDR
2627 ---
2628  * 'linkedid' and 'peeraccount' are new CDR fields available to CDR aficionados.
2629    linkedid is based on uniqueID, but spreads to other channels as transfers, dials,
2630    etc are performed. Thus the pieces of CDR can be grouped into multilegged sets.
2631  * Multiple files and formats can now be specified in cdr_custom.conf.
2632  * cdr_syslog has been added which allows CDRs to be written directly to syslog.
2633    See configs/cdr_syslog.conf.sample for more information.
2634  * A 'sequence' field has been added to CDRs which can be combined with
2635    linkedid or uniqueid to uniquely identify a CDR.
2636  * Handling of billsec and duration field has changed. If your table definition
2637    specifies those fields as float,double or similar they will now be logged with
2638    microsecond accuracy instead of a whole integer.
2639
2640 Calendaring for Asterisk
2641 ------------------------
2642  * A new set of modules were added supporing calendar integration with Asterisk.
2643    Dialplan functions for reading from and writing to calendars are included,
2644    as well as the ability to execute dialplan logic upon calendar event notifications.
2645    iCalendar, CalDAV, and Exchange Server calendars (via res_calendar_exchange for
2646    Exchange Server 2003 with no write or attendee support, and res_calendar_ews for
2647    Exchange Server 2007+ with full write and attendee support) are supported (Exchange
2648    2003 support does not support forms-based authentication).
2649
2650 Call Completion Supplementary Services for Asterisk
2651 ---------------------------------------------------
2652  * Call completion support has been added for SIP, DAHDI/ISDN, and DAHDI/analog.
2653    DAHDI/ISDN supports call completion for the following switch types:
2654    EuroIsdn(ETSI) for PTP and PTMP modes, and Qsig.
2655    See https://wiki.asterisk.org/wiki/x/2ABQ for details.
2656
2657 Multicast RTP Support
2658 ---------------------
2659  * A new RTP engine and channel driver have been added which supports Multicast RTP.
2660    The channel driver can be used with the Page application to perform multicast RTP
2661    paging. The dial string format is: MulticastRTP/<type>/<destination>/<control address>
2662    Type can be either basic or linksys.
2663    Destination is the IP address and port for the RTP packets.
2664    Control address is specific to the linksys type and is used for sending the control
2665    packets unique to them.
2666
2667 Security Events Framework
2668 -------------------------
2669  * Asterisk has a new C API for reporting security events.  The module res_security_log
2670    sends these events to the "security" logger level.  Currently, AMI is the only
2671    Asterisk component that reports security events.  However, SIP support will be
2672    coming soon.  For more information on the security events framework, see the
2673    "Asterisk Security Framework" section of the Asterisk wiki at
2674    https://wiki.asterisk.org/wiki/x/wgBQ
2675  * SIP support was added in Asterisk 10
2676  * This API now supports IPv6 addresses
2677
2678 Fax
2679 ---
2680  * A technology independent fax frontend (res_fax) has been added to Asterisk.
2681  * A spandsp based fax backend (res_fax_spandsp) has been added.
2682  * The app_fax module has been deprecated in favor of the res_fax module and
2683    the new res_fax_spandsp backend.
2684  * The SendFAX and ReceiveFAX applications now send their log messages to a
2685    'fax' logger level, instead of to the generic logger levels. To see these
2686    messages, the system's logger.conf file will need to direct the 'fax' logger
2687    level to one or more destinations; the logger.conf.sample file includes an
2688    example of how to do this. Note that if the 'fax' logger level is *not*
2689    directed to at least one destination, log messages generated by these
2690    applications will be lost, and that if the 'fax' logger level is directed to
2691    the console, the 'core set verbose' and 'core set debug' CLI commands will
2692    have no effect on whether the messages appear on the console or not.
2693
2694 Miscellaneous
2695 -------------
2696  * The transmit_silence_during_record option in asterisk.conf.sample has been removed.
2697    Now, in order to enable transmitting silence during record the transmit_silence
2698    option should be used.  transmit_silence_during_record remains a valid option, but
2699    defaults to the behavior of the transmit_silence option.
2700  * Addition of the Unit Test Framework API for managing registration and execution
2701    of unit tests with the purpose of verifying the operation of C functions.
2702  * SendText is now implemented in chan_gtalk and chan_jingle. It will simply send
2703    XMPP text messages to the remote JID.
2704  * Modules.conf has a new option - "require" - that marks a module as critical for
2705    the execution of Asterisk.
2706    If one of the required modules fail to load, Asterisk will exit with a return
2707    code set to 2.
2708  * An 'X' option has been added to the asterisk application which enables #exec support.
2709    This allows #exec to be used in asterisk.conf.
2710  * jabber.conf supports a new option auth_policy that toggles auto user registration.
2711  * A new lockconfdir option has been added to asterisk.conf to protect the
2712    configuration directory (/etc/asterisk by default) during reloads.
2713  * The parkeddynamic option has been added to features.conf to enable the creation
2714    of dynamic parkinglots.
2715  * chan_dahdi now supports reporting alarms over AMI either by channel or span via
2716    the reportalarms config option.
2717  * chan_dahdi supports dialing configuring and dialing by device file name.
2718    DAHDI/span-name!local!1 will use /dev/dahdi/span-name/local/1 . Likewise
2719    it may appear in chan_dahdi.conf as 'channel => span-name!local!1'.
2720  * A new options for chan_dahdi.conf: 'ignore_failed_channels'. Boolean.
2721    False by default. If set, chan_dahdi will ignore failed 'channel' entries.
2722    Handy for the above name-based syntax as it does not depend on
2723    initialization order.
2724  * The Realtime dialplan switch now caches entries for 1 second.  This provides a
2725    significant increase in performance (about 3X) for installations using this switchtype.
2726  * Distributed devicestate now supports the use of the XMPP protocol, in addition to
2727    AIS.  For more information, please see the Distributed Device State section of the
2728    Asterisk wiki at https://wiki.asterisk.org/wiki/x/jw4iAQ
2729  * The addition of G.719 pass-through support.
2730  * Added support for 16khz Speex audio.  This can be enabled by using 'allow=speex16'
2731    during device configuration.
2732  * The UNISTIM channel driver (chan_unistim) has been updated to support devices that
2733    have less than 3 lines on the LCD.
2734  * Realtime now supports database failover.  See the sample extconfig.conf for details.
2735  * The addition of improved translation path building for wideband codecs.  Sample
2736    rate changes during translation are now avoided unless absolutely necessary.
2737  * The addition of the res_stun_monitor module for monitoring and reacting to network
2738    changes while behind a NAT.
2739  * DTMF: Normal and Reverse Twist acceptance values can be set in dsp.conf.
2740    DTMF Valid/Invalid number of hits/misses can be set in dsp.conf.
2741    These allow support for any Administration. Default is AT&T values.
2742
2743 CLI Changes
2744 -----------
2745  * The 'core set debug' and 'core set verbose' commands, in previous versions, could
2746    optionally accept a filename, to apply the setting only to the code generated from
2747    that source file when Asterisk was built. However, there are some modules in Asterisk
2748    that are composed of multiple source files, so this did not result in the behavior
2749    that users expected. In this version, 'core set debug' and 'core set verbose'
2750    can optionally accept *module* names instead (with or without the .so extension),
2751    which applies the setting to the entire module specified, regardless of which source
2752    files it was built from.
2753  * New 'manager show settings' command showing the current settings loaded from
2754    manager.conf.
2755  * Added 'all' keyword to the CLI command "channel request hangup" so that you can send
2756    the channel hangup request to all channels.
2757  * Added a "core reload" CLI command that executes a global reload of Asterisk.
2758
2759 ------------------------------------------------------------------------------
2760 --- Functionality changes from Asterisk 1.6.1 to Asterisk 1.6.2  -------------
2761 ------------------------------------------------------------------------------
2762
2763 SIP Changes
2764 -----------
2765  * Added support for SUBSCRIBE/NOTIFY with dialog-info based call pickups.
2766    Snom phones use this for call pickup of extensions that the phone is
2767    subscribed to.
2768  * Added support for setting the domain in the URI for caller of an
2769    outbound call by using the SIPFROMDOMAIN channel variable.
2770  * Added a new configuration option "remotesecret" for authentication to
2771    remote services. For backwards compatibility, "secret" still has the
2772    same function as before, but now you can configure both a remote secret and a
2773    local secret for mutual authentication.
2774  * If the channel variable  ATTENDED_TRANSFER_COMPLETE_SOUND is set,
2775    the sound will be played to the target of an attended transfer
2776  * Added two new configuration options, "qualifygap" and "qualifypeers", which allow
2777    finer control over how many peers Asterisk will qualify and the gap between them
2778    when all peers need to be qualified at the same time.
2779  * Added a new 'ignoresdpversion' option to sip.conf.  When this is enabled
2780    (either globally or for a specific peer), chan_sip will treat any SDP data
2781    it receives as new data and update the media stream accordingly.  By
2782    default, Asterisk will only modify the media stream if the SDP session
2783    version received is different from the current SDP session version.  This
2784    option is required to interoperate with devices that have non-standard SDP
2785    session version implementations (observed with Microsoft OCS).  This option
2786    is disabled by default.
2787  * The parsing of register => lines in sip.conf has been modified to allow a port
2788    to be present in the "user" portion. Please see the sip.conf.sample file for more
2789    information
2790  * Added support for subscribing to MWI on a remote server and making the status available
2791    as a mailbox. Please see the sip.conf.sample file for more information.
2792  * Added a function to remove SIP headers added in the dialplan before the
2793    first INVITE is generated - SIPRemoveHeader()
2794  * Channel variables set with setvar= in a device configuration is now
2795    set both for inbound and outbound calls.
2796  * Added support for ITU G.722.1 and G.722.1C (Siren7 and Siren14) media streams.
2797
2798 IAX2 changes
2799 ------------
2800   * Added immediate option to iax.conf
2801   * Added forceencryption option to iax.conf
2802   * Added Encryption and Trunk status to manager command "iaxpeers"
2803
2804 Skinny Changes
2805 --------------
2806  * The configuration file now holds separate sections for devices and lines.
2807    Please have a look at configs/skinny.conf.sample and change your skinny.conf
2808    accordingly.
2809
2810 DAHDI Changes
2811 -------------
2812  * chan_dahdi now supports MFC/R2 signaling when Asterisk is compiled with
2813    support for LibOpenR2.  http://www.libopenr2.org/
2814  * The UK option waitfordialtone has been added for use with BT analog
2815    lines.
2816  * Added a 'faxbuffers' configuration option to chan_dahdi.conf.  This option
2817    is used in conjunction with the 'faxdetect' configuration option.  When
2818    'faxbuffers' is used and fax tones are detected, the channel will dynamically
2819    switch to the configured faxbuffers policy.  For example, to use 6 buffers
2820    and a 'full' buffer policy for a fax transmission, add:
2821      faxbuffers=>6,full
2822    The faxbuffers configuration will be in affect until the call is torn down.
2823  * Added service message support for 4ESS/5ESS switches.
2824
2825 Dialplan Functions
2826 ------------------
2827  * For DAHDI channels, the CHANNEL() dialplan function now
2828    supports changing the channel's buffer policy (for the current
2829    call only), using this syntax:
2830
2831    exten => s,n,Set(CHANNEL(buffers)=6,full)
2832
2833    This would change the channel to the 'full' buffer policy and
2834    6 (six) buffers. Possible options for this setting are the same
2835    as those in chan_dahdi.conf.
2836  * Added a new dialplan function, CURLOPT, which permits setting various
2837    options that may be useful with the CURL dialplan function, such as
2838    cookies, proxies, connection timeouts, passwords, etc.
2839  * Permit the syntax and synopsis fields of the corresponding dialplan
2840    functions to be individually set from func_odbc.conf.
2841  * Added debugging CLI functions to func_odbc, 'odbc read' and 'odbc write'.
2842  * func_odbc now may specify an insert query to execute, when the write query
2843    affects 0 rows (usually indicating that no such row exists).
2844  * Added a new dialplan function, LISTFILTER, which permits removing elements
2845    from a set list, by name.  Uses the same general syntax as the existing CUT
2846    and FIELDQTY dialplan functions, which also manage lists.
2847  * Added REALTIME_FIELD and REALTIME_HASH, which should aid users in better
2848    obtaining realtime data from the dialplan.
2849  * Added LOCAL_PEEK, which allows access to variables in any stack frame within
2850    a subroutine when using the GoSub() and Return() applications.
2851  * Added AUDIOHOOK_INHERIT. For information on its use, please see the output
2852    of "core show function AUDIOHOOK_INHERIT" from the CLI
2853  * Added AES_ENCRYPT. For information on its use, please see the output
2854    of "core show function AES_ENCRYPT" from the CLI
2855  * Added AES_DECRYPT. For information on its use, please see the output
2856    of "core show function AES_DECRYPT" from the CLI
2857  * func_odbc now supports database transactions across multiple queries.
2858
2859 Applications
2860 ------------
2861  * Scheduled meetme conferences may now have their end times extended by
2862    using MeetMeAdmin.
2863  * app_authenticate now gives the ability to select a prompt other than
2864    the default.
2865  * app_directory now pays attention to the searchcontexts setting in
2866    voicemail.conf and will look through all contexts, if no context is
2867    specified in the initial argument.
2868  * A new application, Originate, has been introduced, that allows asynchronous
2869    call origination from the dialplan.
2870  * Voicemail now permits setting the emailsubject and emailbody per mailbox,
2871    in addition to the setting in the "general" context.
2872  * Added ConfBridge dialplan application which does conference bridges without
2873    DAHDI. For information on its use, please see the output of
2874    "core show application ConfBridge" from the CLI.
2875
2876 Miscellaneous
2877 -------------
2878  * The Asterisk CLI has a new command, "channel redirect", which is similar in
2879    operation to the AMI Redirect action.
2880  * extensions.conf now allows you to use keyword "same" to define an extension
2881    without actually specifying an extension.  It uses exactly the same pattern
2882    as previously used on the last "exten" line.  For example:
2883      exten => 123,1,NoOp(something)
2884      same  =>     n,SomethingElse()
2885  * musiconhold.conf classes of type 'files' can now use relative directory paths,
2886    which are interpreted as relative to the astvarlibdir setting in asterisk.conf.
2887  * All deprecated CLI commands are removed from the sourcecode. They are now handled
2888    by the new clialiases module. See cli_aliases.conf.sample file.
2889  * Times within timespecs are now accurate down to the minute.  This is a change
2890    from historical Asterisk, which only provided timespecs rounded to the nearest
2891    even (read: evenly divisible by 2) minute mark.
2892  * The realtime switch now supports an option flag, 'p', which disables searches for
2893    pattern matches.
2894  * In addition to a time range and date range, timespecs now accept a 5th optional
2895    argument, timezone.  This allows you to perform time checks on alternate
2896    timezones, especially if those daylight savings time ranges vary from your
2897    machine's native timezone.  See GotoIfTime, ExecIfTime, IFTIME(), and timed
2898    includes.
2899  * The contrib/scripts/ directory now has a script called sip_nat_settings that will
2900    give you the correct output for an asterisk box behind nat. It will give you the
2901    externhost and localnet settings.
2902  * The Asterisk core now supports ITU G.722.1 and G.722.1C media streams, and
2903    can connect calls in passthrough mode, as well as record and play back files.
2904  * Successful and unsuccessful call pickup can now be alerted through sounds, by
2905    using pickupsound and pickupfailsound in features.conf.
2906  * ASTVARRUNDIR is now set to $(localstatedir)/run/asterisk by default.
2907    This means the asterisk pid file will now be in /var/run/asterisk/asterisk.pid on LINUX
2908    instead of the /var/run/asterisk.pid where it used to be. This will make
2909    installs as non-root easier to manage.
2910
2911 CDR
2912 ---
2913
2914 * The cdr.conf file must exist and be correctly programmed in order for CDR records to
2915   be written; they will no longer be explicitly written.
2916
2917 Asterisk Manager Interface
2918 --------------------------
2919  * When using the AMI over HTTP, you can now include a 'SuppressEvents' header (with
2920    a non-empty value) in your request. If you do this, any pending AMI events will
2921    *not* be included in the response to your request as they would normally, but
2922    will be left in the event queue for the next request you make to retrieve. For
2923    some applications, this will allow you to guarantee that you will only see
2924    events in responses to 'WaitEvent' actions, and can better know when to expect them.
2925    To know whether the Asterisk server supports this header or not, your client can
2926    inspect the first response back from the server to see if it includes this header:
2927
2928    Pragma: SuppressEvents
2929
2930    If this is included, the server supports event suppression.
2931
2932  * Added 4 new Actions to list skinny device(s) and line(s)
2933    SKINNYdevices
2934    SKINNYshowdevice
2935    SKINNYlines
2936    SKINNYshowline
2937
2938 LDAP Schema File Additions
2939 --------------------------
2940  * Added AsteriskDialplan, AsteriskAccount and AsteriskMailbox  objectClasses
2941    to allow standalone dialplan, account and mailbox entries (STRUCTURAL)
2942  * Added new Fields:
2943    - AstAccountLanguage, AstAccountTransport, AstAccountPromiscRedir,
2944    - AstAccountAccountCode, AstAccountSetVar, AstAccountAllowOverlap,
2945    - AstAccountVideoSupport, AstAccountIgnoreSDPVersion
2946  * Removed redundant IPaddr (there's already IPAddress)
2947    - Gives more configuration Flags for SIP-Users available (tested)
2948    - Allows to create Asterisk Attributes in defined Asterisk ObjectClasses
2949      without extensibleObject (which really should be the last resort); gives
2950      also additional possibilities for LDAP-filter
2951
2952 ------------------------------------------------------------------------------
2953 --- Functionality changes from Asterisk 1.6.0 to Asterisk 1.6.1  -------------
2954 ------------------------------------------------------------------------------
2955
2956 Device State Handling
2957 ---------------------
2958  * The event infrastructure in Asterisk got another big update to help support
2959    distributed events.  It currently supports distributed device state and
2960    distributed Voicemail MWI (Message Waiting Indication).  A new module has
2961    been merged, res_ais, which facilitates communicating events between servers.
2962    It uses the SAForum AIS (Service Availability Forum Application Interface
2963    Specification) CLM (Cluster Management) and EVT (Event) services to maintain
2964    a cluster of Asterisk servers, and to share events between them.  For more
2965    information on setting this up, refer to the Distributed Device State section
2966    of the Asterisk wiki at https://wiki.asterisk.org/wiki/x/jw4iAQ
2967
2968 Dialplan Functions
2969 ------------------
2970  * Added a new dialplan function, AST_CONFIG(), which allows you to access
2971    variables from an Asterisk configuration file.
2972  * The JACK_HOOK function now has a c() option to supply a custom client name.
2973  * Added two new dialplan functions from libspeex for audio gain control and
2974    denoise, AGC() and DENOISE(). Both functions can be applied to the tx and
2975    rx directions of a channel from the dialplan.
2976  * The SMDI_MSG_RETRIEVE function now has the ability to search for SMDI messages
2977    based on other parameters.  The default is still to search based on the
2978    forwarding station ID.  However, there are new options that allow you to search
2979    based on the message desk terminal ID, or the message desk number.
2980  * TIMEOUT() has been modified to be accurate down to the millisecond.
2981  * ENUM*() functions now include the following new options:
2982      - 'u' returns the full URI and does not strip off the URI-scheme.
2983      - 's' triggers ISN specific rewriting
2984      - 'i' looks for branches into an Infrastructure ENUM tree
2985      - 'd' for a direct DNS lookup without any flipping of digits.
2986  * TXCIDNAME() has a new zone-suffix parameter (which defaults to 'e164.arpa')
2987  * CHANNEL() now has options for the maximum, minimum, and standard or normal
2988    deviation of jitter, rtt, and loss for a call using chan_sip.
2989
2990 DAHDI channel driver (chan_dahdi) Changes
2991 ----------------------------------------
2992  * Channels can now be configured using named sections in chan_dahdi.conf, just
2993    like other channel drivers, including the use of templates.
2994  * The default for pridialplan has changed from 'national' to 'unknown'.
2995
2996 PBX Changes
2997 -----------
2998  * It is now possible to specify a pattern match as a hint. Once a phone subscribes
2999    to something that matches the pattern a hint will be created using the contents
3000    and variables evaluated.
3001  * Dialplan matching has been extended to allow an extension to return to the
3002    PBX core to wait for more digits.  This is done by using the new dialplan
3003    application called "Incomplete".  This will permit a whole new level of
3004    extension control, by giving the administrator more control over early
3005    matches employing one of the short-circuit pattern match operators.  Note
3006    that custom applications can trigger this same behavior by returning the
3007    special value AST_PBX_INCOMPLETE.
3008
3009 Application Changes
3010 -------------------
3011  * Directory now permits both first and last names to be matched at the same
3012    time.  In addition, the number of digits to enter of the name can be set in
3013    the arguments to Directory; previously, you could enter only 3, regardless
3014    of how many names are in your company.  For large companies, this should be
3015    quite helpful.
3016  * Voicemail now permits a mailbox setting to wrap around from first to last
3017    messages, if the "messagewrap" option is set to a true value.
3018  * Voicemail now permits an external script to be run, for password validation.
3019    The script should output "VALID" or "INVALID" on stdout, depending upon the
3020    wish to validate or invalidate the password given.  Arguments are:
3021    "mailbox" "context" "oldpass" "newpass".  See the sample voicemail.conf for
3022    more details
3023  * Dial has a new option: F(context^extension^pri), which permits a callee to
3024    continue in the dialplan, at the specified label, if the caller hangs up.
3025  * ChanSpy and ExtenSpy have a new option, 's' which suppresses speaking the
3026    technology name (e.g. SIP, IAX, etc) of the channel being spied on.
3027  * The Jack application now has a c() option to supply a custom client name.
3028  * Chanspy has a new option, 'B', which can be used to "barge" on a call. This is
3029    like the pre-existing whisper mode, except that the spy can also talk to the
3030    participant on the bridged channel as well.
3031  * Chanspy has a new option, 'n', which will allow for the spied-on party's name
3032    to be spoken instead of the channel name or number. For more information on the
3033    use of this option, issue the command "core show application ChanSpy" from the
3034    Asterisk CLI.
3035  * Chanspy has a new option, 'd', which allows the spy to use DTMF to swap between
3036    spy modes. Use of this feature overrides the typical use of numeric DTMF. In other
3037    words, if using the 'd' option, it is not possible to enter a number to append to
3038    the first argument to Chanspy(). Pressing 4 will change to spy mode, pressing 5 will
3039    change to whisper mode, and pressing 6 will change to barge mode.
3040  * ExternalIVR now takes several options that affect the way it performs, as
3041    well as having several new commands.  Please see the External IVR page on the Asterisk
3042    wiki for complete documentation: https://wiki.asterisk.org/wiki/x/oQBB
3043  * Added ability to communicate over a TCP socket instead of forking a child process for the
3044    ExternalIVR application.
3045  * ChanIsAvail has a new option, 'a', which will return all available channels instead
3046    of just the first one if you give the function more then one channel to check.
3047  * PrivacyManager now takes an option where you can specify a context where the
3048    given number will be matched. This way you have more control over who is allowed
3049    and it stops the people who blindly enter 10 digits.
3050  * ForkCDR has new options: 'a' updates the answer time on the new CDR; 'A' locks
3051    answer times, disposition, on orig CDR against updates; 'D' Copies the disposition
3052    from the orig CDR to the new CDR after reset; 'e' sets the 'end' time on the
3053    original CDR; 'R' prevents the new CDR from being reset; 's(var=val)' adds/changes
3054    the 'var' variable on the original CDR; 'T' forces ast_cdr_end(), ast_cdr_answer(),
3055    obey the LOCKED flag on cdr's in the chain, and also the ast_cdr_setvar() func.
3056  * The Dial() application no longer copies the language used by the caller to the callee's
3057    channel. If you desire for the caller's channel's language to be used for file playback
3058    to the callee, then the file specified may be prepended with "${CHANNEL(language)}/" .
3059  * SendImage() no longer hangs up the channel on error; instead, it sets the
3060    status variable SENDIMAGESTATUS to one of 'SUCCESS', 'FAILURE', or
3061    'UNSUPPORTED'.  This change makes SendImage() more consistent with other
3062    applications.
3063  * Park has a new option, 's', which silences the announcement of the parking space number.
3064  * A non-numeric, zero, or negative timeout specified to Dial() will now be interpreted as
3065    invalid input and will be assumed to mean that no timeout is desired.
3066
3067 SIP Changes
3068 -----------
3069  * Added DNS manager support to registrations for peers referencing peer entries.
3070    DNS manager runs in the background which allows DNS lookups to be run asynchronously
3071    as well as periodically updating the IP address. These properties allow for
3072    better performance as well as recovery in the event of an IP change.
3073  * Performance improvements via using hash tables (astobj2) and doubly-linked lists to improve
3074    load/reload of large numbers of peers/users by ~40x (for large lists of peers).
3075    These changes also provide performance improvements for call setup and tear down.
3076  * Added ability to specify registration expiry time on a per registration basis in
3077    the register line.
3078  * Added support for T140 RED - redundancy in T.140 to prevent text loss due to
3079    lost packets.
3080  * Added t38pt_usertpsource option. See sip.conf.sample for details.
3081  * Added SIPnotify AMI command, for sending arbitrary SIP notify commands.
3082  * 'sip show peers' and 'sip show users' display their entries sorted in
3083     alphabetical order, as opposed to the order they were in, in the config
3084     file or database.
3085  * Videosupport now supports an additional option, "always", which always sets
3086     up video RTP ports, even on clients that don't support it.  This helps with
3087     callfiles and certain transfers to ensure that if two video phones are
3088     connected, they will always share video feeds.
3089
3090 IAX Changes
3091 -----------
3092  * Existing DNS manager lookups extended to check for SRV records.
3093  * IAX2 encryption support has been improved to support periodic key rotation
3094    within a call for enhanced security.  The option "keyrotate" has been
3095    provided to disable this functionality to preserve backwards compatibility
3096    with older versions of IAX2 that do not support key rotation.
3097
3098 CLI Changes
3099 -----------
3100   * New CLI command, "data get <path> [<search> [<filter>]]" which retrieves the
3101      data tree based on the given <path>.
3102   * New CLI command "data show providers" that will display all the registered
3103      callbacks.
3104   * New CLI command, "config reload <file.conf>" which reloads any module that
3105      references that particular configuration file.  Also added "config list"
3106      which shows which configuration files are in use.
3107   * New CLI commands, "pri show version" and "ss7 show version" that will
3108      display which version of libpri and libss7 are being used, respectively.
3109      A new API call was added so trunk will now have to be compiled against
3110      a versions of libpri and libss7 that have them or it will not know that
3111      these libraries exist.
3112   * The commands "core show globals", "core set global" and "core set chanvar" has
3113      been deprecated in favor of the more semanticly correct "dialplan show globals",
3114      "dialplan set chanvar" and "dialplan set global".
3115   * New CLI command "dialplan show chanvar" to list all variables associated
3116     with a given channel.
3117
3118 DNS manager changes
3119 -------------------
3120   * Addresses managed by DNS manager now can check to see if there is a DNS
3121     SRV record for a given domain and will use that hostname/port if present.
3122
3123 AMI - The manager (TCP/TLS/HTTP)
3124 --------------------------------
3125   * The Status command now takes an optional list of variables to display
3126     along with channel status.
3127   * The QueueEntry event now also includes the channel's uniqueid
3128
3129 ODBC Changes
3130 ------------
3131   * res_odbc no longer has a limit of 1023 total possible unshared connections,
3132     as some people were running into this limit.  This limit has been increased
3133     to 4.2 billion.
3134
3135 Queue changes
3136 -------------
3137   * The TRANSFER queue log entry now includes the the caller's original
3138     position in the transferred-from queue.
3139   * A new configuration option, "timeoutpriority" has been added. Please see the section labeled
3140     "QUEUE TIMING OPTIONS" in configs/queues.conf.sample for a detailed explanation of the option
3141     as well as an explanation about timeout options in general
3142   * Added a new option - C - for forcing the "answered elsewhere" flag on
3143     cancellation of calls in to members of the queue. This is to avoid the
3144     call to a member of a queue having the call listed as a "missed call".
3145
3146 Realtime changes
3147 ----------------
3148   * Several (ODBC, Postgres, MySQL, SQLite) realtime drivers have been given
3149     adaptive capabilities.  What this means in practical terms is that if your
3150     realtime table lacks critical fields, Asterisk will now emit warnings to
3151     that effect.  Also, some of the realtime drivers have the ability (if
3152     configured) to automatically add those columns to the table with the
3153     correct type and length.
3154
3155 Miscellaneous
3156 -------------
3157   * The channel variable ATTENDED_TRANSFER_COMPLETE_SOUND can now be set using
3158     the 'setvar' option to cause a given audio file to be played upon completion
3159     of an attended transfer.  Currently it works for DAHDI, IAX2, SIP, and
3160     Skinny channels only.
3161   * You can now compile Asterisk against the Hoard Memory Allocator, see the
3162     Hoard page on the Asterisk wiki for more information:
3163     https://wiki.asterisk.org/wiki/x/pQBB
3164   * Config file variables may now be appended to, by using the '+=' append
3165     operator.  This is most helpful when working with long SQL queries in
3166     func_odbc.conf, as the queries no longer need to be specified on a single
3167     line.
3168   * CDR config file, cdr.conf, has an added option, "initiatedseconds",
3169     which will add a second to the billsec when the ending
3170     time is set, if the number in the microseconds field of the end time is
3171     greater than the number of microseconds in the answer time. This allows
3172     users to count the 'initiated' seconds in their billing records.
3173
3174 ------------------------------------------------------------------------------
3175 --- Functionality changes from Asterisk 1.4.X to Asterisk 1.6.0  -------------
3176 ------------------------------------------------------------------------------
3177
3178 AMI - The manager (TCP/TLS/HTTP)
3179 --------------------------------
3180   * Manager has undergone a lot of changes, all of them documented
3181     on the Asterisk wiki at https://wiki.asterisk.org/wiki/x/tQBB
3182   * Manager version has changed to 1.1
3183   * Added a new action 'CoreShowChannels' to list currently defined channels
3184      and some information about them.
3185   * Added a new action 'SIPshowregistry' to list SIP registrations.
3186   * Added TLS support for the manager interface and HTTP server
3187   * Added the URI redirect option for the built-in HTTP server
3188   * The output of CallerID in Manager events is now more consistent.
3189      CallerIDNum is used for number and CallerIDName for name.
3190   * Enable https support for builtin web server.
3191      See configs/http.conf.sample for details.
3192   * Added a new action, GetConfigJSON, which can return the contents of an
3193      Asterisk configuration file in JSON format.  This is intended to help
3194      improve the performance of AJAX applications using the manager interface
3195      over HTTP.
3196   * SIP and IAX manager events now use "ChannelType" in all cases where we
3197      indicate channel driver. Previously, we used a mixture of "Channel"
3198      and "ChannelDriver" headers.
3199   * Added a "Bridge" action which allows you to bridge any two channels that
3200      are currently active on the system.
3201   * Added a "ListAllVoicemailUsers" action that allows you to get a list of all
3202      the voicemail users setup.
3203   * Added 'DBDel' and 'DBDelTree' manager commands.
3204   * cdr_manager now reports events via the "cdr" level, separating it from
3205      the very verbose "call" level.
3206   * Manager users are now stored in memory. If you change the manager account
3207     list (delete or add accounts) you need to reload manager.
3208   * Added Masquerade manager event for when a masquerade happens between
3209      two channels.
3210   * Added "manager reload" command for the CLI
3211   * Lots of commands that only provided information are now allowed under the
3212      Reporting privilege, instead of only under Call or System.
3213   * The IAX* commands now require either System or Reporting privilege, to
3214      mirror the privileges of the SIP* commands.
3215   * Added ability to retrieve list of categories in a config file.
3216   * Added ability to retrieve the content of a particular category.
3217   * Added ability to empty a context.
3218   * Created new action to create a new file.
3219   * Updated delete action to allow deletion by line number with respect to category.
3220   * Added new action insert to add new variable to category at specified line.
3221   * Updated action newcat to allow new category to be inserted in file above another
3222     existing category.
3223   * Added new event "JitterBufStats" in the IAX2 channel
3224   * Originate now requires the Originate privilege and, if you want to call out
3225     to a subshell, it requires the System privilege, as well.  This was done to
3226     enhance manager security.
3227   * Originate now accepts codec settings with "Codecs: alaw, ulaw, h264"
3228   * New command: Atxfer. See https://wiki.asterisk.org/wiki/x/uABB for more details
3229     or manager show command Atxfer from the CLI
3230   * New command: IAXregistry. See https://wiki.asterisk.org/wiki/x/uABB for more
3231     details or manager show command IAXregistry from the CLI
3232
3233 Dialplan functions
3234 ------------------
3235   * Added the DEVICE_STATE() dialplan function which allows retrieving any device
3236      state in the dialplan, as well as creating custom device states that are
3237      controllable from the dialplan.
3238   * Extend CALLERID() function with "pres" and "ton" parameters to
3239      fetch string representation of calling number presentation indicator
3240      and numeric representation of type of calling number value.
3241   * MailboxExists converted to dialplan function
3242   * A new option to Dial() for telling IP phones not to count the call
3243      as "missed" when dial times out and cancels.
3244   * Added LOCK(), TRYLOCK(), and UNLOCK(), which provide a single level dialplan
3245      mutex.  No deadlocks are possible, as LOCK() only allows a single lock to be
3246      held for any given channel.  Also, locks are automatically freed when a
3247      channel is hung up.
3248   * Added HINT() dialplan function that allows retrieving hint information.
3249      Hints are mappings between extensions and devices for the sake of
3250      determining the state of an extension.  This function can retrieve the list
3251      of devices or the name associated with a hint.
3252   * Added EXTENSION_STATE() dialplan function which allows retrieving the state
3253     of any extension.
3254   * Added SYSINFO() dialplan function which allows retrieval of system information
3255   * Added a new dialplan function, DIALPLAN_EXISTS(), which allows you to check for
3256      the existence of a dialplan target.
3257   * Added two new dialplan functions, TOUPPER and TOLOWER, which convert a string to
3258      upper and lower case, respectively.
3259   * When bridging, Asterisk sets the BRIDGEPVTCALLID to the channel drivers unique
3260      ID for the call (not the Asterisk call ID or unique ID), provided that the
3261      channel driver supports this. For SIP, you get the SIP call-ID for the
3262      bridged channel which you can store in the CDR with a custom field.
3263
3264 CLI Changes
3265 -----------
3266   * Added CLI permissions, config file: cli_permissions.conf
3267      default is to allow all commands for every local user/group.
3268      Also this new feature added three new CLI commands:
3269       - cli check permissions {<username>|@<groupname>|<username>@<groupname>} [<command>]
3270       - cli reload permissions
3271       - cli show permissions
3272   * New CLI command "core show hint" (usage: core show hint <exten>)
3273   * New CLI command "core show settings"
3274   * Added 'core show channels count' CLI command.
3275   * Added the ability to set the core debug and verbose values on a per-file basis.
3276   * Added 'queue pause member' and 'queue unpause member' CLI commands
3277   * Ability to set process limits ("ulimit") without restarting Asterisk
3278   * Enhanced "agi debug" to print the channel name as a prefix to the debug
3279      output to make debugging on busy systems much easier.
3280   * New CLI commands "dialplan set extenpatternmatching true/false"
3281   * New CLI command: "core set chanvar" to set a channel variable from the CLI.
3282   * Added an easy way to execute Asterisk CLI commands at startup.  Any commands
3283     listed in the startup_commands section of cli.conf will get executed.
3284   * Added a CLI command, "devstate change", which allows you to set custom device
3285      states from the func_devstate module that provides the DEVICE_STATE() function
3286      and handling of the "Custom:" devices.
3287   * New CLI command: "sip show sched" which shows all ast_sched entries for sip,
3288     sorted into the different possible callbacks, with the number of entries
3289     currently scheduled for each. Gives you a feel for how busy the sip channel
3290     driver is.
3291   * Added 'skinny show lines verbose' CLI command. This will show the subs for every channel.
3292   * Cleanup another bunch of CLI commands. Now all modules follow the same schema.
3293     (Done by lmadsen, junky and mvanbaak during the devcon 2008)
3294
3295 SIP changes
3296 -----------
3297  * Added a new 'faxdetect=yes|no' configuration option to sip.conf.  When this
3298     option is enabled, Asterisk will watch for a CNG tone in the incoming audio
3299     for a received call.  If it is detected, the channel will jump to the
3300     'fax' extension in the dialplan.
3301   * The default SIP useragent= identifier now includes the Asterisk version
3302   * A new option, match_auth_username in sip.conf changes the matching of incoming requests.
3303      If set, and the incoming request carries authentication info,
3304      the username to match in the users list is taken from the Digest header
3305      rather than from the From: field. This feature is considered experimental.
3306   * The "musiconhold" and "musicclass" settings in sip.conf are now removed,
3307      since they where replaced by "mohsuggest" and "mohinterpret" in version 1.4
3308   * The "localmask" setting was removed in version 1.2 and the reminder about it
3309      being removed is now also removed.
3310   * A new option "busylevel" for setting a level of calls where asterisk reports
3311      a device as busy, to separate it from call-limit. This value is also added
3312      to the SIP_PEER dialplan function.
3313   * A new realtime family called "sipregs" is now supported to store SIP registration
3314      data. If this family is defined, "sippeers" will be used for configuration and
3315      "sipregs" for registrations. If it's not defined, "sippeers" will be used for
3316      registration data, as before.
3317   * The SIPPEER function have new options for port address, call and pickup groups
3318   * Added support for T.140 realtime text in SIP/RTP
3319   * The "checkmwi" option has been removed from sip.conf, as it is no longer
3320      required due to the restructuring of how MWI is handled.  See the descriptions
3321      in this file of the "pollmailboxes" and "pollfreq" options to voicemail.conf
3322      for more information.
3323   * Added rtpdest option to CHANNEL() dialplan function.
3324   * Added SIPREFERRINGCONTEXT and SIPREFERREDBYHDR variables which are set when a transfer takes place.
3325   * SIP now adds a header to the CANCEL if the call was answered by another phone
3326      in the same dial command, or if the new c option in dial() is used.
3327   * The new default is that 100 Trying is not sent on REGISTER attempts as the RFC specifically
3328      states it is not needed. For phones, however, that do require it the "registertrying" option
3329      has been added so it can be enabled.
3330   * A new option called "callcounter" (global/peer/user level) enables call counters needed
3331      for better status reports needed for queues and SIP subscriptions. (Call-Limit was previously
3332      used to enable this functionality).
3333   * New settings for timer T1 and timer B on a global level or per device. This makes it
3334      possible to force timeout faster on non-responsive SIP servers. These settings are
3335      considered advanced, so don't use them unless you have a problem.
3336   * Added a dial string option to be able to set the To: header in an INVITE to any
3337      SIP uri.
3338   * Added a new global and per-peer option, qualifyfreq, which allows you to configure
3339      the qualify frequency.
3340   * Added SIP Session Timers support (RFC 4028).  This prevents stuck SIP sessions that
3341      were not properly torn down due to network or endpoint failures during an established
3342      SIP session.
3343   * Added experimental TCP and TLS support for SIP.  See https://wiki.asterisk.org/wiki/x/ygBB
3344      and configs/sip.conf.sample for more information on how it is used.
3345   * Added a new configuration option "authfailureevents" that enables manager events when
3346     a peer can't authenticate properly.
3347   * Added DNS manager support to registrations for peers not referencing a peer entry.
3348
3349 IAX2 changes
3350 ------------
3351   * Added the trunkmaxsize configuration option to chan_iax2.
3352   * Added the srvlookup option to iax.conf
3353   * Added support for OSP.  The token is set and retrieved through the CHANNEL()
3354      dialplan function.
3355
3356 XMPP Google Talk/Jingle changes
3357 -------------------------------
3358   * Added the bindaddr option to gtalk.conf.
3359
3360 Skinny changes
3361 -------------
3362   * Added skinny show device, skinny show line, and skinny show settings CLI commands.
3363   * Proper codec support in chan_skinny.
3364   * Added settings for IP and Ethernet QoS requests
3365
3366 MGCP changes
3367 ------------
3368   * Added separate settings for media QoS in mgcp.conf
3369
3370 Console Channel Driver changes
3371 ------------------------------
3372   * Added experimental support for video send & receive to chan_oss.
3373     This requires SDL and ffmpeg/avcodec, plus Video4Linux or X11 to act as
3374     a video source.
3375
3376 Phone channel changes (chan_phone)
3377 ----------------------------------
3378   * Added G729 passthrough support to chan_phone for Sigma Designs boards.
3379
3380 H.323 channel Changes
3381 ---------------------
3382   * H323 remote hold notification support added (by NOTIFY message
3383      and/or H.450 supplementary service)
3384
3385 Local channel changes
3386 ---------------------
3387   * The device state functionality in the Local channel driver has been updated
3388      to indicate INUSE or NOT_INUSE when a Local channel is being used as opposed
3389      to just UNKNOWN if the extension exists.
3390   * Added jitterbuffer support for chan_local.  This allows you to use the
3391      generic jitterbuffer on incoming calls going to Asterisk applications.
3392      For example, this would allow you to use a jitterbuffer for an incoming
3393      SIP call to Voicemail by putting a Local channel in the middle.  This
3394      feature is enabled by using the 'j' option in the Dial string to the Local
3395      channel in conjunction with the existing 'n' option for local channels.
3396   * A 'b' option has been added which causes chan_local to return the actual channel
3397      that is behind it when queried. This is useful for transfer scenarios as the
3398      actual channel will be transferred, not the Local channel.
3399
3400 Agent channel changes
3401 ----------------------
3402   * The ackcall and endcall options are now supplemented with options acceptdtmf
3403     and enddtmf. These allow for the DTMF keypress to be configurable. The options
3404     default to their old hard-coded values ('#' and '*' respectively) so this should
3405     not break any existing agent installations.
3406
3407 DAHDI channel driver (chan_dahdi) Changes
3408 ----------------------------------------
3409   * SS7 support (via libss7 library)
3410   * In India, some carriers transmit CID via dtmf. Some code has been added
3411      that will handle some situations. The cidstart=polarity_IN choice has been added for
3412      those carriers that transmit CID via dtmf after a polarity change.
3413   * CID matching information is now shown when doing 'dialplan show'.
3414   * Added dahdi show version CLI command.
3415   * Added setvar support to chan_dahdi.conf channel entries.
3416   * Added two new options: mwimonitor and mwimonitornotify.  These options allow
3417      you to enable MWI monitoring on FXO lines.  When the MWI state changes,
3418      the script specified in the mwimonitornotify option is executed.  An internal
3419      event indicating the new state of the mailbox is also generated, so that
3420      the normal MWI facilities in Asterisk work as usual.
3421   * Added signalling type 'auto', which attempts to use the same signalling type
3422      for a channel as configured in DAHDI. This is primarily designed for analog
3423      ports, but will also work for digital ports that are configured for FXS or FXO
3424      signalling types. This mode is also the default now, so if your chan_dahdi.conf
3425      does not specify signalling for a channel (which is unlikely as the sample
3426      configuration file has always recommended specifying it for every channel) then
3427      the 'auto' mode will be used for that channel if possible.
3428   * Added a 'dahdi set dnd' command to allow CLI control of the Do-Not-Disturb
3429      state for a channel; also ensured that the DNDState Manager event is
3430      emitted no matter how the DND state is set or cleared.
3431
3432 New Channel Drivers
3433 -------------------
3434   * Added a new channel driver, chan_unistim.  See the Asterisk wiki at
3435      https://wiki.asterisk.org/wiki/x/vgsiAQ and configs/unistim.conf.sample
3436      for details.  This new channel driver allows you to use Nortel i2002,
3437      i2004, and i2050 phones with Asterisk.
3438   * Added a new channel driver, chan_console, which uses portaudio as a cross
3439      platform audio interface.  It was written as a channel driver that would
3440      work with Mac CoreAudio, but portaudio supports a number of other audio
3441      interfaces, as well. Note that this channel driver requires v19 or higher
3442      of portaudio; older versions have a different API.
3443
3444 DUNDi changes
3445 -------------
3446   * Added the ability to specify arguments to the Dial application when using
3447      the DUNDi switch in the dialplan.
3448   * Added the ability to set weights&n