Fix a file descriptor leak in off nominal path
[asterisk/asterisk.git] / CHANGES
diff --git a/CHANGES b/CHANGES
index b728626..8bcd533 100644 (file)
--- a/CHANGES
+++ b/CHANGES
 === and the other UPGRADE files for older releases.
 ===
 ==============================================================================
+------------------------------------------------------------------------------
+--- Functionality changes from Asterisk 11 to Asterisk 12 --------------------
+------------------------------------------------------------------------------
+
+
+AMI (Asterisk Manager Interface)
+------------------
+ * The SIPshowpeer action will now include a 'SubscribeContext' field for a peer
+   in its response if the peer has a subscribe context set.
+
+ * The SIPqualifypeer action now acknowledges the request once it has established
+   that the request is against a known peer. It also issues a new event,
+   'SIPqualifypeerdone', once the qualify action has been completed.
+
+ * The PlayDTMF action now supports an optional 'Duration' parameter.  This
+   specifies the duration of the digit to be played, in milliseconds.
+
+ * Added VoicemailRefresh action to allow an external entity to trigger mailbox
+   updates when changes occur instead of requiring the use of pollmailboxes.
+
+ * CLI Command 'Manager Show Commands' no longer truncates command names longer
+   than 15 characters and no longer shows authorization requirement for commands.
+   'Manager Show Command' now displays the privileges needed for using a given
+   manager command instead.
+
+ * Added new action "ControlPlayback". The ControlPlayback action allows an AMI
+   client to manipulate audio currently being played back on a channel. The
+   supported operations depend on the application being used to send audio to
+   the channel. When the audio playback was initiated using the ControlPlayback
+   application or CONTROL STREAM FILE AGI command, the audio can be paused,
+   stopped, restarted, reversed, or skipped forward. When initiated by other
+   mechanisms (such as the Playback application), the audio can be stopped,
+   reversed, or skipped forward.
+
+ * Channel related events now contain a snapshot of channel state, adding new
+   fields to many of these events.
+
+ * The AMI event 'Newexten' field 'Extension' is deprecated, and may be removed
+   in a future release. Please use the common 'Exten' field instead.
+
+ * The AMI event 'UserEvent' from app_userevent now contains the channel state
+   fields. The channel state fields will come before the body fields.
+
+ * The deprecated use of | (pipe) as a separator in the channelvars setting in
+   manager.conf has been removed.
+
+Channel Drivers
+------------------
+
+chan_mobile
+------------------
+ * Added general support for busy detection.
+
+ * Added ECAM command support for Sony Ericsson phones.
+
+chan_sip
+------------------
+ * Added support for RFC 3327 "Path" headers. This can be enabled in sip.conf
+   using the 'supportpath' setting, either on a global basis or on a peer basis.
+   This setting enables Asterisk to route outgoing out-of-dialog requests via a
+   set of proxies by using a pre-loaded route-set defined by the Path headers in
+   the REGISTER request. See Realtime updates for more configuration information.
+
+Features
+-------------------
+ * The BRIDGE_FEATURES channel variable would previously only set features for
+   the calling party and would set this feature regardless of whether the
+   feature was in caps or in lowercase. Use of a caps feature for a letter
+   will now apply the feature to the calling party while use of a lowercase
+   letter will apply that feature to the called party.
+
+ * Add support for automixmonitor to the BRIDGE_FEATURES channel variable.
+
+ * PARKINGSLOT and PARKEDLOT channel variables will now be set for a parked
+   channel even when comebactoorigin=yes
+
+Logging
+-------------------
+ * When performing queue pause/unpause on an interface without specifying an
+   individual queue, the PAUSEALL/UNPAUSEALL event will only be logged if at
+   least one member of any queue exists for that interface.
+
+ * Added the 'queue_log_realtime_use_gmt' option to have timestamps in GMT
+   for realtime queue log entries.
+
+MeetMe
+-------------------
+* Added the 'n' option to MeetMe to prevent application of the DENOISE function
+  to a channel joining a conference. Some channel drivers that vary the number
+  of audio samples in a voice frame will experience significant quality problems
+  if a denoiser is attached to the channel; this option gives them the ability
+  to remove the denoiser without having to unload func_speex.
+
+Queue
+-------------------
+ * Add queue available hint.  exten => 8501,hint,Queue:markq_avail
+   Note: the suffix '_avail' after the queuename.
+   Reports 'InUse' for no logged in agents or no free agents.
+   Reports 'Idle' when an agent is free.
+
+Core
+------------------
+ * Redirecting reasons can now be set to arbitrary strings. This means
+   that the REDIRECTING dialplan function can be used to set the redirecting
+   reason to any string. It also allows for custom strings to be read as the
+   redirecting reason from SIP Diversion headers.
+
+Realtime
+------------------
+ * Dynamic realtime tables for SIP Users can now include a 'path' field. This
+   will store the path information for that peer when it registers. Realtime
+   tables can also use the 'supportpath' field to enable Path header support.
+
+ * LDAP realtime configurations for SIP Users now have the AstAccountPathSupport
+   objectIdentifier. This maps to the supportpath option in sip.conf. 
+
+RTP
+------------------
+ * ICE/STUN/TURN support in res_rtp_asterisk has been made optional.  To enable
+   them, an Asterisk-specific version of pjproject needs to be installed.
+   Tarballs are available from https://github.com/asterisk/pjproject/tags/.
+
+XMPP
+------------------
+ * Device state for XMPP buddies is now available using the following format:
+   XMPP/<client name>/<buddy address>
+   If any resource is available the device state is considered to be not in use.
+   If no resources exist or all are unavailable the device state is considered
+   to be unavailable.
 
 ------------------------------------------------------------------------------
 --- Functionality changes from Asterisk 10 to Asterisk 11 --------------------
 ------------------------------------------------------------------------------
 
-Core
-----
- * The expression parser now recognizes the ABS() absolute value function,
-   which will convert negative floating point values to positive values.
+Build System
+-------------------
  * The Asterisk build system will now build and install a shared library
    (libasteriskssl.so) used to wrap various initialization and shutdown functions
    from the libssl and libcrypto libraries provided by OpenSSL. This is done so
@@ -24,133 +151,589 @@ Core
    in any single process. If desired, this feature can be disabled by supplying
    the "--disable-asteriskssl" option to the configure script.
 
-CLI Changes
+ * A new make target, 'full', has been added to the Makefile.  This performs
+   the same compilation actions as make all, but will also scan the entirety of
+   each source file for documentation.  This option is needed to generate AMI
+   event documentation.  Note that your system must have Python in order for
+   this make target to succeed.
+
+ * The optimization portion of the build system has been reworked to avoid
+   broken builds on certain architectures.  All architecture-specific
+   optimization has been removed in favor of using -march=native to allow gcc
+   to detect the environment in which it is running when possible.  This can
+   be toggled as BUILD_NATIVE under "Compiler Flags" in menuselect.
+
+ * BUILD_CFLAGS and BUILD_LDFLAGS can now be passed to menuselect, e.g.,
+   make BUILD_CFLAGS="whatever" BUILD_LDFLAGS="whatever"
+
+ * Remove "asterisk/version.h" in favor of "asterisk/ast_version.h".  If you
+   previously parsed the header file to obtain the version of Asterisk, you
+   will now have to go through Asterisk to get the version information.
+
+
+Applications
 -------------------
- * mixmonitor list <channel> command will now show MixMonitor ID, and the filenames
-   of all running mixmonitors on a channel.
- * The debuglevel of "pri set debug" is now a bitmask ranging from 0 to 15 if
-   numeric instead of 0, 1, or 2.
+
+Bridge
+-------------------
+ * Added 'F()' option. Similar to the dial option, this can be supplied with
+   arguments indicating where the callee should go after the caller is hung up,
+   or without options specified, the priority after the Queue will be used.
+
 
 ConfBridge
 -------------------
  * Added menu action admin_toggle_mute_participants.  This will mute / unmute
