1 =========================================================
2 === Information for upgrading from Asterisk 1.2 to 1.4
5 === UPGRADE-1.2.txt -- Upgrade info for 1.0 to 1.2
6 === UPGRADE-1.4.txt -- Upgrade info for 1.2 to 1.4
7 === UPGRADE.txt -- Upgrade info for 1.4 to 1.6
8 =========================================================
10 Build Process (configure script):
12 Asterisk now uses an autoconf-generated configuration script to learn how it
13 should build itself for your system. As it is a standard script, running:
17 will show you all the options available. This script can be used to tell the
18 build process what libraries you have on your system (if it cannot find them
19 automatically), which libraries you wish to have ignored even though they may
22 You must run the configure script before Asterisk will build, although it will
23 attempt to automatically run it for you with no options specified; for most
24 users, that will result in a similar build to what they would have had before
25 the configure script was added to the build process (except for having to run
26 'make' again after the configure script is run). Note that the configure script
27 does NOT need to be re-run just to rebuild Asterisk; you only need to re-run it
28 when your system configuration changes or you wish to build Asterisk with
31 Build Process (module selection):
33 The Asterisk source tree now includes a basic module selection and build option
34 selection tool called 'menuselect'. Run 'make menuselect' to make your choices.
35 In this tool, you can disable building of modules that you don't care about,
36 turn on/off global options for the build and see which modules will not
37 (and cannot) be built because your system does not have the required external
38 dependencies installed.
40 The resulting file from menuselect is called 'menuselect.makeopts'. Note that
41 the resulting menuselect.makeopts file generally contains which modules *not*
42 to build. The modules listed in this file indicate which modules have unmet
43 dependencies, a present conflict, or have been disabled by the user in the
44 menuselect interface. Compiler Flags can also be set in the menuselect
45 interface. In this case, the resulting file contains which CFLAGS are in use,
46 not which ones are not in use.
48 If you would like to save your choices and have them applied against all
49 builds, the file can be copied to '~/.asterisk.makeopts' or
50 '/etc/asterisk.makeopts'.
52 Build Process (Makefile targets):
54 The 'valgrind' and 'dont-optimize' targets have been removed; their functionality
55 is available by enabling the DONT_OPTIMIZE setting in the 'Compiler Flags' menu
56 in the menuselect tool.
58 It is now possible to run most make targets against a single subdirectory; from
59 the top level directory, for example, 'make channels' will run 'make all' in the
60 'channels' subdirectory. This also is true for 'clean', 'distclean' and 'depend'.
62 Sound (prompt) and Music On Hold files:
64 Beginning with Asterisk 1.4, the sound files and music on hold files supplied for
65 use with Asterisk have been replaced with new versions produced from high quality
66 master recordings, and are available in three languages (English, French and
67 Spanish) and in five formats (WAV (uncompressed), mu-Law, a-Law, GSM and G.729).
68 In addition, the music on hold files provided by FreePlay Music are now available
69 in the same five formats, but no longer available in MP3 format.
71 The Asterisk 1.4 tarball packages will only include English prompts in GSM format,
72 (as were supplied with previous releases) and the FreePlay MOH files in WAV format.
73 All of the other variations can be installed by running 'make menuselect' and
74 selecting the packages you wish to install; when you run 'make install', those
75 packages will be downloaded and installed along with the standard files included
78 If for some reason you expect to not have Internet access at the time you will be
79 running 'make install', you can make your package selections using menuselect and
80 then run 'make sounds' to download (only) the sound packages; this will leave the
81 sound packages in the 'sounds' subdirectory to be used later during installation.
83 WARNING: Asterisk 1.4 supports a new layout for sound files in multiple languages;
84 instead of the alternate-language files being stored in subdirectories underneath
85 the existing files (for French, that would be digits/fr, letters/fr, phonetic/fr,
86 etc.) the new layout creates one directory under /var/lib/asterisk/sounds for the
87 language itself, then places all the sound files for that language under that
88 directory and its subdirectories. This is the layout that will be created if you
89 select non-English languages to be installed via menuselect, HOWEVER Asterisk does
90 not default to this layout and will not find the files in the places it expects them
91 to be. If you wish to use this layout, make sure you put 'languageprefix=yes' in your
92 /etc/asterisk/asterisk.conf file, so that Asterisk will know how the files were
97 * The (very old and undocumented) ability to use BYEXTENSION for dialing
98 instead of ${EXTEN} has been removed.
100 * Builtin (res_features) transfer functionality attempts to use the context
101 defined in TRANSFER_CONTEXT variable of the transferer channel first. If
102 not set, it uses the transferee variable. If not set in any channel, it will
103 attempt to use the last non macro context. If not possible, it will default
104 to the current context.
106 * The autofallthrough setting introduced in Asterisk 1.2 now defaults to 'yes';
107 if your dialplan relies on the ability to 'run off the end' of an extension
108 and wait for a new extension without using WaitExten() to accomplish that,
109 you will need set autofallthrough to 'no' in your extensions.conf file.
111 Command Line Interface:
113 * 'show channels concise', designed to be used by applications that will parse
114 its output, previously used ':' characters to separate fields. However, some
115 of those fields can easily contain that character, making the output not
116 parseable. The delimiter has been changed to '!'.
120 * In previous Asterisk releases, many applications would jump to priority n+101
121 to indicate some kind of status or error condition. This functionality was
122 marked deprecated in Asterisk 1.2. An option to disable it was provided with
123 the default value set to 'on'. The default value for the global priority
124 jumping option is now 'off'.
126 * The applications Cut, Sort, DBGet, DBPut, SetCIDNum, SetCIDName, SetRDNIS,
127 AbsoluteTimeout, DigitTimeout, ResponseTimeout, SetLanguage, GetGroupCount,
128 and GetGroupMatchCount were all deprecated in version 1.2, and therefore have
129 been removed in this version. You should use the equivalent dialplan
130 function in places where you have previously used one of these applications.
132 * The application SetGlobalVar has been deprecated. You should replace uses
133 of this application with the following combination of Set and GLOBAL():
134 Set(GLOBAL(name)=value). You may also access global variables exclusively by
135 using the GLOBAL() dialplan function, instead of relying on variable
136 interpolation falling back to globals when no channel variable is set.
138 * The application SetVar has been renamed to Set. The syntax SetVar was marked
139 deprecated in version 1.2 and is no longer recognized in this version. The
140 use of Set with multiple argument pairs has also been deprecated. Please
141 separate each name/value pair into its own dialplan line.
143 * app_read has been updated to use the newer options codes, using "skip" or
144 "noanswer" will not work. Use s or n. Also there is a new feature i, for
145 using indication tones, so typing in skip would give you unexpected results.
147 * OSPAuth is added to authenticate OSP tokens in in_bound call setup messages.
149 * The CONNECT event in the queue_log from app_queue now has a second field
150 in addition to the holdtime field. It contains the unique ID of the
151 queue member channel that is taking the call. This is useful when trying
152 to link recording filenames back to a particular call from the queue.
154 * The old/current behavior of app_queue has a serial type behavior
155 in that the queue will make all waiting callers wait in the queue
156 even if there is more than one available member ready to take
157 calls until the head caller is connected with the member they
158 were trying to get to. The next waiting caller in line then
159 becomes the head caller, and they are then connected with the
160 next available member and all available members and waiting callers
161 waits while this happens. This cycle continues until there are
162 no more available members or waiting callers, whichever comes first.
163 The new behavior, enabled by setting autofill=yes in queues.conf
164 either at the [general] level to default for all queues or
165 to set on a per-queue level, makes sure that when the waiting
166 callers are connecting with available members in a parallel fashion
167 until there are no more available members or no more waiting callers,
168 whichever comes first. This is probably more along the lines of how
169 one would expect a queue should work and in most cases, you will want
170 to enable this new behavior. If you do not specify or comment out this
171 option, it will default to "no" to keep backward compatability with the old
174 * Queues depend on the channel driver reporting the proper state
175 for each member of the queue. To get proper signalling on
176 queue members that use the SIP channel driver, you need to
177 enable a call limit (could be set to a high value so it
178 is not put into action) and also make sure that both inbound
179 and outbound calls are accounted for.
191 * The app_queue application now has the ability to use MixMonitor to
192 record conversations queue members are having with queue callers. Please
193 see configs/queues.conf.sample for more information on this option.
195 * The app_queue application strategy called 'roundrobin' has been deprecated
196 for this release. Users are encouraged to use 'rrmemory' instead, since it
197 provides more 'true' round-robin call delivery. For the Asterisk 1.6 release,
198 'rrmemory' will be renamed 'roundrobin'.
200 * The app_queue application option called 'monitor-join' has been deprecated
201 for this release. Users are encouraged to use 'monitor-type=mixmonitor' instead,
202 since it provides the same functionality but is not dependent on soxmix or some
203 other external program in order to mix the audio.
205 * app_meetme: The 'm' option (monitor) is renamed to 'l' (listen only), and
206 the 'm' option now provides the functionality of "initially muted".
207 In practice, most existing dialplans using the 'm' flag should not notice
208 any difference, unless the keypad menu is enabled, allowing the user
209 to unmute themsleves.
211 * ast_play_and_record would attempt to cancel the recording if a DTMF
212 '0' was received. This behavior was not documented in most of the
213 applications that used ast_play_and_record and the return codes from
214 ast_play_and_record weren't checked for properly.
215 ast_play_and_record has been changed so that '0' no longer cancels a
216 recording. If you want to allow DTMF digits to cancel an
217 in-progress recording use ast_play_and_record_full which allows you
218 to specify which DTMF digits can be used to accept a recording and
219 which digits can be used to cancel a recording.
221 * ast_app_messagecount has been renamed to ast_app_inboxcount. There is now a
222 new ast_app_messagecount function which takes a single context/mailbox/folder
223 mailbox specification and returns the message count for that folder only.
224 This addresses the deficiency of not being able to count the number of
225 messages in folders other than INBOX and Old.
227 * The exit behavior of the AGI applications has changed. Previously, when
228 a connection to an AGI server failed, the application would cause the channel
229 to immediately stop dialplan execution and hangup. Now, the only time that
230 the AGI applications will cause the channel to stop dialplan execution is
231 when the channel itself requests hangup. The AGI applications now set an
232 AGISTATUS variable which will allow you to find out whether running the AGI
233 was successful or not.
235 Previously, there was no way to handle the case where Asterisk was unable to
236 locally execute an AGI script for some reason. In this case, dialplan
237 execution will continue as it did before, but the AGISTATUS variable will be
240 A locally executed AGI script can now exit with a non-zero exit code and this
241 failure will be detected by Asterisk. If an AGI script exits with a non-zero
242 exit code, the AGISTATUS variable will be set to "FAILURE" as opposed to
245 * app_voicemail: The ODBC_STORAGE capability now requires the extended table format
246 previously used only by EXTENDED_ODBC_STORAGE. This means that you will need to update
247 your table format using the schema provided in doc/odbcstorage.txt
249 * app_waitforsilence: Fixes have been made to this application which changes the
250 default behavior with how quickly it returns. You can maintain "old-style" behavior
251 with the addition/use of a third "timeout" parameter.
252 Please consult the application documentation and make changes to your dialplan
257 * After executing the 'status' manager action, the "Status" manager events
258 included the header "CallerID:" which was actually only the CallerID number,
259 and not the full CallerID string. This header has been renamed to
260 "CallerIDNum". For compatibility purposes, the CallerID parameter will remain
261 until after the release of 1.4, when it will be removed. Please use the time
262 during the 1.4 release to make this transition.
264 * The AgentConnect event now has an additional field called "BridgedChannel"
265 which contains the unique ID of the queue member channel that is taking the
266 call. This is useful when trying to link recording filenames back to
267 a particular call from the queue.
269 * app_userevent has been modified to always send Event: UserEvent with the
270 additional header UserEvent: <userspec>. Also, the Channel and UniqueID
271 headers are not automatically sent, unless you specify them as separate
272 arguments. Please see the application help for the new syntax.
274 * app_meetme: Mute and Unmute events are now reported via the Manager API.
275 Native Manager API commands MeetMeMute and MeetMeUnmute are provided, which
276 are easier to use than "Action Command:". The MeetMeStopTalking event has
277 also been deprecated in favor of the already existing MeetmeTalking event
278 with a "Status" of "on" or "off" added.
280 * OriginateFailure and OriginateSuccess events were replaced by event
281 OriginateResponse with a header named "Response" to indicate success or
286 * The builtin variables ${CALLERID}, ${CALLERIDNAME}, ${CALLERIDNUM},
287 ${CALLERANI}, ${DNID}, ${RDNIS}, ${DATETIME}, ${TIMESTAMP}, ${ACCOUNTCODE},
288 and ${LANGUAGE} have all been deprecated in favor of their related dialplan
289 functions. You are encouraged to move towards the associated dialplan
290 function, as these variables will be removed in a future release.
292 * The CDR-CSV variables uniqueid, userfield, and basing time on GMT are now
293 adjustable from cdr.conf, instead of recompiling.
295 * OSP applications exports several new variables, ${OSPINHANDLE},
296 ${OSPOUTHANDLE}, ${OSPINTOKEN}, ${OSPOUTTOKEN}, ${OSPCALLING},
297 ${OSPINTIMELIMIT}, and ${OSPOUTTIMELIMIT}
299 * Builtin transfer functionality sets the variable ${TRANSFERERNAME} in the new
300 created channel. This variables holds the channel name of the transferer.
302 * The dial plan variable PRI_CAUSE will be removed from future versions
304 It is replaced by adding a cause value to the hangup() application.
308 * The function ${CHECK_MD5()} has been deprecated in favor of using an
309 expression: $[${MD5(<string>)} = ${saved_md5}].
311 * The 'builtin' functions that used to be combined in pbx_functions.so are
312 now built as separate modules. If you are not using 'autoload=yes' in your
313 modules.conf file then you will need to explicitly load the modules that
314 contain the functions you want to use.
316 * The ENUMLOOKUP() function with the 'c' option (for counting the number of
317 records), but the lookup fails to match any records, the returned value will
318 now be "0" instead of blank.
320 * The REALTIME() function is now available in version 1.4 and app_realtime has
321 been deprecated in favor of the new function. app_realtime will be removed
322 completely with the version 1.6 release so please take the time between
323 releases to make any necessary changes
325 * The QUEUEAGENTCOUNT() function has been deprecated in favor of
326 QUEUE_MEMBER_COUNT().
330 * It is possible that previous configurations depended on the order in which
331 peers and users were specified in iax.conf for forcing the order in which
332 chan_iax2 matched against them. This behavior is going away and is considered
333 deprecated in this version. Avoid having ambiguous peer and user entries and
334 to make things easy on yourself, always set the "username" option for users
335 so that the remote end can match on that exactly instead of trying to infer
336 which user you want based on host.
338 If you would like to go ahead and use the new behavior which doesn't use the
339 order in the config file to influence matching order, then change the
340 MAX_PEER_BUCKETS define in chan_iax2.c to a value greater than one. An
341 example is provided there. By changing this, you will get *much* better
342 performance on systems that do a lot of peer and user lookups as they will be
343 stored in memory in a much more efficient manner.
345 * The "mailboxdetail" option has been deprecated. Previously, if this option
346 was not enabled, the 2 byte MSGCOUNT information element would be set to all
347 1's to indicate there there is some number of messages waiting. With this
348 option enabled, the number of new messages were placed in one byte and the
349 number of old messages are placed in the other. This is now the default
350 (and the only) behavior.
354 * The "incominglimit" setting is replaced by the "call-limit" setting in
357 * OSP support code is removed from SIP channel to OSP applications. ospauth
358 option in sip.conf is removed to osp.conf as authpolicy. allowguest option
359 in sip.conf cannot be set as osp anymore.
361 * The Asterisk RTP stack has been changed in regards to RFC2833 reception
362 and transmission. Packets will now be sent with proper duration instead of all
363 at once. If you are receiving calls from a pre-1.4 Asterisk installation you
364 will want to turn on the rfc2833compensate option. Without this option your
365 DTMF reception may act poorly.
367 * The $SIPUSERAGENT dialplan variable is deprecated and will be removed
368 in coming versions of Asterisk. Please use the dialplan function
369 SIPCHANINFO(useragent) instead.
371 * The ALERT_INFO dialplan variable is deprecated and will be removed
372 in coming versions of Asterisk. Please use the dialplan application
373 sipaddheader() to add the "Alert-Info" header to the outbound invite.
375 * The "canreinvite" option has changed. canreinvite=yes used to disable
376 re-invites if you had NAT=yes. In 1.4, you need to set canreinvite=nonat
377 to disable re-invites when NAT=yes. This is propably what you want.
378 The settings are now: "yes", "no", "nonat", "update". Please consult
379 sip.conf.sample for detailed information.
383 * Support for MFC/R2 has been removed, as it has not been functional for some
384 time and it has no maintainer.
388 * Callback mode (AgentCallbackLogin) is now deprecated, since the entire function
389 it provided can be done using dialplan logic, without requiring additional
390 channel and module locks (which frequently caused deadlocks). An example of
391 how to do this using AEL dialplan is in doc/queues-with-callback-members.txt.
395 * It has been determined that previous versions of Asterisk used the wrong codeword
396 packing order for G726-32 data. This version supports both available packing orders,
397 and can transcode between them. It also now selects the proper order when
398 negotiating with a SIP peer based on the codec name supplied in the SDP. However,
399 there are existing devices that improperly request one order and then use another;
400 Sipura and Grandstream ATAs are known to do this, and there may be others. To
401 be able to continue to use these devices with this version of Asterisk and the
402 G726-32 codec, a configuration parameter called 'g726nonstandard' has been added
403 to sip.conf, so that Asterisk can use the packing order expected by the device (even
404 though it requested a different order). In addition, the internal format number for
405 G726-32 has been changed, and the old number is now assigned to AAL2-G726-32. The
406 result of this is that this version of Asterisk will be able to interoperate over
407 IAX2 with older versions of Asterisk, as long as this version is told to allow
408 'g726aal2' instead of 'g726' as the codec for the call.
412 * On BSD systems, the installation directories have changed to more "FreeBSDish"
413 directories. On startup, Asterisk will look for the main configuration in
414 /usr/local/etc/asterisk/asterisk.conf
415 If you have an old installation, you might want to remove the binaries and
416 move the configuration files to the new locations. The following directories
418 ASTLIBDIR /usr/local/lib/asterisk
419 ASTVARLIBDIR /usr/local/share/asterisk
420 ASTETCDIR /usr/local/etc/asterisk
421 ASTBINDIR /usr/local/bin/asterisk
422 ASTSBINDIR /usr/local/sbin/asterisk
426 * The music on hold handling has been changed in some significant ways in hopes
427 to make it work in a way that is much less confusing to users. Behavior will
428 not change if the same configuration is used from older versions of Asterisk.
429 However, there are some new configuration options that will make things work
430 in a way that makes more sense.
432 Previously, many of the channel drivers had an option called "musicclass" or
433 something similar. This option set what music on hold class this channel
434 would *hear* when put on hold. Some people expected (with good reason) that
435 this option was to configure what music on hold class to play when putting
436 the bridged channel on hold. This option has now been deprecated.
438 Two new music on hold related configuration options for channel drivers have
439 been introduced. Some channel drivers support both options, some just one,
440 and some support neither of them. Check the sample configuration files to see
441 which options apply to which channel driver.
443 The "mohsuggest" option specifies which music on hold class to suggest to the
444 bridged channel when putting them on hold. The only way that this class can
445 be overridden is if the bridged channel has a specific music class set that
446 was done in the dialplan using Set(CHANNEL(musicclass)=something).
448 The "mohinterpret" option is similar to the old "musicclass" option. It
449 specifies which music on hold class this channel would like to listen to when
450 put on hold. This music class is only effective if this channel has no music
451 class set on it from the dialplan and the bridged channel putting this one on
452 hold had no "mohsuggest" setting.
454 The IAX2 and Zap channel drivers have an additional feature for the
455 "mohinterpret" option. If this option is set to "passthrough", then these
456 channel drivers will pass through the HOLD message in signalling instead of
457 starting music on hold on the channel. An example for how this would be
458 useful is in an enterprise network of Asterisk servers. When one phone on one
459 server puts a phone on a different server on hold, the remote server will be
460 responsible for playing the hold music to its local phone that was put on
461 hold instead of the far end server across the network playing the music.
465 * The behavior of the "clid" field of the CDR has always been that it will
466 contain the callerid ANI if it is set, or the callerid number if ANI was not
467 set. When using the "callerid" option for various channel drivers, some
468 would set ANI and some would not. This has been cleared up so that all
469 channel drivers set ANI. If you would like to change the callerid number
470 on the channel from the dialplan and have that change also show up in the
471 CDR, then you *must* set CALLERID(ANI) as well as CALLERID(num).
475 * There are some API functions that were not previously prefixed with the 'ast_'
476 prefix but now are; these include the ADSI, ODBC and AGI interfaces. If you
477 have a module that uses the services provided by res_adsi, res_odbc, or
478 res_agi, you will need to add ast_ prefixes to the functions that you call
483 * format_wav: The GAIN preprocessor definition has been changed from 2 to 0
484 in Asterisk 1.4. This change was made in response to user complaints of
485 choppiness or the clipping of loud signal peaks. The GAIN preprocessor
486 definition will be retained in Asterisk 1.4, but will be removed in a
487 future release. The use of GAIN for the increasing of voicemail message
488 volume should use the 'volgain' option in voicemail.conf