2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\section { Introduction}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								There are two levels of parameter evaluation done in the Asterisk
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								dial plan in extensions.conf.
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { enumerate}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  The first, and most frequently used, is the substitution of variable 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  references with their values. 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\item  Then there are the evaluations of expressions done in \$ [ .. ] .  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  This will be discussed below.
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { enumerate}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								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.
							 
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\section { Parameter Quoting}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								exten => s,5,BackGround,blabla
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								The parameter (blabla) can be quoted ("blabla"). In this case, a 
							 
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								comma does not terminate the field. However, the double quotes
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								will be passed down to the Background command, in this example.
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Also, characters special to variable substitution, expression evaluation, etc
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								(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 \\ ). 
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								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.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\section { Variables}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								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 : 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    exten => 1,2,Set(varname=value)
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								You can substitute the value of a variable everywhere using \$ { variablename} .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For example, to stringwise append \$ lala to \$ blabla and store result in \$ koko, 
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								do: 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   exten => 1,2,Set(koko=$ { blabla } $ { lala} )
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-01-10 04:03:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								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, 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								enclose it inside \$ { } . For example, Set takes as the first argument 
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								(before the =) a variable name, so: 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									exten => 1,2,Set(koko=lala)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									exten => 1,3,Set($ { koko } = blabla ) 
 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								stores to the variable "koko" the value "lala" and to variable "lala" the 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								value "blabla". 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								In fact, everything contained \$ { here}  is just replaced with the value of 
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								the variable "here". 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\section { Variable Inheritance}  
						 
					
						
							
								
									
										
										
										
											2005-10-18 19:16:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Variable names which are prefixed by "\_ " will be inherited to channels 
							 
						 
					
						
							
								
									
										
										
										
											2005-10-18 19:16:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								that are created in the process of servicing the original channel in 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								which the variable was set.  When the inheritance takes place, the 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								prefix will be removed in the channel inheriting the variable.  If the 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								name is prefixed by "\_ \_ " in the channel, then the variable is 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								inherited and the "\_ \_ " will remain intact in the new channel.
							 
						 
					
						
							
								
									
										
										
										
											2005-10-18 19:16:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In the dialplan, all references to these variables refer to the same 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								variable, regardless of having a prefix or not.  Note that setting any 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								version of the variable removes any other version of the variable, 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								regardless of prefix.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { Example}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-10-18 19:16:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Set(_ _ FOO=bar) ; Sets an inherited version of "FOO" variable 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Set(FOO=bar)   ; Removes the inherited version and sets a local 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								               ; variable.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								However,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								NoOp($ { _ _ FOO } )  is identical to NoOp ( $ { FOO} )
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-10-18 19:16:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\section { Selecting Characters from Variables}  
						 
					
						
							
								
									
										
										
										
											2005-02-13 20:57:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-12-13 18:54:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The format for selecting characters from a variable can be expressed as:
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-04-20 14:46:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									$ { variable _ name [ :offset [ :length ] ] } 
 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-12-13 18:54:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If you want to select the first N characters from the string assigned
							 
						 
					
						
							
								
									
										
										
										
											2005-04-20 14:46:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								to a variable, simply append a colon and the number of characters to
							 
						 
					
						
							
								
									
										
										
										
											2005-12-13 18:54:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								skip from the beginning of the string to the variable name.
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-13 20:57:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									;Remove the first character of extension, save in "number" variable
							 
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									exten => _ 9X.,1,Set(number=$ { EXTEN: 1 } ) 
 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-04-20 14:46:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Assuming we've dialed 918005551234, the value saved to the 'number' variable
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								would be 18005551234. This is useful in situations when we require users to 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								dial a number to access an outside line, but do not wish to pass the first 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								digit.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you use a negative offset number, Asterisk starts counting from the end 
							 
						 
					
						
							
								
									
										
										
										
											2005-12-13 18:54:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								of the string and then selects everything after the new position. The following
							 
						 
					
						
							
								
									
										
										
										
											2005-04-20 14:46:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								example will save the numbers 1234 to the 'number' variable, still assuming
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								we've dialed 918005551234.
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-04-20 14:46:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									;Remove everything before the last four digits of the dialed string
							 
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									exten => _ 9X.,1,Set(number=$ { EXTEN: - 4 } ) 
 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-04-20 14:46:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								We can also limit the number of characters from our offset position that we
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								wish to use. This is done by appending a second colon and length value to the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								variable name. The following example will save the numbers 555 to the 'number'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								variable.
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-04-20 14:46:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									;Only save the middle numbers 555 from the string 918005551234
							 
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									exten => _ 9X.,1,Set(number=$ { EXTEN: 5 : 3 } ) 
 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-04-20 14:46:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The length value can also be used in conjunction with a negative offset. This
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								may be useful if the length of the string is unknown, but the trailing digits
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								are. The following example will save the numbers 555 to the 'number' variable,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								even if the string starts with more characters than expected (unlike the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								previous example).
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-04-20 14:46:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									;Save the numbers 555 to the 'number' variable
							 
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									exten => _ 9X.,1,Set(number=$ { EXTEN: - 7 : 3 } ) 
 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2006-08-14 02:14:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If a negative length value is entered, Asterisk will remove that many characters
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								from the end of the string.
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2006-08-14 02:14:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									;Set pin to everything but the trailing #.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									exten => _ XXXX#,1,Set(pin=$ { EXTEN: 0 : - 1 } ) 
 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2006-08-14 02:14:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\section { Expressions}   
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Everything contained inside a bracket pair prefixed by a \$  (like \$ [this] ) is 
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								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 
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								evaluation. 
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								For example, after the sequence:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								exten => 1,1,Set(lala=$ [ 1   +   2 ] ) 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								exten => 1,2,Set(koko=$ [ 2   *   $ { lala} ])
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								the value of variable koko is "6".
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								and, further:
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								exten => 1,1,Set,(lala=$ [    1   +      2     ] ) ;
 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								will parse as intended. Extra spaces are ignored.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { Spaces Inside Variables Values}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								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:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								exten => s,6,GotoIf($ [  " $ { CALLERIDNAME} " : "Privacy Manager" ]?callerid-liar|s|1:s|7)
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The variable CALLERIDNAME could evaluate to "DELOREAN MOTORS" (with a space)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								but the above will evaluate to:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								"DELOREAN MOTORS" : "Privacy Manager"
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and will evaluate to 0.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The above without double quotes would have evaluated to:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								DELOREAN MOTORS : Privacy Manager
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and will result in syntax errors, because token DELOREAN is immediately
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								followed by token MOTORS and the expression parser will not know how to 
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								evaluate this expression, because it does not match its grammar.
							 
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { Operators}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								Operators are listed below in order of increasing precedence.  Operators
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								with equal precedence are grouped within {  }  symbols.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								     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
							 
						 
					
						
							
								
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											 
										 
										
											2007-07-05 18:15:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								             Return the results of floating point comparison if both arguments are
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             numbers; otherwise, returns the results of string comparison
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								             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
							 
						 
					
						
							
								
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											 
										 
										
											2007-07-05 18:15:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								             Return the results of addition or subtraction of floating point-valued
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								             arguments.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     expr1 { *, /, %} expr2
 
							 
						 
					
						
							
								
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											 
										 
										
											2007-07-05 18:15:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								             Return the results of multiplication, floating point division, or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             remainder of arguments.
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								     - expr1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            Return the result of subtracting expr1 from 0.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            This, the unary minus operator, is right associative, and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            has the same precedence as the ! operator.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     ! expr1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            Return the result of a logical complement of expr1.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            In other words, if expr1 is null, 0, an empty string,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            or the string "0", return a 1. Otherwise, return a 0.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            It has the same precedence as the unary minus operator, and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            is also right associative.
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								     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.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								             Normally, the double quotes wrapping a string are left as part
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             of the string. This is disastrous to the : operator. Therefore,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             before the regex match is made, beginning and ending double quote
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             characters are stripped from both the pattern and the string.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      expr1 =~ expr2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             Exactly the same as the ':' operator, except that the match is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             not anchored to the beginning of the string. Pardon any similarity
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             to seemingly similar operators in other programming languages!
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             The ":" and "=~" operators share the same precedence.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      expr1 ? expr2 :: expr3
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             Traditional Conditional operator. If expr1 is a number
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     that evaluates to 0 (false), expr3 is result of the this
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     expression evaluation.  Otherwise, expr2 is the result.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     If expr1 is a string, and evaluates to an empty string,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     or the two characters (""), then expr3 is the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     result. Otherwise, expr2 is the result.  In Asterisk, all
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     3 exprs will be "evaluated"; if expr1 is "true", expr2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     will be the result of the "evaluation" of this
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     expression.  expr3 will be the result otherwise. This
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     operator has the lowest precedence.
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								Parentheses are used for grouping in the usual manner.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Operator precedence is applied as one would expect in any of the C
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								or C derived languages.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											 
										 
										
											2007-07-05 18:15:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								subsection{ Floating Point Numbers} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In 1.6 and above, we shifted the \$ \[ ... \]  expressions to be calculated
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								via floating point numbers instead of integers. We use 'long double' numbers
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								when possible, which provide around 16 digits of precision with 12 byte numbers. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								To specify a floating point constant, the number has to have this format: D.D, where D is 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								a string of base 10 digits. So, you can say 0.10, but you can't say .10 or 20.-- we hope
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								this is not an excessive restriction!
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Floating point numbers are turned into strings via the '%g'/'%Lg' format of the printf
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								function set. This allows numbers to still 'look' like integers to those counting
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								on integer behavior. If you were counting on 1/4 evaluating to 0, you need to now say
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								TRUNC(1/4). For a list of all the truncation/rounding capabilities, see the next section.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								subsection{ Functions} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In 1.6 and above, we upgraded the $ [ ]  expressions to handle floating point numbers.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Because of this, folks counting on integer behavior would be disrupted. To make
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the same results possible, some rounding and integer truncation functions have been
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								added to the core of the Expr2 parser. Indeed, dialplan functions can be called from
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ [ .. ]  expressions without the  $ { ...}  operators. The only trouble might be in the fact that 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the arguments to these functions must be specified with a comma. If you try to call
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the MATH function, for example, and try to say 3 + MATH(7*8), the expression parser will
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								evaluate 7*8 for you into 56, and the MATH function will most likely complain that its 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								input doesn't make any sense.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								We also provide access to most of the floating point functions in the C library. (but not all of them).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								While we don't expect someone to want to do Fourier analysis in the dialplan, we
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								don't want to preclude it, either.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Here is a list of the 'builtin' functions in Expr2. All other dialplan functions
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								are available by simply calling them (read-only). In other words, you don't need to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								surround function calls in \$ \[ ... \]  expressions with \$ \{ ...\} . Don't jump to conclusions,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								though! -- you still need to wrap variable names in curly braces!
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { Enumerate}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  COS(x) x is in radians. Results vary from -1 to 1.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  SIN(x) x is in radians. Results vary from -1 to 1. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  TAN(x) x is in radians. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  ACOS(x) x should be a value between -1 and 1. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  ASIN(x) x should be a value between -1 and 1. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  ATAN(x) returns the arc tangent in radians; between -PI/2 and PI/2. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  ATAN2(x,y) returns a result resembling y/x, except that the signs of both args are used to determine the quadrant of the result. Its result is in radians, between -PI and PI. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  POW(x,y) returns the value of x raised to the power of y. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  SQRT(x) returns the square root of x. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  FLOOR(x) rounds x down to the nearest integer. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  CEIL(x) rounds x up to the nearest integer. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  ROUND(x) rounds x to the nearest integer, but round halfway cases away from zero. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  RINT(x) rounds x to the nearest integer, rounding halfway cases to the nearest even integer. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  TRUNC(x) rounds x to the nearest integer not larger in absolute value. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  REMAINDER(x,y) computes the remainder of dividing x by y. The return value is x - n*y, where n is the value x/y, rounded to the nearest integer. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If this quotient is 1/2, it is rounded to the nearest even number.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  EXP(x) returns e to the x power. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  EXP2(x) returns 2 to the x power. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  LOG(x) returns the natural logarithm of x. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  LOG2(x) returns the base 2 log of x. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  LOG10(x) returns the base 10 log of x. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\end { Enumerate}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								subsection{ Examples} 
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 "One Thousand Five Hundred" =~ "(T[^  ]+)"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns: Thousand
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 "One Thousand Five Hundred" =~ "T[^  ]+"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns: 8
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 "One Thousand Five Hundred" : "T[^  ]+"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns: 0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 "8015551212" : "(...)"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns: 801
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 "3075551212":"...(...)"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns: 555
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 ! "One Thousand Five Hundred" =~ "T[^  ]+"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns: 0 (because it applies to the string, which is non-null,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    which it turns to "0", and then looks for the pattern
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    in the "0", and doesn't find it)
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 !( "One Thousand Five Hundred" : "T[^  ]+" )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns: 1  (because the string doesn't start with a word starting
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     with T, so the match evals to 0, and the ! operator
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     inverts it to 1 ).
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 2 + 8 / 2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 6. (because of operator precedence; the division is done first, then the addition).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 2+8/2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 6. Spaces aren't necessary.
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								(2+8)/2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 5, of course.
							 
						 
					
						
							
								
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											 
										 
										
											2007-07-05 18:15:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								(3+8)/2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 5.5 now.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								TRUNC((3+8)/2)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 5.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								FLOOR(2.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								FLOOR(-2.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns -3
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								CEIL(2.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 3.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								CEIL(-2.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns -2.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ROUND(2.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 3.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ROUND(3.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 4.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ROUND(-2.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns -3
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								RINT(2.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 2.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								RINT(3.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 4.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								RINT(-2.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns -2.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								RINT(-3.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns -4.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								TRUNC(2.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 2.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								TRUNC(3.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns 3.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								TRUNC(-3.5)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									returns -3.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Of course, all of the above examples use constants, but would work the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								same if any of the numeric or string constants were replaced with a
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								variable reference \$ { CALLERIDNUM} , for instance.
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\subsection { Numbers Vs. Strings}  
						 
					
						
							
								
									
										
										
										
											2005-06-17 00:33:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											 
										 
										
											2007-07-05 18:15:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Tokens consisting only of numbers are converted to 'long double' if possible, which
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								are from 80 bits to 128 bits depending on the OS, compiler, and hardware.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This means that overflows can occur when the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								numbers get above 18 digits (depending on the number of bits involved).  Warnings will appear in the logs in this
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								case.
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\subsection { Conditionals}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-06-21 22:15:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								There is one conditional application - the conditional goto : 
							 
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									exten => 1,2,gotoif(condition?label1:label2)
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								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 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									exten => 1,2,gotoif($ [ $ { CALLERID}  = 123456]?2|1:3|1)
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Example of use : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-05-15 23:32:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								exten => s,2,Set(vara=1)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								exten => s,3,Set(varb=$ [ $ { vara}  + 2])
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								exten => s,4,Set(varc=$ [ $ { varb}  * 2])
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								exten => s,5,GotoIf($ [ $ { varc}  = 6]?99|1:s|6)
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2002-09-06 15:22:51 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { Parse Errors}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Syntax errors are now output with 3 lines.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If the extensions.conf file contains a line like:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								exten => s,6,GotoIf($ [  " $ { CALLERIDNUM} "  = "3071234567" &  &   "$ { CALLERIDNAME } " : "Privacy Manager"  ] ?callerid - liar|s| 1 :s| 7 ) 
 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								You may see an error in /var/log/asterisk/messages like this:
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Jul 15 21:27:49 WARNING[1251240752]: ast_ yyerror(): syntax error: parse error, unexpected TOK_ AND, expecting TOK_ MINUS or TOK_ LP or TOKEN; Input:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								"3072312154"  = "3071234567" &  &  "Steves Extension" : "Privacy Manager" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                               ^ 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The log line tells you that a syntax error was encountered. It now
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								also tells you (in grand standard bison format) that it hit an "AND"
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								(\& ) token unexpectedly, and that was hoping for for a MINUS (-), LP
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								(left parenthesis), or a plain token (a string or number).
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The next line shows the evaluated expression, and the line after
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								that, the position of the parser in the expression when it became confused,
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								marked with the "\^ " character.
							 
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { NULL Strings}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Testing to see if a string is null can be done in one of two different ways:
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									exten => _ XX.,1,GotoIf($ [ " $ { calledid} " != ""]?3) 
							 
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									exten => _ XX.,1,GotoIf($ [ foo $ { calledid}  != foo]?3) 
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								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.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { Warning}  
						 
					
						
							
								
									
										
										
										
											2004-05-04 16:33:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								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.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { Incompatabilities}  
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The asterisk expression parser has undergone some evolution. It is hoped
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								that the changes will be viewed as positive. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The "original" expression parser had a simple, hand-written scanner,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and a simple bison grammar. This was upgraded to a more involved bison
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								grammar, and a hand-written scanner upgraded to allow extra spaces,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and to generate better error diagnostics. This upgrade required bison
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.85, and part of the user community felt the pain of having to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								upgrade their bison version.
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The next upgrade included new bison and flex input files, and the makefile
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								was upgraded to detect current version of both flex and bison, conditionally
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								compiling and linking the new files if the versions of flex and bison would
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								allow it.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you have not touched your extensions.conf files in a year or so, the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								above upgrades may cause you some heartburn in certain circumstances, as
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								several changes have been made, and these will affect asterisk's behavior on 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								legacy extension.conf constructs.  The changes have been engineered
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								to minimize these conflicts, but there are bound to be problems.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The following list gives some (and most likely, not all) of areas
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								of possible concern with "legacy" extension.conf files:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { enumerate}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\item  Tokens separated by space(s). 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   Previously, tokens were separated by spaces. Thus, ' 1 + 1 ' would evaluate
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   to the value '2', but '1+1' would evaluate to the string '1+1'. If this
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   behavior was depended on, then the expression evaluation will break. '1+1'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   will now evaluate to '2', and something is not going to work right.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   To keep such strings from being evaluated, simply wrap them in double 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   quotes: '  "1+1" '
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\item  The colon operator. In versions previous to double quoting, the 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   colon operator takes the right hand string, and using it as a 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   regex pattern, looks for it in the left hand string. It is given
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   an implicit \^  operator at the beginning, meaning the pattern 
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   will match only at the beginning of the left hand string. 
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   If the pattern or the matching string had double quotes around
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   them, these could get in the way of the pattern match. Now,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   the wrapping double quotes are stripped from both the pattern 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   and the left hand string before applying the pattern. This
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   was done because it recognized that the new way of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   scanning the expression doesn't use spaces to separate tokens,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   and the average regex expression is full of operators that 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   the scanner will recognize as expression operators. Thus, unless
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   the pattern is wrapped in double quotes, there will be trouble.
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   For instance,      \$ { VAR1}  : (Who|What*)+
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   may have have worked before, but unless you wrap the pattern
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   in double quotes now, look out for trouble! This is better:
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								         "\$ { VAR1} " : "(Who|What*)+"
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   and should work as previous.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\item  Variables and Double Quotes 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   Before these changes, if a variable's value contained one or more double
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   quotes, it was no reason for concern. It is now!
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\item  LE, GE, NE operators removed. The code supported these operators, 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								   but they were not documented. The symbolic operators, <=, >=, and !=
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								   should be used instead.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\item   Added the unary '-' operator. So you can 3+ -4 and get -1. 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\item   Added the unary '!' operator, which is a logical complement. 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Basically, if the string or number is null, empty, or '0',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    a '1' is returned. Otherwise a '0' is returned.
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\item   Added the '=~' operator, just in case someone is just looking for 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    match anywhere in the string. The only diff with the ':' is that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    match doesn't have to be anchored to the beginning of the string.
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\item   Added the conditional operator  'expr1 ? true\_ expr :: false\_ expr' 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    First, all 3 exprs are evaluated, and if expr1 is false, the 'false\_ expr'
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    is returned as the result. See above for details. 
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\item   Unary operators '-' and '!' were made right associative. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\end { enumerate}  
						 
					
						
							
								
									
										
										
										
											2005-06-24 02:51:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { Debugging Hints}  
						 
					
						
							
								
									
										
										
										
											2005-06-21 22:15:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								There are two utilities you can build to help debug the \$ [ ]  in
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								your extensions.conf file.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The first, and most simplistic, is to issue the command:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								make testexpr2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								in the top level asterisk source directory. This will build a small
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								executable, that is able to take the first command line argument, and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								run it thru the expression parser. No variable substitutions will be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								performed. It might be safest to wrap the expression in single
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								quotes...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								testexpr2 '2*2+2/2'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								is an example.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								And, in the utils directory, you can say:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								make check\_ expr
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and a small program will be built, that will check the file mentioned
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								in the first command line argument, for any expressions that might be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								have problems when you move to flex-2.5.31.  It was originally
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								designed to help spot possible incompatibilities when moving from the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								pre-2.5.31 world to the upgraded version of the lexer.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								But one more capability has been added to check\_ expr, that might make
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								it more generally useful. It now does a simple minded evaluation of
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								all variables, and then passes the \$ []  exprs to the parser. If there
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								are any parse errors, they will be reported in the log file. You can
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								use check\_ expr to do a quick sanity check of the expressions in your
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								extensions.conf file, to see if they pass a crude syntax check.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The "simple-minded" variable substitution replaces \$ { varname}  variable
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								references with '555'. You can override the 555 for variable values,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								by entering in var=val arguments after the filename on the command
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								line.  So...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 check\_ expr /etc/asterisk/extensions.conf CALLERIDNUM=3075551212 DIALSTATUS=TORTURE EXTEN=121
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								will substitute any \$ { CALLERIDNUM}  variable references with
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3075551212, any \$ { DIALSTATUS}  variable references with 'TORTURE', and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								any \$ { EXTEN}  references with '121'.  If there is any fancy stuff
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								going on in the reference, like \$ { EXTEN:2} , then the override will
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								not work. Everything in the \$ { ...}  has to match. So, to substitute
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\$ { EXTEN:2}  references, you'd best say: 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 check\_ expr /etc/asterisk/extensions.conf CALLERIDNUM=3075551212 DIALSTATUS=TORTURE EXTEN:2=121
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								on stdout, you will see something like:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 OK -- \$ [ "\${DIALSTATUS}"  = "TORTURE" | "\${DIALSTATUS}" = "DONTCALL" ]  at line 416
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								In the expr2\_ log file that is generated, you will see:
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 line 416, evaluation of \$ [  "TORTURE"  = "TORTURE" | "TORTURE" = "DONTCALL"  ]  result: 1
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								check\_ expr is a very simplistic algorithm, and it is far from being
							 
						 
					
						
							
								
									
										
										
										
											2005-08-26 19:21:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								guaranteed to work in all cases, but it is hoped that it will be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								useful.
							 
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:35:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\section { Asterisk standard channel variables}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								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.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2006-01-09 19:33:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { ACCOUNTCODE }  	 	 *  Account code  ( if specified )   ( Deprecated; use  $ { CDR(accountcode)} ) 
						 
					
						
							
								
									
										
										
										
											2005-04-22 02:55:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { BLINDTRANSFER }  	The name of the channel on the other side of a blind transfer
  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { BRIDGEPEER } 	 	Bridged peer
  
						 
					
						
							
								
									
										
										
										
											2006-01-09 19:33:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { CALLERANI } 	 	 *  Caller ANI  ( PRI channels )   ( Deprecated; use  $ { CALLERID(ani)} ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { CALLERID } 	 	 *  Caller ID  ( Deprecated; use  $ { CALLERID(all)} ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { CALLERIDNAME } 	 	 *  Caller ID Name only  ( Deprecated; use  $ { CALLERID(name)} ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { CALLERIDNUM } 	 	 *  Caller ID Number only  ( Deprecated; use  $ { CALLERID(num)} ) 
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { CALLINGANI 2 } 	 	 *  Caller ANI 2   ( 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
  
						 
					
						
							
								
									
										
										
										
											2006-01-09 19:33:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { DATETIME } 	 	 *  Current date time in the format: DDMMYYYY - HH:MM:SS  ( Deprecated; use  $ { STRFTIME($ { EPOCH } ,, %d%m%Y-%H:%M:%S)})
  
						 
					
						
							
								
									
										
										
										
											2005-11-15 18:16:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { DB _ RESULT } 		Result value of DB _ EXISTS ( )  dial plan function
  
						 
					
						
							
								
									
										
										
										
											2006-01-09 19:33:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { DNID }           	 *  Dialed Number Identifier  ( Deprecated; use  $ { CALLERID(dnid)} ) 
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { EPOCH } 	 	 *  Current unix style epoch
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { EXTEN } 	 	 *  Current extension
  
						 
					
						
							
								
									
										
										
										
											2006-01-09 19:33:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { ENV ( VAR ) } 	 	Environmental variable VAR
  
						 
					
						
							
								
									
										
										
										
											2005-04-22 02:55:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { GOTO _ ON _ BLINDXFR } 	Transfer to the specified context / extension / priority
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											after a blind transfer (use ^  characters in place of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											| to separate context/extension/priority when setting
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											this variable from the dialplan)
							 
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { 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 ) 
  
						 
					
						
							
								
									
										
										
										
											2006-01-09 19:33:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { LANGUAGE } 	 	 *  Current language  ( Deprecated; use  $ { LANGUAGE()} ) 
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { LEN ( VAR ) } 	 	 *  String length of VAR  ( integer ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { PRIORITY } 	 	 *  Current priority in the dialplan
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { PRIREDIRECTREASON }  	Reason for redirect on PRI, if a call was directed
  
						 
					
						
							
								
									
										
										
										
											2006-01-09 19:33:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { RDNIS }          	 *  Redirected Dial Number ID Service  ( Deprecated; use  $ { CALLERID(rdnis)} ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { TIMESTAMP } 	 	 *  Current date time in the format: YYYYMMDD - HHMMSS  ( Deprecated; use  $ { STRFTIME($ { EPOCH } ,, %Y%m%d-%H%M%S)})
  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { TRANSFER _ CONTEXT }  	Context for transferred calls
  
						 
					
						
							
								
									
										
										
										
											2006-01-13 19:09:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { FORWARD _ CONTEXT }      Context for forwarded calls
  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { UNIQUEID } 	 	 *  Current call unique identifier
  
						 
					
						
							
								
									
										
										
										
											2006-02-14 23:42:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { SYSTEMNAME } 		 *  value of the systemname option of asterisk.conf
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { Application return values}  
						 
					
						
							
								
									
										
										
										
											2005-11-15 18:16:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-------------------------
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In Asterisk 1.2, many applications return the result in a variable
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								instead of, as in Asterisk 1.0, changing the dial plan priority (+101).
							 
						 
					
						
							
								
									
										
										
										
											2005-11-15 19:15:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								For the various status values, see each application's help text.
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2006-05-25 16:44:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { AGISTATUS } 			 *  agi ( ) 
  
						 
					
						
							
								
									
										
										
										
											2005-11-15 18:16:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { AQMSTATUS } 			 *  addqueuemember ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { AVAILSTATUS } 			 *  chanisavail ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { CHECKGROUPSTATUS } 		 *  checkgroup ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { CHECKMD 5 STATUS } 		 *  checkmd 5 ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { CPLAYBACKSTATUS } 		 *  controlplayback ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { DIALSTATUS }    		 *  dial ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { DBGETSTATUS } 			 *  dbget ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { ENUMSTATUS } 			 *  enumlookup ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { HASVMSTATUS } 			 *  hasnewvoicemail ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { LOOKUPBLSTATUS } 		 *  lookupblacklist ( ) 
  
						 
					
						
							
								
									
										
										
										
											2006-04-07 19:11:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { OSPAUTHSTATUS } 		 *  ospauth ( ) 
  
						 
					
						
							
								
									
										
										
										
											2005-11-15 18:16:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { OSPLOOKUPSTATUS } 		 *  osplookup ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { OSPNEXTSTATUS } 		 *  ospnext ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { OSPFINISHSTATUS } 		 *  ospfinish ( ) 
  
						 
					
						
							
								
									
										
										
										
											2006-01-22 07:18:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { PARKEDAT } 			 *  parkandannounce ( ) 
  
						 
					
						
							
								
									
										
										
										
											2005-11-15 18:16:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { PLAYBACKSTATUS } 		 *  playback ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { PQMSTATUS } 			 *  pausequeuemember ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { PRIVACYMGRSTATUS } 		 *  privacymanager ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { QUEUESTATUS } 			 *  queue ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { RQMSTATUS } 			 *  removequeuemember ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { SENDIMAGESTATUS } 		 *  sendimage ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { SENDTEXTSTATUS } 		 *  sendtext ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { SENDURLSTATUS } 		 *  sendurl ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { SYSTEMSTATUS } 			 *  system ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { TRANSFERSTATUS } 		 *  transfer ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { TXTCIDNAMESTATUS } 		 *  txtcidname ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { UPQMSTATUS } 			 *  unpausequeuemember ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { VMSTATUS } 			 *  voicmail ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { VMBOXEXISTSSTATUS } 		 *  vmboxexists ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { WAITSTATUS } 			 *  waitforsilence ( ) 
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-11-15 18:16:46 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { Various application variables}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { 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
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { MONITOR } 		 *  Set to "TRUE" if the channel is / has been monitored  ( app monitor ( ) ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { MONITOR _ EXEC } 		Application to execute after monitoring a call
  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { MONITOR _ EXEC _ ARGS } 	Arguments to application
  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { MONITOR _ FILENAME }  	File for monitoring  ( recording )  calls in queue
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { QUEUE _ PRIO } 		Queue priority
  
						 
					
						
							
								
									
										
										
										
											2006-01-06 03:40:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { QUEUE _ MAX _ PENALTY } 	Maximum member penalty allowed to answer caller
  
						 
					
						
							
								
									
										
										
										
											2005-03-28 20:48:24 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { QUEUESTATUS }  		Status of the call, one of:
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											(TIMEOUT | FULL | JOINEMPTY | LEAVEEMPTY | JOINUNAVAIL | LEAVEUNAVAIL)
							 
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { RECORDED _ FILE }  	 *  Recorded file in record ( ) 
  
						 
					
						
							
								
									
										
										
										
											2005-04-29 17:28:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { TALK _ DETECTED }  	 *  Result from talkdetect ( ) 
  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { TOUCH _ MONITOR }  	The filename base to use with Touch Monitor  ( auto record ) 
  
						 
					
						
							
								
									
										
										
										
											2005-05-16 00:43:16 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { TOUCH _ MONITOR _ FORMAT }  The audio format to use with Touch Monitor  ( auto record ) 
  
						 
					
						
							
								
									
										
										
										
											2005-12-09 00:24:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { TOUCH _ MONITOR _ OUTPUT }   *  Recorded file from Touch Monitor  ( auto record ) 
  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { TXTCIDNAME } 		 *  Result of application TXTCIDName
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { VPB _ GETDTMF } 		chan _ vpb
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { The MeetMe Conference Bridge}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { 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 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { MEETMESECS }  			 *  Number of seconds a user participated in a MeetMe conference
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { The VoiceMail() application}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-04-02 01:08:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { VM _ CATEGORY } 		Sets voicemail category
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { 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
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { VM _ MESSAGEFILE } 	 *  Path to message left by caller
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-04-02 01:08:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { The VMAuthenticate() application}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { AUTH _ MAILBOX } 	 *  Authenticated mailbox
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { AUTH _ CONTEXT } 	 *  Authenticated mailbox context
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { DUNDiLookup()}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { DUNDTECH } 	 *  The Technology of the result from a call to DUNDiLookup ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { DUNDDEST } 	 *  The Destination of the result from a call to DUNDiLookup ( ) 
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { chan\_ zap}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { ANI 2 } 			 *  The ANI 2  Code provided by the network on the incoming call. 
  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											(ie, Code 29 identifies call as a Prison/Inmate Call)
							 
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { CALLTYPE } 		 *  Type of call  ( Speech, Digital, etc ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { CALLEDTON } 		 *  Type of number for incoming PRI extension
  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											i.e. 0=unknown, 1=international, 2=domestic, 3=net_ specific, 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											4=subscriber, 6=abbreviated, 7=reserved 
							 
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { CALLINGSUBADDR } 	 *  Called PRI Subaddress
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { FAXEXTEN } 	 	 *  The extension called before being redirected to "fax"	
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { PRIREDIRECTREASON } 	 *  Reason for redirect, if a call was directed
  
						 
					
						
							
								
									
										
										
										
											2006-02-10 23:55:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { SMDI _ VM _ TYPE } 		 *  When an call is received with an SMDI message, the 'type'
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											of message 'b' or 'u'
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { chan\_ sip}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { SIPCALLID }  		 *  SIP Call - ID: header verbatim  ( for logging or CDR matching ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { SIPDOMAIN }     	 *  SIP destination domain of an inbound call  ( if appropriate ) 
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { SIPUSERAGENT }  	 *  SIP user agent  ( deprecated ) 
  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { SIPURI } 		 *  SIP uri
  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { SIP _ CODEC }  		Set the SIP codec for a call	
  
						 
					
						
							
								
									
										
										
										
											2005-09-01 23:01:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { SIP _ URI _ OPTIONS } 	 *  additional options to add to the URI for an outgoing call
  
						 
					
						
							
								
									
										
										
										
											2006-06-09 21:30:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { RTPAUDIOQOS } 		RTCP QoS report for the audio of this call
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { RTPVIDEOQOS } 		RTCP QoS report for the video of this call
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { chan\_ agent}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { 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
  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { AGENTNUMBER } 		 *  Agent number  ( username )  set at login
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { AGENTSTATUS } 		 *  Status of login	 (  fail | on | off  ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { AGENTEXTEN } 		 *  Extension for logged in agent
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\subsection { The Dial() application}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { 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:
  
						 
					
						
							
								
									
										
										
										
											2005-06-21 22:15:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                		(CHANUNAVAIL | CONGESTION | BUSY | NOANSWER 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													| ANSWER | CANCEL | DONTCALL | TORTURE)
							 
						 
					
						
							
								
									
										
										
										
											2005-11-03 21:53:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { DYNAMIC _ FEATURES } 		 *  The list of features  ( from the  [ applicationmap ]  section of
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												  features.conf) to activate during the call, with feature
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												  names separated by '#' characters
							 
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { 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
  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { OUTBOUND _ GROUP } 		Default groups for peer channels  ( as in SetGroup ) 
  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								* See "show application dial" for more information
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { The chanisavail() application}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { AVAILCHAN } 		 *  the name of the available channel if one was found	
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { AVAILORIGCHAN }  	 *  the canonical channel name that was used to create the channel
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { AVAILSTATUS } 		 *  Status of requested channel
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { Dialplan Macros}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-03-23 05:56:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { MACRO _ EXTEN } 		 *  The calling extensions
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { MACRO _ CONTEXT } 	 *  The calling context
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { MACRO _ PRIORITY } 	 *  The calling priority
  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { MACRO _ OFFSET } 		Offset to add to priority at return from macro
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2005-02-10 07:16:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { The ChanSpy() application}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2006-05-03 22:25:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { SPYGROUP } 		 *  A ':'  ( colon )  separated list of group names.
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											  (To be set on spied on channel and matched against the g(grp) option)
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}  
						 
					
						
							
								
									
										
										
										
											2006-05-03 22:25:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\subsection { OSP}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								\begin { verbatim}  
						 
					
						
							
								
									
										
										
										
											2006-04-07 19:11:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { OSPINHANDLE } 		OSP handle of in _ bound call
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { OSPINTIMELIMIT } 	Duration limit for in _ bound call
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { OSPOUTHANDLE } 		OSP handle of out _ bound call
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { OSPTECH } 		OSP technology 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { OSPDEST } 		OSP destination
  
						 
					
						
							
								
									
										
										
										
											2006-04-07 19:11:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$ { OSPCALLING } 		OSP calling number
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { OSPOUTTOKEN } 		OSP token to use for out _ bound call
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { OSPOUTTIMELIMIT } 	Duration limit for out _ bound call
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								$ { OSPRESULTS } 		Number of remained destinations
  
						 
					
						
							
								
									
										
										
										
											2007-03-15 22:29:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								\end { verbatim}