-   all non-admin participants on a conference.  The confbridge configuration file
-   also allows for the default sounds played to all conference users when this
-   occurs to be overriden using sound_participants_unmuted and sound_participants_muted.
- * Added menu action participant_count.  This will playback the number of current
-   participants in a conference.
+   all non-admin participants on a conference.  The confbridge configuration
+   file also allows for the default sounds played to all conference users when
+   this occurs to be overriden using sound_participants_unmuted and
+   sound_participants_muted.
+
+ * Added menu action participant_count.  This will playback the number of
+   current participants in a conference.
+
+ * Added announcement configuration option to user profile. If set the sound
+   file will be played to the user, and only the user, upon joining the
+   conference bridge.
+
+ * Added record_file_append option that defaults to "yes", but if set to no
+   will create a new file between each start/stop recording.
+
+
+Dial
+-------------------
+ * Added 'b' and 'B' options to Dial that execute a Gosub on callee and caller
+   channels respectively before the callee channels are called.
+
+
+ExternalIVR
+-------------------
+ * Added support for IPv6.
+
+ * Add interrupt ('I') command to ExternalIVR.  Sending this command from an
+   external process will cause the current playlist to be cleared, including
+   stopping any audio file that is currently playing.  This is useful when you
+   want to interrupt audio playback only when specific DTMF is entered by the
+   caller.
+
+
+FollowMe
+-------------------
+ * A new option, 'I' has been added to app_followme. By setting this option,
+   Asterisk will not update the caller with connected line changes when they
+   occur.  This is similar to app_dial and app_queue.
+
+ * The 'N' option is now ignored if the call is already answered.
+
+ * Added 'b' and 'B' options to FollowMe that execute a Gosub on callee
+   and caller channels respectively before the callee channels are called.
+
+ * The winning FollowMe outgoing call is now put on hold if the caller put it on
+   hold.
+
+
+MixMonitor
+------------------
+ * MixMonitor hooks now have IDs associated with them which can be used to
+   assign a target to StopMixMonitor. Use of MixMonitor's i(variable) option
+   will allow storage of the MixMontior ID in a channel variable. StopMixmonitor
+   now accepts that ID as an argument.
+
+ * Added 'm' option, which stores a copy of the recording as a voicemail in the
+   indicated mailboxes.
+
+
+MySQL
+-------------------
+ * The connect action in app_mysql now allows you to specify a port number to
+   connect to.  This is useful if you run a MySQL server on a non-standard
+   port number.
+
+
+OSP Applications
+-------------------
+ * Increased the default number of allowed destinations from 5 to 12.
+
+
+Page
+-------------------
+ * The app_page application now no longer depends on DAHDI or app_meetme.  It
+   has been re-architected to use app_confbridge internally.
+
+
+Queue
+-------------------
+ * Added queue options autopausebusy and autopauseunavail for automatically
+   pausing a queue member when their device reports busy or congestion.
+
+ * The 'ignorebusy' option for queue members has been deprecated in favor of
+   the option 'ringinuse. Also a 'queue set ringinuse' CLI command has been
+   added as well as an AMI action 'QueueMemberRingInUse' to set this variable on a
+   per interface basis. Individual ringinuse values can now be set in
+   queues.conf via an argument to member definitions. Lastly, the queue
+   'ringinuse' setting now only determines defaults for the per member
+   'ringinuse' setting and does not override per member settings like it does
+   in earlier versions.
+
+ * Added 'F()' option. Similar to the dial option, this can be supplied with
+   arguments indicating where the callee should go after the caller is hung up,
+   or without options specified, the priority after the Queue will be used.
+
+ * Added new option log_member_name_as_agent, which will cause the membername to
+   be logged in the agent field for ADDMEMBER and REMOVEMEMBER queue events if a
+   state_interface has been set.
+
+ * Add queue monitoring hints.  exten => 8501,hint,Queue:markq.
+
+SayUnixTime
+------------------
+ * Added 'j' option to SayUnixTime. SayUnixTime no longer auto jumps to extension
+   when receiving DTMF.  Use the 'j' option to enable extension jumping. Also
+   changed arguments to SayUnixTime so that every option is truly optional even
+   when using multiple options (so that j option could be used without having to
+   manually specify timezone and format) There are other benefits, e.g., format
+   can now be used without specifying time zone as well.
+
 
 Voicemail
 ------------------
- * Addition of the VM_INFO function - see Dialplan function changes
+ * Addition of the VM_INFO function - see Function changes.
+
  * The imapserver, imapport, and imapflags configuration options can now be
    overriden on a user by user basis.
 
-SIP Changes
------------
- * Asterisk will no longer substitute CID number for CID name into display
+ * When voicemail plays a message's envelope with saycid set to yes, when
+   reaching the caller id field it will play a recording of a file with the same
+   base name as the sender's callerid if there is a similarly named file in
+   <astspooldir>/recordings/callerids/
+
+ * Voicemails now contains a unique message identifier "msg_id", which is stored
+   in the message envelope with the sound files.  IMAP backends will now store
+   the message identifiers with a header of "X-Asterisk-VM-Message-ID".  ODBC
+   backends will store the message identifier in a "msg_id" column.  See
+   UPGRADE.txt for more information.
+
+ * Added VoiceMailPlayMsg application.  This application will play a single
+   voicemail message from a mailbox.  The result of the application, SUCCESS or
+   FAILED, is stored in the channel variable VOICEMAIL_PLAYBACKSTATUS.
+
+
+Functions
+------------------
+ * Hangup handlers can be attached to channels using the CHANNEL() function.
+   Hangup handlers will run when the channel is hung up similar to the h
+   extension. The hangup_handler_push option will push a GoSub compatible
+   location in the dialplan onto the channel's hangup handler stack.  The
+   hangup_handler_pop option will remove the last added location, and optionally
+   replace it with a new GoSub compatible location.  The hangup_handler_wipe
+   option will remove all locations on the stack, and optionally add a new
+   location.
+
+ * The expression parser now recognizes the ABS() absolute value function,
+   which will convert negative floating point values to positive values.
+
+ * FAXOPT(faxdetect) will enable a generic fax detect framehook for dialplan
+   control of faxdetect.
+
+ * Addition of the VM_INFO function that can be used to retrieve voicemail
+   user information, such as the email address and full name.
+   The MAILBOX_EXISTS dialplan function has been deprecated in favour of
+   VM_INFO.
+
+ * The REDIRECTING function now supports the redirecting original party id
+   and reason.
+
+ * Two new functions have been added: FEATURE() and FEATUREMAP().  FEATURE()
+   lets you set some of the configuration options from the [general] section
+   of features.conf on a per-channel basis.  FEATUREMAP() lets you customize
+   the key sequence used to activate built-in features, such as blindxfer,
+   and automon.  See the built-in documentation for details.
+
+ * MESSAGE(from) for incoming SIP messages now returns "display-name" <uri>
+   instead of simply the uri.  This is the format that MessageSend() can use
+   in the from parameter for outgoing SIP messages.
+
+ * Added the PRESENCE_STATE function.  This allows retrieving presence state
+   information from any presence state provider.  It also allows setting
+   presence state information from a CustomPresence presence state provider.
+   See AMI/CLI changes for related commands.
+
+ * Added the AMI_CLIENT function to make manager account attributes available
+   to the dialplan. It currently supports returning the current number of
+   active sessions for a given account.
+
+ * Added support for private party ID information to CALLERID, CONNECTEDLINE,
+   and the REDIRECTING functions.
+
+
+Channel Drivers
+------------------
+
+chan_local
+------------------
+ * Added a manager event "LocalBridge" for local channel call bridges between
+   the two pseudo-channels created.
+
+
+chan_dahdi
+------------------
+ * Added dialtone_detect option for analog ports to disconnect incoming
+   calls when dialtone is detected.
+
+ * Added option colp_send to send ISDN connected line information.  Allowed
+   settings are block, to not send any connected line information; connect, to
+   send connected line information on initial connect; and update, to send
+   information on any update during a call.  Default is update.
+
+ * Add options namedcallgroup and namedpickupgroup to support installations
+   where a higher number of groups (>64) is required.
+
+ * Added support to use private party ID information with PRI calls.
+
+
+chan_motif
+------------------
+ * A new channel driver named chan_motif has been added which provides support for
+   Google Talk and Jingle in a single channel driver. This new channel driver includes
+   support for both audio and video, RFC2833 DTMF, all codecs supported by Asterisk,
+   hold, unhold, and ringing notification. It is also compliant with the current Jingle
+   specification, current Google Jingle specification, and the original Google Talk
+   protocol.
+
+
+chan_ooh323
+------------------
+ * Added NAT support for RTP.  Setting in config is 'nat', which can be set
+   globally and overriden on a peer by peer basis.
+
+ * Direct media functionality has been added. Options in config are:
+   directmedia (directrtp) and directrtpsetup (earlydirect)
+
+ * ChannelUpdate events now contain a CallRef header.
+
+
+chan_sip
+------------------
+ * Asterisk will no longer substitute CID number for CID name in the display
    name field if CID number exists without a CID name. This change improves
    compatibility with certain device features such as Avaya IP500's directory
    lookup service.
