dect
/
asterisk
Archived
13
0
Fork 0
This repository has been archived on 2022-02-17. You can view files and clone it, but cannot push or open issues or pull requests.
asterisk/doc
markster 4ff9c9455b Fix colon expansion (bug #3572)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@5023 f38db490-d61c-443f-a65b-d21fe96a405b
2005-02-13 20:57:52 +00:00
..
CODING-GUIDELINES Modify code example suggestion 2005-01-19 02:34:59 +00:00
PEERING Add DUNDi.... (http://www.dundi.com) 2004-10-18 21:45:13 +00:00
README.cdr Update CDR documentation (bug #3525) 2005-02-10 07:28:27 +00:00
README.cliprompt Merge Tilghman's color patches for the asterisk prompt (bug #1535) 2004-05-02 19:13:16 +00:00
README.configuration Remove duplicate section (bug #3545) 2005-02-10 21:17:36 +00:00
README.dundi Add DUNDi.... (http://www.dundi.com) 2004-10-18 21:45:13 +00:00
README.extconfig Add ability to store voicemail in ODBC database 2004-11-28 21:28:30 +00:00
README.h323 add new file README.h323 to help lower the signal-to-noise ratio 2004-05-16 16:52:18 +00:00
README.iax Update IAX readme (bug #3310) 2005-01-10 22:07:01 +00:00
README.ices Add Icecast streaming support 2004-02-17 07:03:14 +00:00
README.math Update documentation 2004-10-03 14:22:01 +00:00
README.mp3 Add README.mp3 to docs to clear up confusion about working and 2004-08-18 14:27:25 +00:00
README.mysql Remove MySQL support from default Asterisk in accordance with new MySQL library licensing 2003-09-26 22:03:10 +00:00
README.odbcstorage Add missing schema (bug #3216) 2005-01-07 06:19:37 +00:00
README.sms Add revk's SMS application (bug #1437). Thanks! 2004-04-28 20:43:06 +00:00
README.variables Fix colon expansion (bug #3572) 2005-02-13 20:57:52 +00:00
app_sms.html Merge sms stuff and move to "utils" subdir (bug #2973) 2004-12-11 22:36:27 +00:00
apps.txt Version 0.1.0 from FTP 1999-10-19 01:52:58 +00:00
cdr.txt Fix typo in cdr.txt (bug 2510) 2004-09-26 16:39:11 +00:00
channel.txt Version 0.1.1 from FTP 1999-12-16 12:59:53 +00:00
extensions.txt Various spelling errors fixed in docs 2004-02-15 07:48:46 +00:00
iax.txt Version 0.1.2 from FTP 1999-12-25 00:13:34 +00:00
linkedlists.README Document linked lists better (bug #3139) 2004-12-23 22:35:35 +00:00
localchannel.txt Various spelling errors fixed in docs 2004-02-15 07:48:46 +00:00
manager.txt Allow "fast" asynchronous manager initiation of events (bug #772) 2004-05-01 23:52:27 +00:00
model.txt Various spelling errors fixed in docs 2004-02-15 07:48:46 +00:00
modules.txt Various spelling errors fixed in docs 2004-02-15 07:48:46 +00:00
queuelog.txt Merge agent callback login/logoff events and logging (bug #1775) 2004-06-03 17:33:35 +00:00

README.variables

Asterisk dial plan variables 
---------------------------

There are two levels of parameter evaluation done in the Asterisk
dial plan in extensions.conf.
* The first, and most frequently used, is the substitution of variable
  references with their values. 
* Then there are the evaluations of expressions done in $[ .. ]. 
  This will be discussed below.

Asterisk has user-defined variables and standard variables set
by various modules in Asterisk. These standard variables are
listed at the end of this document.

___________________________
PARAMETER QUOTING: 
---------------------------

exten => s,5,BackGround,blabla

The parameter (blabla) can be quoted ("blabla"). In this case, a 
comma does not terminate the field. However, the double quotes
will be passed down to the Background command, in this example.

Also, characters special to variable substitution, expression evaluation, etc
(see below), can be quoted. For example, to literally use a $ on the 
string "$1231", quote it with a preceding \. Special characters that must
be quoted to be used, are [ ] $ " \. (to write \ itself, use \\). 

These Double quotes and escapes are evaluated at the level of the
asterisk config file parser. 

Double quotes can also be used inside expressions, as discussed below.

___________________________
VARIABLES: 
---------------------------

Parameter strings can include variables. Variable names are arbitrary strings. 
They are stored in the respective channel structure. 

To set a variable to a particular value, do : 

    exten => 1,2,SetVar(varname=value)

You can substitute the value of a variable everywhere using ${variablename}.
For example, to stringwise append $lala to $blabla and store result in $koko, 
do: 

   exten => 1,2,SetVar(koko=${blabla}${lala})


There are two reference modes - reference by value and reference by name. 
To refer to a variable with its name (as an argument to a function that 
requires a variable), just write the name. To refer to the variable's value, 
enclose it inside ${}. For example, SetVar takes as the first argument 
(before the =) a variable name, so: 

	exten => 1,2,SetVar(koko=lala)
	exten => 1,3,SetVar(${koko}=blabla)

stores to the variable "koko" the value "lala" and to variable "lala" the 
value "blabla". 

In fact, everything contained ${here} is just replaced with the value of 
the variable "here". 

_______________________________
REMOVING CHARACTERS FROM STRING
-------------------------------

If you want to remove the first N characters from a string, you just
add a colon and the number of characters, like

	;Remove the first character of extension, save in "number" variable
	exten => _9X.,1,setvar(number=${EXTEN:1})

A second colon limits the number of characters used from the original
string. 
	;Strip five characters from the start of string, use only two 
	; (character 6 and 7 in the original string)
	exten => 1000,4,setvar(skrep=${STRING:5:2})

You can also count from the end of the string by giving a negative
position:

	;Use the two first of the three last characters in the account code
	exten => 4500,4,setvar(acc=${ACCOUNTCODE:-3:2})

Or 
	;Use the last three digits of the phone number
	exten => 6112,4,goto(${EXTEN:-3},1)

___________________________
EXPRESSIONS: 
---------------------------

Everything contained inside a bracket pair prefixed by a $ (like $[this]) is 
considered as an expression and it is evaluated. Evaluation works similar to 
(but is done on a later stage than) variable substitution: the expression 
(including the square brackets) is replaced by the result of the expression 
evaluation. 
Note: The arguments and operands of the expression MUST BE separated 
by at least one space. 


For example, after the sequence: 

exten => 1,1,SetVar(lala=$[1 + 2])
exten => 1,2,SetVar(koko=$[2 * ${lala}])

the value of variable koko is "6".

And, further:

exten => 1,1,SetVar(lala=$[1+2]);

will not work as you might have expected. Since all the chars in the single 
token "1+2" are not numbers, it will be evaluated as the string "1+2". Again,
please do not forget, that this is a very simple parsing engine, and it
uses a space (at least one), to separate "tokens".

and, further:

exten => 1,1,SetVar,"lala=$[  1 +    2   ]";

will parse as intended. Extra spaces are ignored.

___________________________
SPACES INSIDE VARIABLE
---------------------------
If the variable being evaluated contains spaces, there can be problems.

For these cases, double quotes around text that may contain spaces
will force the surrounded text to be evaluated as a single token.
The double quotes will be counted as part of that lexical token.

As an example:

exten => s,6,GotoIf($[ "${CALLERIDNAME}" : "Privacy Manager" ]?callerid-liar|s|1:s|7)

The variable CALLERIDNAME could evaluate to "DELOREAN MOTORS" (with a space)
but the above will evaluate to:

"DELOREAN MOTORS" : "Privacy Manager"

and will evaluate to 0.

The above without double quotes would have evaluated to:

DELOREAN MOTORS : Privacy Manager

and will result in syntax errors, because token DELOREAN is immediately
followed by token MOTORS and the expression parser will not know how to 
evaluate this expression.

_____________________
OPERATORS
---------------------
Operators are listed below in order of increasing precedence.  Operators
with equal precedence are grouped within { } symbols.

     expr1 | expr2
             Return the evaluation of expr1 if it is neither an empty string
             nor zero; otherwise, returns the evaluation of expr2.

     expr1 & expr2
             Return the evaluation of expr1 if neither expression evaluates to
             an empty string or zero; otherwise, returns zero.

     expr1 {=, >, >=, <, <=, !=} expr2
             Return the results of integer comparison if both arguments are
             integers; otherwise, returns the results of string comparison
             using the locale-specific collation sequence.  The result of each
             comparison is 1 if the specified relation is true, or 0 if the
             relation is false.

     expr1 {+, -} expr2
             Return the results of addition or subtraction of integer-valued
             arguments.

     expr1 {*, /, %} expr2
             Return the results of multiplication, integer division, or
             remainder of integer-valued arguments.

     expr1 : expr2
             The `:' operator matches expr1 against expr2, which must be a
             regular expression.  The regular expression is anchored to the
             beginning of  the string with an implicit `^'.

             If the match succeeds and the pattern contains at least one regu-
             lar expression subexpression `\(...\)', the string correspond-
             ing to `\1' is returned; otherwise the matching operator
             returns the number of characters matched.  If the match fails and
             the pattern contains a regular expression subexpression the null
             string is returned; otherwise 0.

Parentheses are used for grouping in the usual manner.

The parser must be parsed with bison (bison is REQUIRED - yacc cannot 
produce pure parsers, which are reentrant) 

___________________________
CONDITIONALS
---------------------------

There is one conditional operator - the conditional goto : 

	exten => 1,2,gotoif(condition?label1:label2)

If condition is true go to label1, else go to label2. Labels are interpreted
exactly as in the normal goto command.

"condition" is just a string. If the string is empty or "0", the condition
is considered to be false, if it's anything else, the condition is true. 
This is designed to be used together with the expression syntax described 
above, eg : 

	exten => 1,2,gotoif($[${CALLERID} = 123456]?2|1:3|1)


Example of use : 

exten => s,2,SetVar(vara=1)
exten => s,3,SetVar(varb=$[${vara} + 2])
exten => s,4,SetVar(varc=$[${varb} * 2])
exten => s,5,GotoIf($[${varc} = 6]?99|1:s|6)

___________________________
PARSE ERRORS
---------------------------

Syntax errors are now output with 3 lines.

If the extensions.conf file contains a line like:

exten => s,6,GotoIf($[ "${CALLERIDNUM}"  = "3071234567" & &  "${CALLERIDNAME}" : "Privacy Manager" ]?callerid-liar|s|1:s|7)

You may see an error in /var/log/asterisk/messages like this:

May  3 15:58:53 WARNING[1234455344]: ast_yyerror(): syntax error: parse error; Input:
 "3072312154"  : "3071234567" & & "Steves Extension" : "Privacy Manager"
 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
                                  ^

The first line shows the string passed to the expression parser. This
string is the result of the variable replacements, etc. This way, you
can see the actual string that went into the parser.

The second line usually shows a string of '^' chars, that show what's
been legally parsed so far.

And the third line shows where the parser was (lookahead token lexing,
etc), when the parse hit the rocks. A single '^' here. The error is
going to be somewhere between the last '^' on the second line, and the
'^' on the third line. That's right, in the example above, there are two
'&' chars, separated by a space, and this is a definite no-no!


___________________________
NULL STRINGS
---------------------------

Testing to see if a string is null can be done in one of two different ways:

	exten => _XX.,1,GotoIf($["${calledid}" != ""]?3) 

	exten => _XX.,1,GotoIf($[foo${calledid} != foo]?3) 


The second example above is the way suggested by the WIKI. It will 
work as long as there are no spaces in the evaluated value.

The first way should work in all cases, and indeed, might now
be the safest way to handle this situation.

___________________________
WARNING
---------------------------

If you need to do complicated things with strings, asterisk expressions
is most likely NOT the best way to go about it. AGI scripts are an
excellent option to this need, and make available the full power of
whatever language you desire, be it Perl, C, C++, Cobol, RPG, Java,
Snobol, PL/I, Scheme, Common Lisp, Shell scripts, Tcl, Forth, Modula,
Pascal, APL, assembler, etc.

---------------------------------------------------------
Asterisk standard channel variables 
---------------------------------------------------------
There are a number of variables that are defined or read
by Asterisk. Here is a list of them. More information is
available in each application's help text. All these variables
are in UPPER CASE only.

Variables marked with a * are builtin functions and can't be set,
only read in the dialplan.  Writes to such variables are silently 
ignored.

${ACCOUNTCODE} 	 * Account code (if specified)
${BLINDTRANSFER} The name of the channel on the other side a blind transfer
${BRIDGEPEER}	 Bridged peer
${CALLERANI}	 * Caller ANI (PRI channels)
${CALLERID}	 * Caller ID
${CALLERIDNAME}	 * Caller ID Name only
${CALLERIDNUM}	 * Caller ID Number only
${CALLINGANI2}	 * Caller ANI2 (PRI channels)
${CALLINGPRES}	 * Caller ID presentation for incoming calls (PRI channels)
${CALLINGTNS} 	 * Transit Network Selector (PRI channels)
${CALLINGTON}    * Caller Type of Number (PRI channels)
${CHANNEL}	 * Current channel name
${CONTEXT}       * Current context
${DATETIME}	 * Current date time in the format: YYYY-MM-DD_HH:MM:SS
${DNID}          * Dialed Number Identifier
${EPOCH}	 * Current unix style epoch
${EXTEN}	 * Current extension
${ENV(VAR)}	 * Environmental variable VAR
${HANGUPCAUSE}	 * Asterisk cause of hangup (inbound/outbound)
${HINT}          * Channel hints for this extension
${HINTNAME}      * Suggested Caller*ID name for this extension
${INVALID_EXTEN} The invalid called extension (used in the "i" extension)
${LANGUAGE}	 * Current language
${LEN(VAR)}	 * String length of VAR (integer)
${PRIORITY}	 * Current priority in the dialplan
${PRIREDIRECTREASON} Reason for redirect on PRI, if a call was directed
${RDNIS}         * Redirected Dial Number ID Service
${TIMESTAMP}	 * Current date time in the format: YYYYMMDD-HHMMSS
${TRANSFER_CONTEXT} Context for transferred calls
${UNIQUEID}	 * Current call unique identifier

Various application variables
-----------------------------
${CURL}		Resulting page content for curl()
${ENUM}		Result of application EnumLookup
${EXITCONTEXT}	Context to exit to in IVR menu (app background())
		or in the RetryDial() application
${GROUPCOUNT}	Result from groupcount()
${MONITOR}	Set to "TRUE" if the channel is/has been monitored (app monitor())
${MONITOR_EXEC}	Application to execute after monitoring a call
${MONITOR_EXEC_ARGS}	Arguments to application
${MONITOR_FILENAME} File for monitoring (recording) calls in queue
${QUEUE_PRIO}	Queue priority
${RECORDED_FILE} Recorded file in record()
${TALK_DETECED} Result from talkdetect()
${TOUCH_MONITOR} The filename base to use with Touch Monitor (auto record)
${TXTCIDNAME}	Result of application TXTCIDName
${VPB_GETDTMF}	chan_vpb

The MeetMe Conference Bridge uses the following variables:
----------------------------------------------------------
${MEETME_RECORDINGFILE} Name of file for recording a conference with 
		the "r" option
${MEETME_RECORDINGFORMAT} Format of file to be recorded
${MEETME_EXIT_CONTEXT} 	Context for exit out of meetme meeting
${MEETME_AGI_BACKGROUND} AGI script for Meetme (zap only)

Meetme() sets the following variable:
${MEETMESECS} 	Number of seconds a user participated in a MeetMe conference

The voicemail() application uses the following variables:
---------------------------------------------------------
${VM_CATEGORY}	Sets voicemail category

The following variables are set by voicemail()
${VM_NAME}	Full name in voicemail
${VM_DUR}	Voicemail duration
${VM_MSGNUM}	Number of voicemail message in mailbox
${VM_CALLERID}	Voicemail Caller ID (Person leaving vm)
${VM_CIDNAME}	Voicemail Caller ID Name
${VM_CIDNUM}	Voicemail Caller ID Number
${VM_DATE}	Voicemail Date

The following variables are set by vmauthenticate()
${AUTH_MAILBOX}	Authenticated mailbox
${AUTH_CONTEXT}	Authenticated mailbox context
${DIFF_DAY}	Day difference (internal use)

Dundi() uses the following variables
---------------------------------------------------------
${DUNDTECH}	Technology
${DUNDDEST}	Destination

The Zaptel channel sets the following variables:
---------------------------------------------------------
${ANI2}			The ANI2 Code provided by the network on the incoming call. 
			(ie, Code 29 identifies call as a Prison/Inmate Call)
${CALLTYPE}		Type of call (Speech, Digital, etc)
${CALLEDTON}		Type of number for incoming PRI extension
			i.e. 0=unknown, 1=international, 2=domestic, 3=net_specific, 
			4=subscriber, 6=abbreviated, 7=reserved 
${CALLINGSUBADDR}	Called PRI Subaddress
${FAXEXTEN}	 	The extension called before being redirected to "fax"	
${PRIREDIRECTREASON}	Reason for redirect, if a call was directed

The SIP channel sets the following variables:
---------------------------------------------------------
${SIPCALLID} 		SIP Call-ID: header verbatim (for logging or CDR matching)
${SIPDOMAIN}    	SIP destination domain of an inbound call (if appropriate)
${SIPUSERAGENT} 	SIP user agent 
${SIPURI}		SIP uri

The SIP channel reads the following variable:
${SIP_CODEC} 		Set the SIP codec for a call	

The Agent channel uses the following variables:
---------------------------------------------------------
${AGENTMAXLOGINTRIES}	Set the maximum number of failed logins
${AGENTUPDATECDR}	Whether to update the CDR record with Agent channel data
${AGENTGOODBYE}		Sound file to use for "Good Bye" when agent logs out
${AGENTACKCALL} 	Whether the agent should acknowledge the incoming call
${AGENTAUTOLOGOFF}	Auto logging off for an agent
${AGENTWRAPUPTIME}	Setting the time for wrapup between incoming calls
${AGENTNUMBER}		Agent number (username) set at login
${AGENTSTATUS}		Status of login	( fail | on | off )
${AGENTEXTEN}		Extension for logged in agent

The Dial() application sets the following variables:
---------------------------------------------------------
${DIALEDPEERNAME} Dialed peer name
${DIALEDPEERNUMBER} Dialed peer number
${DIALEDTIME}   Time for the call (seconds)
${ANSWEREDTIME} Time from dial to answer (seconds)
${DIALSTATUS}   Status of the call, one of:
                CHANUNAVAIL | CONGESTION | BUSY | NOANSWER | ANSWER | CANCEL

The dial() application reads the following variables
${LIMIT_PLAYAUDIO_CALLER}	Soundfile for call limits
${LIMIT_PLAYAUDIO_CALLEE}	Soundfile for call limits
${LIMIT_WARNING_FILE}		Soundfile for call limits
${LIMIT_TIMEOUT_FILE}		Soundfile for call limits
${LIMIT_CONNECT_FILE}		Soundfile for call limits
${OUTBOUND_GROUP}	Default groups for peer channels (as in SetGroup)
* See "show application dial" for more information



The chanisavail() application sets the following variables:
-----------------------------------------------------------
${AVAILCHAN}		return value
${AVAILORIGCHAN} 	return value
${AVAILSTATUS}		Status of requested channel

When using macros in the dialplan, these variables are available
---------------------------------------------------------
${MACRO_EXTEN}		The calling extensions
${MACRO_CONTEXT}	The calling context
${MACRO_PRIORITY}	The calling priority
${MACRO_OFFSET}		Offset to add to priority at return from macro

If you compile with OSP support in the SIP channel, these
variables are used:
---------------------------------------------------------
${OSPHANDLE}		Handle from the OSP Library
${OSPTECH}		OSP Technology from Library
${OSPDEST}		OSP Destination from Library
${OSPTOKEN}		OSP Token to use for call from Library
${OSPRESULTS}		Number of OSP results