+
  * A new setting for autocreatepeer (autocreatepeer=persistent) allows peers
    created using that setting to not be removed during SIP reload.
- * Add support to realtime for the 'callbackextension' option
+
+ * Added settings recordonfeature and recordofffeature.  When receiving an INFO
+   request with a "Record:" header, this will turn the requested feature on/off.
+   Allowed values are 'automon', 'automixmon', and blank to disable.  Note that
+   dynamic features must be enabled and configured properly on the requesting
+   channel for this to function properly.
+
+ * Add support to realtime for the 'callbackextension' option.
+
  * When multiple peers exist with the same address, but differing
    callbackextension options, incoming requests that are matched by address
    will be matched to the peer with the matching callbackextension if it is
    available.
- * NAT settings are now a combinable list of options. The equivalent of the
-   deprecated nat=yes is nat=force_rport,comedia. nat=no behaves as before.
+
  * Two new NAT options, auto_force_rport and auto_comedia, have been added
    which set the force_rport and comedia options automatically if Asterisk
    detects that an incoming SIP request crossed a NAT after being sent by
    the remote endpoint.
+
+ * The default global nat setting in sip.conf has been changed from force_rport
+   to auto_force_rport.
+
+ * NAT settings are now a combinable list of options. The equivalent of the
+   deprecated nat=yes is nat=force_rport,comedia. nat=no behaves as before.
+
  * Adds an option send_diversion which can be disabled to prevent
-   diversion headers from automatically being added to invites.
+   diversion headers from automatically being added to INVITE requests.
+
+ * Add support for lightweight NAT keepalive. If enabled a blank packet will
+   be sent to the remote host at a given interval to keep the NAT mapping open.
+   This can be enabled using the keepalive configuration option.
+
+ * Add option 'tonezone' to specify country code for indications.  This option
+   can be set both globally and overridden for specific peers.
+
+ * The SIP Security Events Framework now supports IPv6.
+
+ * Add a new setting for directmedia, 'outgoing', to alleviate INVITE glares
+   between multiple user agents. When set, for directmedia reinvites,
+   Asterisk will not send an immediate reinvite on an incoming call leg. This
+   option is useful when peered with another SIP user agent that is known to
+   send immediate direct media reinvites upon call establishment.
+
+ * Add support for WebSocket transport. This can be configured using 'ws' or 'wss'
+   as the transport.
+
+ * Add options subminexpiry and submaxexpiry to set limits of subscription
+   timer independently from registration timer settings. The setting of the
+   registration timer limits still is done by options minexpiry, maxexpiry
+   and defaultexpiry. For backwards compatibility the setting of minexpiry
+   and maxexpiry also is used to configure the subscription timer limits if
+   subminexpiry and submaxexpiry are not set in sip.conf.
+
+ * Set registration timer limits to default values when reloading sip
+   configuration and values are not set by configuration.
 
-Chan_local changes
+ * Add options namedcallgroup and namedpickupgroup to support installations
+   where a higher number of groups (>64) is required.
+
+ * When a MESSAGE request is received, the address the request was received from
+   is now saved in the SIP_RECVADDR variable.
+
+ * Add ANI2/OLI parsing for SIP.  The "From" header in INVITE requests is now
+   parsed for the presence of "isup-oli", "ss7-oli", or "oli" tags.  If present,
+   the ANI2/OLI information is set on the channel, which can be retrieved using
+   the CALLERID function.
+
+ * Peers can now be configured to support negotiation of ICE candidates using
+   the setting icesupport.  See res_rtp_asterisk changes for more information.
+
+ * Added support for format attribute negotiation.  See the Codecs changes for
+   more information.
+
+ * Extra headers specified with SIPAddHeader are sent with the REFER message
+   when using Transfer application. See refer_addheaders in sip.conf.sample.
+
+ * Added support to use private party ID information with calls.
+
+ * Adds an option discard_remote_hold_retrieval that when set stops telling
+   the peer to start music on hold.
+
+
+chan_skinny
 ------------------
- * Added a manager event "LocalBridge" for local channel call bridges between
-   the two pseudo-channels created.
+ * Added skinny version 17 protocol support.
 
-Codec changes
--------------
- * Codec lists may now be modified by the '!' character, to allow succinct
-   specification of a list of codecs allowed and disallowed, without the
-   requirement to use two different keywords.  For example, to specify all
-   codecs except g729 and g723, one need only specify allow=all,!g729,!g723.
 
-Music On Hold Changes
----------------------
- * Added 'announcement' option which will play at the start of MOH and between
-   songs in modes of MOH that can detect transitions between songs (eg.
-   files, mp3, etc).
+chan_unistim
+--------------------
+ * Added ability to use multiple lines for a single phone.  This allows multiple
+   calls to occur on a single phone, using callwaiting and switching between calls.
 
-Queue changes
--------------
- * Added queue options autopausebusy and autopauseunavail for automatically
-   pausing a queue member when their device reports busy or congestion.
+ * Added option 'sharpdial' allowing end dialing by pressing # key
 
-Voicemail changes
------------------
- * When voicemail plays a message's envelope with saycid set to yes, when reaching
-   the caller id field it will play a recording of a file with the same base name
-   as the sender's callerid if there is a similarly named file in
-   <astspooldir>/recordings/callerids/
+ * Added option 'interdigit_timer' to control phone dial timeout
 
-Applications
-------------
- * Added 'j' option to SayUnixTime. SayUnixTime no longer auto jumps to extension
-   when receiving DTMF.  Use the 'j' option to enable extension jumping. Also
-   changed arguments to SayUnixTime so that every option is truly optional even
-   when using multiple options (so that j option could be used without having to
-   manually specify timezone and format) There are other beneftis eg. format can
-   now be used without specifying time zone as well.
+ * Added options 'cwstyle', 'cwvolume' controlling callwaiting appearance
 
-Parking
-------------
- * New per parking lot options: comebackcontext and comebackdialtime. See
-   configs/features.conf.sample for more details.
+ * Added global 'debug' option, that enables debug in channel driver
 
- * Channel variable PARKER is now set when comebacktoorigin is disabled in
-   a parking lot.
+ * Added ability to translate on-screen menu in multiple languages. Tested on
+   Russian languages.  Supported encodings: ISO 8859-1, ISO 8859-2, ISO 8859-4,
+   ISO 8859-5, ISO 2022-JP. Language controlled by 'language' and on-screen
+   menu of phone
 
- * MixMonitor hooks now have IDs associated with them which can be used to assign
-   a target to StopMixMonitor. Use of MixMonitor's i(variable) option will allow
-   storage of the MixMontior ID in a channel variable.  StopMixmonitor now accepts
-   that ID as an argument.
+ * In addition to English added French and Russian languages for on-screen menus
+
+ * Reworked dialing number input: added dialing by timeout, immediate dial on
+   on dialplan compare, phone number length now not limited by screen size
+
+ * Added ability to pickup a call using features.conf defined value and
+   on-screen key
+
+
+chan_mISDN:
+------------------
+ * Add options namedcallgroup and namedpickupgroup to support installations
+   where a higher number of groups (>64) is required.
+
+ * Added support to use private party ID information with calls.
+
+
+Core
+------------------
+ * The minimum DTMF duration can now be configured in asterisk.conf
+   as "mindtmfduration". The default value is (as before) set to 80 ms.
+   (previously it was only available in source code)
+
+ * Named ACLs can now be specified in acl.conf and used in configurations that
+   use ACLs. As a general rule, if some derivative of 'permit' or 'deny' is
+   used to specify an ACL, a similar form of 'acl' will add a named ACL to the
+   working ACL. In addition, some CLI commands have been added to provide
+   show information and allow for module reloading - see CLI Changes.
+
+ * Rules in ACLs (specified using 'permit' and 'deny') can now contain multiple
+   items (separated by commas), and items in the rule can be negated by prefixing
+   them with '!'. This simplifies Asterisk Realtime configurations, since it is no
+   longer necessray to control the order that the 'permit' and 'deny' columns are
+   returned from queries.
+
+ * DUNDi now allows the built in variables ${NUMBER}, ${IPADDR} and ${SECRET} to
+   be used within the dynamic weight attribute when specifying a mapping.
+
+ * CEL backends can now be configured to show "USER_DEFINED" in the EventName
+   header, instead of putting the user defined event name there.  When enabled
+   the UserDefType header is added for user defined events.  This feature is
+   enabled with the setting show_user_defined.
+
+ * Macro has been deprecated in favor of GoSub.  For redirecting and connected
+   line purposes use the following variables instead of their macro equivalents:
+   REDIRECTING_SEND_SUB, REDIRECTING_SEND_SUB_ARGS, CONNECTED_LINE_SEND_SUB,
+   CONNECTED_LINE_SEND_SUB_ARGS.  For CCSS, use cc_callback_sub instead of
+   cc_callback_macro in channel configurations.
+
+ * Asterisk can now use a system-provided NetBSD editline library (libedit) if it
+   is available.
+
+ * Call files now support the "early_media" option to connect with an outgoing
+   extension when early media is received.
+
+ * Added support to use private party ID information with calls.
+
+
+AGI
+------------------
+ * A new channel variable, AGIEXITONHANGUP, has been added which allows
+   Asterisk to behave like it did in Asterisk 1.4 and earlier where the
+   AGI application would exit immediately after a channel hangup is detected.
+
+ * IPv6 addresses are now supported when using FastAGI (agi://).  Hostnames
+   are resolved and each address is attempted in turn until one succeeds or
+   all fail.
+
+
+AMI (Asterisk Manager Interface)
+------------------
+ * The originate action now has an option "EarlyMedia" that enables the
+   call to bridge when we get early media in the call. Previously,
+   early media was disregarded always when originating calls using AMI.
+
+ * Added setvar= option to manager accounts (much like sip.conf)
+
+ * Originate now generates an error response if the extension given is not found
+   in the dialplan
+
+ * MixMonitor will now show IDs associated with the mixmonitor upon creating
+   them if the i(variable) option is used. StopMixMonitor will accept
+   MixMonitorID as an option to close specific MixMonitors.
+
+ * The SIPshowpeer manager action response field "SIP-Forcerport" has been
+   updated to include information about peers configured with
+   nat=auto_force_rport by returning "A" if auto_force_rport is set and nat is
+   detected, and "a" if it is set and nat is not detected. "Y" and "N" are still
+   returned if auto_force_rport is not enabled.
+
+ * Added SIPpeerstatus manager command which will generate PeerStatus events
+   similar to the existing PeerStatus events found in chan_sip on demand.
+
+ * Hangup now can take a regular expression as the Channel option.  If you want
+   to hangup multiple channels, use /regex/ as the Channel option.  Existing
+   behavior to hanging up a single channel is unchanged, but if you pass a regex,
+   the manager will send you a list of channels back that were hung up.
+
+ * Support for IPv6 addresses has been added.
+
+ * AMI Events can now be documented in the Asterisk source. Note that AMI event
+   documentation is only generated when Asterisk is compiled using 'make full'.
+   See the CLI section for commands to display AMI event information.
+
+ * The AMI Hangup event now includes the AccountCode header so you can easily
+   correlate with AMI Newchannel events.
+
+ * The QueueMemberStatus, QueueMemberAdded, and QueueMember events now include
+   the StateInterface of the queue member.
+
+ * Added AMI event SessionTimeout in the Call category that is issued when a
+   call is terminated due to either RTP stream inactivity or SIP session timer
+   expiration.
+
+ * CEL events can now contain a user defined header UserDefType.  See core
+   changes for more information.
+
+ * OOH323 ChannelUpdate events now contain a CallRef header.
+
+ * Added PresenceState command.  This command will report the presence state for
+   the given presence provider.
+
+ * Added Parkinglots command.  This will list all parking lots as a series of
+   AMI Parkinglot events.
+
+ * Added MessageSend command.  This behaves in the same manner as the
+   MessageSend application, and is a technolgoy agnostic mechanism to send out
+   of call text messages.
+
+ * Added "message" class authorization.  This grants an account permission to
+   send out of call messages.  Write-only.
+
+
+CLI
+-------------------
+ * The "dialplan add include" command has been modified to create context a context
+   if one does not already exist. For instance, "dialplan add include foo into bar"
+   will create context "bar" if it does not already exist.
+
+ * A  "dialplan remove context" command has been added to remove a context from
+   the dialplan
+
+ * The "mixmonitor list <channel>" command will now show MixMonitor ID, and the
+   filenames of all running mixmonitors on a channel.
+
+ * The debug level of "pri set debug" is now a bitmask ranging from 0 to 15 if
+   numeric instead of 0, 1, or 2.
+
+ * "stun show status" will show a table describing how the STUN client is
+   behaving.
+
+ * "acl show [named acl]" will show information regarding a Named ACL.  The
+   acl module can be reloaded with "reload acl".
+
+ * Added CLI command to display AMI event information - "manager show events",
+   which shows a list of all known and documented AMI events, and "manager show
+   event [event name]", which shows detail information about a specific AMI
+   event.
+
+ * The result of the CLI command "queue show" now includes the state interface
+   information of the queue member.
+
+ * The command "core set verbose" will now set a separate level of logging for
+   each remote console without affecting any other console.
 
-CDR postgresql driver changes
------------------------------
  * Added command "cdr show pgsql status" to check connection status
 
-AMI (Asterisk Manager Interface) changes
-----------------------------------------
- * Originate now generates an error response if the extension given
-   is not found in the dialplan
+ * "sip show channel" will now display the complete route set.
 
- * MixMonitor will now show IDs associated with the mixmonitor upon creating them
-   if the i(variable) option is used. StopMixMonitor will accept MixMonitorID as
-   on option to close specific MixMonitors.
+ * Added "presencestate list" command.  This command will list all custom
+   presence states that have been set by using the PRESENCE_STATE dialplan
+   function.
 
- * The SIPshowpeer manager action response field "SIP-Forcerport" has been updated
-   to include information about peers configured with nat=auto_force_rport by
-   returning "A" if auto_force_rport is set and nat is detected, and "a" if it is
-   set and nat is not detected. "Y" and "N" are still returned if auto_force_rport
-   is not enabled.
+ * Added "presencestate change <entity> <state>[,<subtype>[,message[,options]]]"
+   command.  This changes a custom presence to a new state.
 
-FAX changes
------------
- * FAXOPT(faxdetect) will enable a generic fax detect framehook for dialplan
-   control of faxdetect.
+
+Codecs
+-------------------
+ * Codec lists may now be modified by the '!' character, to allow succinct
+   specification of a list of codecs allowed and disallowed, without the
+   requirement to use two different keywords.  For example, to specify all
+   codecs except g729 and g723, one need only specify allow=all,!g729,!g723.
+
+ * Add support for parsing SDP attributes, generating SDP attributes, and
+   passing it through. This support includes codecs such as H.263, H.264, SILK,
+   and CELT. You are able to set up a call and have attribute information pass.
+   This should help considerably with video calls.
+
+ * The iLBC codec can now use a system-provided iLBC library if one is installed,
+   just like the GSM codec.
 
 DUNDi changes
 -------------
- * Allow the built in variables ${NUMBER}, ${IPADDR} and ${SECRET} to be
-   used within the dynamic weight attribute when specifying a mapping.
+ * Added CLI commands dundi show hints and dundi show cache which will list DUNDi
+   'DONTASK' hints in the cache and list all DUNDi cache entires respectively.
+
+Logging
+-------------------
+ * Asterisk version and build information is now logged at the beginning of a
+   log file.
+
+ * Threads belonging to a particular call are now linked with callids which get
+   added to any log messages produced by those threads. Log messages can now be
+   easily identified as involved with a certain call by looking at their call id.
+   Call ids may also be attached to log messages for just about any case where
+   it can be determined to be related to a particular call.
 
-Core changes
-------------
  * Each logging destination and console now have an independent notion of the
    current verbosity level.  Logger.conf now allows an optional argument to
    the 'verbose' specifier, indicating the level of verbosity sent to that
@@ -159,23 +742,50 @@ Core changes
    a separate level for each remote console without affecting any other
    console.
 
-Dialplan functions
-------------------
- * Addition of the VM_INFO function that can be used to retrieve voicemail
-   user information, such as the email address and full name.
-   The MAILBOX_EXISTS dialplan function has been deprecated in favour of
-   VM_INFO.
 
-Followme changes
--------------
- * A new option, 'I' has been added to app_followme.
-   By setting this option, Asterisk will not update the caller with
-   connected line changes when they occur.  This is similar to app_dial
-   and app_queue.
- * The 'N' option is now ignored if the call is already answered.
+Music On Hold
+-------------------
+ * Added 'announcement' option which will play at the start of MOH and between
+   songs in modes of MOH that can detect transitions between songs (eg.
+   files, mp3, etc).
 
-RTP changes
--------------
+
+Parking
+-------------------
+ * New per parking lot options: comebackcontext and comebackdialtime. See
+   configs/features.conf.sample for more details.
+
+ * Channel variable PARKER is now set when comebacktoorigin is disabled in
+   a parking lot.
+
+ * Channel variable PARKEDCALL is now set with the name of the parking lot
+   when a timeout occurs.
+
+
+CDRs
+-------------------
+
+CDR Postgresql Driver
+-------------------
+ * Added command "cdr show pgsql status" to check connection status
+
+
+CDR Adaptive ODBC Driver
+-------------------
+ * Added schema option for databases that support specifying a schema.
+
+
+Resource Modules
+-------------------
+
+Calendars
+-------------------
+ * A CALENDAR_SUCCESS=1/0 channel variable is now set to show whether or not
+   CALENDAR_WRITE has completed successfully.
+
+
+res_rtp_asterisk
+-------------------
  * A new option, 'probation' has been added to rtp.conf
    RTP in strictrtp mode can now require more than 1 packet to exit learning
    mode with a new source (and by default requires 4). The probation option
@@ -185,14 +795,13 @@ RTP changes
    mode has successfully exited. These changes are based on how pjmedia handles
    media sources and source changes.
 
-Text Messaging
---------------
- * MESSAGE(from) for incoming SIP messages now returns "display-name" <uri>
-   instead of simply the uri.  This is the format that MessageSend() can use
-   in the from parameter for outgoing SIP messages.
+ * Add support for ICE/STUN/TURN in res_rtp_asterisk.  This option can be
+   enabled or disabled using the icesupport setting.  A variety of other
+   settings have been introduced to configure STUN/TURN connections.
+
 
 res_corosync
-------------
+-------------------
  * A new module, res_corosync, has been introduced.  This module uses the
    Corosync cluster enginer (http://www.corosync.org) to allow a local cluster
    of Asterisk servers to both Message Waiting Indication (MWI) and/or
@@ -200,11 +809,25 @@ res_corosync
    is a replacement for the res_ais module that was in previous releases of
    Asterisk.
 
-AGI
----
- * A new channel variable, AGIEXITONHANGUP, has been added which allows
-   Asterisk to behave like it did in Asterisk 1.4 and earlier where the
-   AGI application would exit immediately after a channel hangup is detected.
+
+res_xmpp
+-------------------
+ * This module adds a cleaned up, drop-in replacement for res_jabber called
+   res_xmpp. This provides the same externally facing functionality but is
+   implemented differently internally.  res_jabber has been deprecated in favor
+   of res_xmpp; please see the UPGRADE.txt file for more information.
+
+
+Scripts
+-------------------
+ * The safe_asterisk script has been updated to allow several of its parameters
+   to be set from environment variables.  This also enables a custom run
+   directory of Asterisk to be specified, instead of defaulting to /tmp.
+
+ * The live_ast script will now look for the LIVE_AST_BASE_DIR variable and use
+   its value to determine the directory to assume is the top-level directory of
+   the source tree.  If the variable is not set, it defaults to the current
+   behavior and uses the current working directory.
 
 ------------------------------------------------------------------------------
 --- Functionality changes from Asterisk 1.8 to Asterisk 10 -------------------
@@ -300,7 +923,7 @@ ConfBridge
    mixing audio at sample rates ranging from 8khz-96khz.
  * CONFBRIDGE dialplan function capable of creating dynamic ConfBridge user
    and bridge profiles on a channel.
- * CONFBRIDGE_INFO dialplan function capable of retrieving information 
+ * CONFBRIDGE_INFO dialplan function capable of retrieving information
    about a conference such as locked status and number of parties, admins,
    and marked users.
  * Addition of video_mode option in confbridge.conf for adding video support
@@ -348,7 +971,7 @@ Calendaring
 
 MixMonitor
 --------------------------
- * Added two new options, r and t with file name arguments to record 
+ * Added two new options, r and t with file name arguments to record
    single direction (unmixed) audio recording separate from the bidirectional
    (mixed) recording.  The mixed file name argument is optional now as long
    as at least one recording option is used.
@@ -410,8 +1033,6 @@ Queue changes
  * Added member option ignorebusy this when set and ringinuse is not
    will allow per member control of multiple calls as ringinuse does for
    the Queue.
- * Added global option check_state_unknown to enforce checking of device state
-   when the device state is unknown app_queue will see unknown as available.
 
 Applications
 ------------
@@ -612,7 +1233,7 @@ Applications
  * Added 'y' option to app_record. This option enables a mode where any DTMF digit
    received will terminate recording.
  * Voicemail now supports per mailbox settings for folders when using IMAP storage.
-   Previously the folder could only be set per context, but has now been extended 
+   Previously the folder could only be set per context, but has now been extended
    using the imapfolder option.
  * Voicemail now supports per mailbox settings for nextaftercmd and minsecs.
  * Voicemail now allows the pager date format to be specified separately from the
@@ -644,7 +1265,9 @@ Applications
  * Voicemail now runs the externnotify script when pollmailboxes is activated and
    notices a change.
  * Voicemail now includes rdnis within msgXXXX.txt file.
- * Added 'D' command to ExternalIVR full details in doc/externalivr.txt
+ * ExternalIVR now supports IPv6 addresses.
+ * Added 'D' command to ExternalIVR. Details are available on the Asterisk wiki
+   at https://wiki.asterisk.org/wiki/x/oQBB
  * ParkedCall and Park can now specify the parking lot to use.
 
 Dialplan Functions
@@ -861,7 +1484,7 @@ libpri channel driver (chan_dahdi) DAHDI changes
    to eliminate tromboned calls.  A tromboned call goes out an interface and comes
    back into the same interface.  Tromboned calls happen because of call routing,
    call deflection, call forwarding, and call transfer.
- * Added the ability to send and receive ETSI Advice-Of-Charge messages. 
+ * Added the ability to send and receive ETSI Advice-Of-Charge messages.
  * Added the ability to support call waiting calls.  (The SETUP has no B channel
    assigned.)
  * Added Malicious Call ID (MCID) event to the AMI call event class.
@@ -885,7 +1508,7 @@ Asterisk Manager Interface
  * The configuration file manager.conf now supports a channelvars option, which
    specifies a list of channel variables to include in each channel-oriented
    event.
- * The redirect command now has new parameters ExtraContext, ExtraExtension, 
+ * The redirect command now has new parameters ExtraContext, ExtraExtension,
    and ExtraPriority to allow redirecting the second channel to a different
    location than the first.
  * Added new event "JabberStatus" in the Jabber module to monitor buddies
@@ -945,7 +1568,7 @@ Call Completion Supplementary Services for Asterisk
  * Call completion support has been added for SIP, DAHDI/ISDN, and DAHDI/analog.
    DAHDI/ISDN supports call completion for the following switch types:
    EuroIsdn(ETSI) for PTP and PTMP modes, and Qsig.
-   See doc/CCSS_architecture.pdf and doc/tex/ccss.tex(asterisk.pdf) for details.
+   See https://wiki.asterisk.org/wiki/x/2ABQ for details.
 
 Multicast RTP Support
 ---------------------
@@ -963,7 +1586,10 @@ Security Events Framework
    sends these events to the "security" logger level.  Currently, AMI is the only
    Asterisk component that reports security events.  However, SIP support will be
    coming soon.  For more information on the security events framework, see the
-   "Security Events" chapter of the included documentation - doc/tex/asterisk.pdf.
+   "Asterisk Security Framework" section of the Asterisk wiki at
+   https://wiki.asterisk.org/wiki/x/wgBQ
+ * SIP support was added in Asterisk 10
+ * This API now supports IPv6 addresses
 
 Fax
 ---
@@ -991,7 +1617,7 @@ Miscellaneous
    of unit tests with the purpose of verifying the operation of C functions.
  * SendText is now implemented in chan_gtalk and chan_jingle. It will simply send
    XMPP text messages to the remote JID.
- * Modules.conf has a new option - "require" - that marks a module as critical for 
+ * Modules.conf has a new option - "require" - that marks a module as critical for
    the execution of Asterisk.
    If one of the required modules fail to load, Asterisk will exit with a return
    code set to 2.
@@ -1014,7 +1640,8 @@ Miscellaneous
  * The Realtime dialplan switch now caches entries for 1 second.  This provides a
    significant increase in performance (about 3X) for installations using this switchtype.
  * Distributed devicestate now supports the use of the XMPP protocol, in addition to
-   AIS.  For more information, please see doc/distributed_devstate-XMPP.txt
+   AIS.  For more information, please see the Distributed Device State section of the
+   Asterisk wiki at https://wiki.asterisk.org/wiki/x/jw4iAQ
  * The addition of G.719 pass-through support.
  * Added support for 16khz Speex audio.  This can be enabled by using 'allow=speex16'
    during device configuration.
@@ -1025,6 +1652,9 @@ Miscellaneous
    rate changes during translation are now avoided unless absolutely necessary.
  * The addition of the res_stun_monitor module for monitoring and reacting to network
    changes while behind a NAT.
+ * DTMF: Normal and Reverse Twist acceptance values can be set in dsp.conf.
+   DTMF Valid/Invalid number of hits/misses can be set in dsp.conf.
+   These allow support for any Administration. Default is AT&T values.
 
 CLI Changes
 -----------
@@ -1037,7 +1667,7 @@ CLI Changes
    which applies the setting to the entire module specified, regardless of which source
    files it was built from.
  * New 'manager show settings' command showing the current settings loaded from
-   manager.conf. 
+   manager.conf.
  * Added 'all' keyword to the CLI command "channel request hangup" so that you can send
    the channel hangup request to all channels.
  * Added a "core reload" CLI command that executes a global reload of Asterisk.
@@ -1057,7 +1687,7 @@ SIP Changes
    remote services. For backwards compatibility, "secret" still has the
    same function as before, but now you can configure both a remote secret and a
    local secret for mutual authentication.
- * If the channel variable  ATTENDED_TRANSFER_COMPLETE_SOUND is set, 
+ * If the channel variable  ATTENDED_TRANSFER_COMPLETE_SOUND is set,
    the sound will be played to the target of an attended transfer
  * Added two new configuration options, "qualifygap" and "qualifypeers", which allow
    finer control over how many peers Asterisk will qualify and the gap between them
@@ -1077,7 +1707,7 @@ SIP Changes
    as a mailbox. Please see the sip.conf.sample file for more information.
  * Added a function to remove SIP headers added in the dialplan before the
    first INVITE is generated - SIPRemoveHeader()
- * Channel variables set with setvar= in a device configuration is now 
+ * Channel variables set with setvar= in a device configuration is now
    set both for inbound and outbound calls.
  * Added support for ITU G.722.1 and G.722.1C (Siren7 and Siren14) media streams.
 
@@ -1233,7 +1863,7 @@ LDAP Schema File Additions
    - Gives more configuration Flags for SIP-Users available (tested)
    - Allows to create Asterisk Attributes in defined Asterisk ObjectClasses
      without extensibleObject (which really should be the last resort); gives
-     also additional possibilities for LDAP-filter 
+     also additional possibilities for LDAP-filter
 
 ------------------------------------------------------------------------------
 --- Functionality changes from Asterisk 1.6.0 to Asterisk 1.6.1  -------------
@@ -1242,21 +1872,22 @@ LDAP Schema File Additions
 Device State Handling
 ---------------------
  * The event infrastructure in Asterisk got another big update to help support
-    distributed events.  It currently supports distributed device state and
-    distributed Voicemail MWI (Message Waiting Indication).  A new module has
-    been merged, res_ais, which facilitates communicating events between servers.
-    It uses the SAForum AIS (Service Availability Forum Application Interface
-    Specification) CLM (Cluster Management) and EVT (Event) services to maintain
-    a cluster of Asterisk servers, and to share events between them.  For more
-    information on setting this up, see doc/distributed_devstate.txt.
+   distributed events.  It currently supports distributed device state and
+   distributed Voicemail MWI (Message Waiting Indication).  A new module has
+   been merged, res_ais, which facilitates communicating events between servers.
+   It uses the SAForum AIS (Service Availability Forum Application Interface
+   Specification) CLM (Cluster Management) and EVT (Event) services to maintain
+   a cluster of Asterisk servers, and to share events between them.  For more
+   information on setting this up, refer to the Distributed Device State section
+   of the Asterisk wiki at https://wiki.asterisk.org/wiki/x/jw4iAQ
 
 Dialplan Functions
 ------------------
  * Added a new dialplan function, AST_CONFIG(), which allows you to access
    variables from an Asterisk configuration file.
  * The JACK_HOOK function now has a c() option to supply a custom client name.
- * Added two new dialplan functions from libspeex for audio gain control and 
-   denoise, AGC() and DENOISE(). Both functions can be applied to the tx and 
+ * Added two new dialplan functions from libspeex for audio gain control and
+   denoise, AGC() and DENOISE(). Both functions can be applied to the tx and
    rx directions of a channel from the dialplan.
  * The SMDI_MSG_RETRIEVE function now has the ability to search for SMDI messages
    based on other parameters.  The default is still to search based on the
@@ -1315,7 +1946,7 @@ Application Changes
    participant on the bridged channel as well.
  * Chanspy has a new option, 'n', which will allow for the spied-on party's name
    to be spoken instead of the channel name or number. For more information on the
-   use of this option, issue the command "core show application ChanSpy" from the 
+   use of this option, issue the command "core show application ChanSpy" from the
    Asterisk CLI.
  * Chanspy has a new option, 'd', which allows the spy to use DTMF to swap between
    spy modes. Use of this feature overrides the typical use of numeric DTMF. In other
@@ -1323,13 +1954,13 @@ Application Changes
    the first argument to Chanspy(). Pressing 4 will change to spy mode, pressing 5 will
    change to whisper mode, and pressing 6 will change to barge mode.
  * ExternalIVR now takes several options that affect the way it performs, as
-   well as having several new commands.  Please see doc/externalivr.txt for the
-   complete documentation.
- * Added ability to communicate over a TCP socket instead of forking a child process for the 
+   well as having several new commands.  Please see the External IVR page on the Asterisk
+   wiki for complete documentation: https://wiki.asterisk.org/wiki/x/oQBB
+ * Added ability to communicate over a TCP socket instead of forking a child process for the
    ExternalIVR application.
  * ChanIsAvail has a new option, 'a', which will return all available channels instead
    of just the first one if you give the function more then one channel to check.
- * PrivacyManager now takes an option where you can specify a context where the 
+ * PrivacyManager now takes an option where you can specify a context where the
    given number will be matched. This way you have more control over who is allowed
    and it stops the people who blindly enter 10 digits.
  * ForkCDR has new options: 'a' updates the answer time on the new CDR; 'A' locks
@@ -1352,10 +1983,10 @@ Application Changes
 SIP Changes
 -----------
  * Added DNS manager support to registrations for peers referencing peer entries.
-   DNS manager runs in the background which allows DNS lookups to be run asynchronously 
+   DNS manager runs in the background which allows DNS lookups to be run asynchronously
    as well as periodically updating the IP address. These properties allow for
    better performance as well as recovery in the event of an IP change.
- * Performance improvements via using hash tables (astobj2) and doubly-linked lists to improve 
+ * Performance improvements via using hash tables (astobj2) and doubly-linked lists to improve
    load/reload of large numbers of peers/users by ~40x (for large lists of peers).
    These changes also provide performance improvements for call setup and tear down.
  * Added ability to specify registration expiry time on a per registration basis in
@@ -1365,8 +1996,8 @@ SIP Changes
  * Added t38pt_usertpsource option. See sip.conf.sample for details.
  * Added SIPnotify AMI command, for sending arbitrary SIP notify commands.
  * 'sip show peers' and 'sip show users' display their entries sorted in
-    alphabetical order, as opposed to the order they were in, in the config 
-    file or database. 
+    alphabetical order, as opposed to the order they were in, in the config
+    file or database.
  * Videosupport now supports an additional option, "always", which always sets
     up video RTP ports, even on clients that don't support it.  This helps with
     callfiles and certain transfers to ensure that if two video phones are
@@ -1443,17 +2074,18 @@ Miscellaneous
     the 'setvar' option to cause a given audio file to be played upon completion
     of an attended transfer.  Currently it works for DAHDI, IAX2, SIP, and
     Skinny channels only.
-  * You can now compile Asterisk against the Hoard Memory Allocator, see doc/hoard.txt
-    for more information.
+  * You can now compile Asterisk against the Hoard Memory Allocator, see the
+    Hoard page on the Asterisk wiki for more information:
+    https://wiki.asterisk.org/wiki/x/pQBB
   * Config file variables may now be appended to, by using the '+=' append
     operator.  This is most helpful when working with long SQL queries in
     func_odbc.conf, as the queries no longer need to be specified on a single
     line.
-  * CDR config file, cdr.conf, has an added option, "initiatedseconds", 
+  * CDR config file, cdr.conf, has an added option, "initiatedseconds",
     which will add a second to the billsec when the ending
-    time is set, if the number in the microseconds field of the end time is 
+    time is set, if the number in the microseconds field of the end time is
     greater than the number of microseconds in the answer time. This allows
-    users to count the 'initiated' seconds in their billing records. 
+    users to count the 'initiated' seconds in their billing records.
 
 ------------------------------------------------------------------------------
 --- Functionality changes from Asterisk 1.4.X to Asterisk 1.6.0  -------------
@@ -1462,10 +2094,10 @@ Miscellaneous
 AMI - The manager (TCP/TLS/HTTP)
 --------------------------------
   * Manager has undergone a lot of changes, all of them documented
-    in doc/manager_1_1.txt
+    on the Asterisk wiki at https://wiki.asterisk.org/wiki/x/tQBB
   * Manager version has changed to 1.1
   * Added a new action 'CoreShowChannels' to list currently defined channels
-     and some information about them. 
+     and some information about them.
   * Added a new action 'SIPshowregistry' to list SIP registrations.
   * Added TLS support for the manager interface and HTTP server
   * Added the URI redirect option for the built-in HTTP server
@@ -1477,7 +2109,7 @@ AMI - The manager (TCP/TLS/HTTP)
      Asterisk configuration file in JSON format.  This is intended to help
      improve the performance of AJAX applications using the manager interface
      over HTTP.
-  * SIP and IAX manager events now use "ChannelType" in all cases where we 
+  * SIP and IAX manager events now use "ChannelType" in all cases where we
      indicate channel driver. Previously, we used a mixture of "Channel"
      and "ChannelDriver" headers.
   * Added a "Bridge" action which allows you to bridge any two channels that
@@ -1508,11 +2140,11 @@ AMI - The manager (TCP/TLS/HTTP)
   * Originate now requires the Originate privilege and, if you want to call out
     to a subshell, it requires the System privilege, as well.  This was done to
     enhance manager security.
-  * Originate now accepts codec settings with "Codecs: alaw, ulaw, h264" 
-  * New command: Atxfer. See doc/manager_1_1.txt for more details or 
-    manager show command Atxfer from the CLI
-  * New command: IAXregistry. See doc/manager_1_1.txt for more details or
-    manager show command IAXregistry from the CLI
+  * Originate now accepts codec settings with "Codecs: alaw, ulaw, h264"
+  * New command: Atxfer. See https://wiki.asterisk.org/wiki/x/uABB for more details
+    or manager show command Atxfer from the CLI
+  * New command: IAXregistry. See https://wiki.asterisk.org/wiki/x/uABB for more
+    details or manager show command IAXregistry from the CLI
 
 Dialplan functions
 ------------------
@@ -1530,7 +2162,7 @@ Dialplan functions
      held for any given channel.  Also, locks are automatically freed when a
      channel is hung up.
   * Added HINT() dialplan function that allows retrieving hint information.
-     Hints are mappings between extensions and devices for the sake of 
+     Hints are mappings between extensions and devices for the sake of
      determining the state of an extension.  This function can retrieve the list
      of devices or the name associated with a hint.
   * Added EXTENSION_STATE() dialplan function which allows retrieving the state
@@ -1580,7 +2212,7 @@ SIP changes
 -----------
  * Added a new 'faxdetect=yes|no' configuration option to sip.conf.  When this
     option is enabled, Asterisk will watch for a CNG tone in the incoming audio
-    for a received call.  If it is detected, the channel will jump to the 
+    for a received call.  If it is detected, the channel will jump to the
     'fax' extension in the dialplan.
   * The default SIP useragent= identifier now includes the Asterisk version
   * A new option, match_auth_username in sip.conf changes the matching of incoming requests.
@@ -1601,8 +2233,8 @@ SIP changes
   * The SIPPEER function have new options for port address, call and pickup groups
   * Added support for T.140 realtime text in SIP/RTP
   * The "checkmwi" option has been removed from sip.conf, as it is no longer
-     required due to the restructuring of how MWI is handled.  See the descriptions 
-     in this file of the "pollmailboxes" and "pollfreq" options to voicemail.conf 
+     required due to the restructuring of how MWI is handled.  See the descriptions
+     in this file of the "pollmailboxes" and "pollfreq" options to voicemail.conf
      for more information.
   * Added rtpdest option to CHANNEL() dialplan function.
   * Added SIPREFERRINGCONTEXT and SIPREFERREDBYHDR variables which are set when a transfer takes place.
@@ -1610,11 +2242,11 @@ SIP changes
      in the same dial command, or if the new c option in dial() is used.
   * The new default is that 100 Trying is not sent on REGISTER attempts as the RFC specifically
      states it is not needed. For phones, however, that do require it the "registertrying" option
-     has been added so it can be enabled. 
+     has been added so it can be enabled.
   * A new option called "callcounter" (global/peer/user level) enables call counters needed
      for better status reports needed for queues and SIP subscriptions. (Call-Limit was previously
      used to enable this functionality).
-  * New settings for timer T1 and timer B on a global level or per device. This makes it 
+  * New settings for timer T1 and timer B on a global level or per device. This makes it
      possible to force timeout faster on non-responsive SIP servers. These settings are
      considered advanced, so don't use them unless you have a problem.
   * Added a dial string option to be able to set the To: header in an INVITE to any
@@ -1624,10 +2256,10 @@ SIP changes
   * Added SIP Session Timers support (RFC 4028).  This prevents stuck SIP sessions that
      were not properly torn down due to network or endpoint failures during an established
      SIP session.
-  * Added experimental TCP and TLS support for SIP.  See doc/siptls.txt and 
-     configs/sip.conf.sample for more information on how it is used.
+  * Added experimental TCP and TLS support for SIP.  See https://wiki.asterisk.org/wiki/x/ygBB
+     and configs/sip.conf.sample for more information on how it is used.
   * Added a new configuration option "authfailureevents" that enables manager events when
-    a peer can't authenticate properly. 
+    a peer can't authenticate properly.
   * Added DNS manager support to registrations for peers not referencing a peer entry.
 
 IAX2 changes
@@ -1715,15 +2347,16 @@ DAHDI channel driver (chan_dahdi) Changes
 
 New Channel Drivers
 -------------------
-  * Added a new channel driver, chan_unistim.  See doc/unistim.txt and
-     configs/unistim.conf.sample for details.  This new channel driver allows
-     you to use Nortel i2002, i2004, and i2050 phones with Asterisk.
+  * Added a new channel driver, chan_unistim.  See the Asterisk wiki at
+     https://wiki.asterisk.org/wiki/x/vgsiAQ and configs/unistim.conf.sample
+     for details.  This new channel driver allows you to use Nortel i2002,
+     i2004, and i2050 phones with Asterisk.
   * Added a new channel driver, chan_console, which uses portaudio as a cross
      platform audio interface.  It was written as a channel driver that would
      work with Mac CoreAudio, but portaudio supports a number of other audio
      interfaces, as well. Note that this channel driver requires v19 or higher
      of portaudio; older versions have a different API.
+
 DUNDi changes
 -------------
   * Added the ability to specify arguments to the Dial application when using
@@ -1790,15 +2423,15 @@ Queue changes
 -------------
   * Added the general option 'shared_lastcall' so that member's wrapuptime may be
      used across multiple queues.
-  * Added QUEUE_VARIABLES function to set queue variables added setqueuevar and 
+  * Added QUEUE_VARIABLES function to set queue variables added setqueuevar and
      setqueueentryvar options for each queue, see queues.conf.sample for details.
   * Added keepstats option to queues.conf which will keep queue
      statistics during a reload.
   * setinterfacevar option in queues.conf also now sets a variable
      called MEMBERNAME which contains the member's name.
   * Added 'Strategy' field to manager event QueueParams which represents
-     the queue strategy in use. 
-  * Added option to run macro when a queue member is connected to a caller, 
+     the queue strategy in use.
+  * Added option to run macro when a queue member is connected to a caller,
      see queues.conf.sample for details.
   * app_queue now has a 'loose' option which is almost exactly like 'strict' except it
      does not count paused queue members as unavailable.
@@ -1844,7 +2477,7 @@ Queue changes
 
 MeetMe Changes
 --------------
-  * The 'o' option to provide an optimization has been removed and its functionality 
+  * The 'o' option to provide an optimization has been removed and its functionality
      has been enabled by default.
   * When a conference is created, the UNIQUEID of the channel that caused it to be
      created is stored.  Then, every channel that joins the conference will have the
@@ -1872,7 +2505,7 @@ MeetMe Changes
      conference when there is only one member and the M option is used.
   * Added MEETME_INFO dialplan function which provides a way to query
      various properties of a Meetme conference.
-  * Added new admin features: *81: Roll call, *82: eject all, *83: mute all, 
+  * Added new admin features: *81: Roll call, *82: eject all, *83: mute all,
      and *84: record in-conf
 
 Other Dialplan Application Changes
@@ -1911,7 +2544,7 @@ Other Dialplan Application Changes
 
 Music On Hold Changes
 ---------------------
-  * A new option, "digit", has been added for music on hold classes in 
+  * A new option, "digit", has been added for music on hold classes in
      musiconhold.conf.  If this is set for a music on hold class, a caller
      listening to music on hold can press this digit to switch to listening
      to this music on hold class.
@@ -1924,7 +2557,7 @@ AEL Changes
 -----------
   * AEL upgraded to use the Gosub with Arguments instead
      of Macro application, to hopefully reduce the problems
-     seen with the artificially low stack ceiling that 
+     seen with the artificially low stack ceiling that
      Macro bumps into. Macros can only call other Macros
      to a depth of 7. Tests run using gosub, show depths
      limited only by virtual memory. A small test demonstrated
@@ -1940,17 +2573,17 @@ AEL Changes
      fashion:  Set(LOCAL(myvar)=someval);  ("local" is now
      an AEL keyword).
   * utils/conf2ael introduced. Will convert an extensions.conf
-     file into extensions.ael. Very crude and unfinished, but 
+     file into extensions.ael. Very crude and unfinished, but
      will be improved as time goes by. Should be useful for a
      first pass at conversion.
   * aelparse will now read extensions.conf to see if a referenced
      macro or context is there before issueing a warning.
-  * AEL parser sets a local channel variable ~~EXTEN~~, to 
+  * AEL parser sets a local channel variable ~~EXTEN~~, to
     preserve the value of ${EXTEN} thru switch statements.
   * New operator in $[...] expressions: the ~~ operator serves
     as a concatenation operator. AT THE MOMENT, it is really only
     necessary and useful in AEL, especially in if() expressions.
-    Operation: ${a} ~~ ${b|  with force both a and b to strings, strip 
+    Operation: ${a} ~~ ${b|  with force both a and b to strings, strip
     any enclosing double-quotes, and evaluate to the value of a
     concatenated with the value of b.  For example if a is set to
     "xyz"  and b has the value "abc", then ${a} ~~ ${b| would
@@ -2018,7 +2651,7 @@ Logger changes
      and to ensure that the oldest log file gets deleted.
   * Added realtime support for the queue log
 
-Call Detail Records 
+Call Detail Records
 -------------------
   * The cdr_manager module has a [mappings] feature, like cdr_custom,
     to add fields to the manager event from the CDR variables.
@@ -2079,7 +2712,7 @@ Miscellaneous New Modules
   * Added support for writing and running your dialplan in lua using the pbx_lua
      module.  See configs/extensions.lua.sample for examples of how to do this.
 
-Miscellaneous 
+Miscellaneous
 -------------
   * Ability to use libcap to set high ToS bits when non-root
      on Linux. If configure is unable to find libcap then you
@@ -2089,8 +2722,8 @@ Miscellaneous
   * Added the jittertargetextra configuration option.
   * Added support for setting the CoS for VLAN traffic (802.1p).  See the sample
      configuration files for the IP channel drivers.  The new option is "cos".
-     This information is also documented in doc/qos.tex, or the IP Quality of Service
-     section of asterisk.pdf.
+     This information is also documented on the Asterisk wiki at
+     https://wiki.asterisk.org/wiki/x/EYBG
   * When originating a call using AMI or pbx_spool that fails the reason for failure
      will now be available in the failed extension using the REASON dialplan variable.
   * Added support for reading the TOUCH_MONITOR_PREFIX channel variable.
@@ -2127,7 +2760,7 @@ Miscellaneous
      turned on, via the CHANNEL(trace) dialplan function.  Could be useful for
      dialplan debugging.
   * iLBC source code no longer included (see UPGRADE.txt for details)
-  * If compiled with DETECT_DEADLOCKS enabled and if you have glibc, then if 
+  * If compiled with DETECT_DEADLOCKS enabled and if you have glibc, then if
      deadlock is detected, a backtrace of the stack which led to the lock calls
      will be output to the CLI.
   * If compiled with DEBUG_THREADS enabled and if you have glibc, then issuing