Pages for other versions: devel 3.5 3.4 Older versions: 3.3 3.2 3.1 3.0 2.4 2.3 2.2 2.1 1.11 1.10 1.9 1.8 1.7 1.6 1.5 1.4
Core Variables v1.4 |
Prev | Next |
Table of Content (hide)
OpenSIPS provides multiple type of variables to be used in the routing script. The difference between the types of variables comes from (1) the visibility of the variable (when it is visible), (2) what the variable is attached to (where the variable resides), (3) read-write status of the variable (some types of the variables are read-only and (4) how multipe values (for the same variable are handled).
The OpenSIPS variables can be easily identified in the script as all their names (or notations) starts with the $ sign.
Types of variables:
Naming: **$var(name)**
Hints:
Example of usage:
$var(a) = 2; # sets the value of variable 'a' to integer '2' $var(a) = "2"; # sets the value of variable 'a' to string '2' $var(a) = 3 + (7&(~2)); # arithmetic and bitwise operation $var(a) = "sip:" + $au + "@" + $fd; # compose a value from authentication username and From URI domain # using a script variable for tests if( [ $var(a) & 4 ] ) { xlog("var a has third bit set\n"); }
Setting a variable to NULL is actually initializing the value to integer '0'. Script variables don't have NULL value.
Naming: **$avp(id)** or **$(avp(id)[N])**
The 'id' can be:
When using the index "N" you can force the AVP to return a certain value (the N-th value). If no index is given, the first value will be returned.
Hints:
Example of usage:
# enable avps in onreply route modparam("tm", "onreply_avp_mode", 1) # define "tmp" as alias for "i:17" avp_aliases="tmp=i:17" ... route{ ... $avp(tmp) = $Ts ; # store the current time (at request processing) ... t_onreply("1"); t_relay(); ... } onreply_route[1] { if (t_check_status("200")) { # calculate the setup time $var(setup_time) = $Ts - $avp(tmp); } }
$avp(i:17) = "one"; # we have a sigle value $avp(i:17) = "two"; # we have two values ("two","one") $avp(i:17) = "three"; # we have three values ("three","two","one") xlog("accessing values with no index: $avp(i:17)\n"); # this will print the first value, which is the last added value -> "three" xlog("accessing values with no index: $(avp(i:17)[2])\n"); # this will print the index 2 value (third one), -> "one" # remove the last value of the avp; if there is only one value, the AVP itself will be destroyed $avp(i:17) = NULL; # delete all values and destroy the AVP avp_delete("$avp(i:17)/g");
The AVPOPS module provides a lot of useful functions to operate AVPs (like checking values, pushing values into different other locations, deleting AVPs, etc).
Naming: $name
Hints:
Predefined (provided by core) PVs are listed in alphabetical order.
$ai - reference to URI in request's P-Asserted-Identity header (see RFC 3325)
$adu - URI from Authorization or Proxy-Authorization header. This URI is used when calculating the HTTP Digest Response.
$ar - realm from Authorization or Proxy-Authorization header
$au - user part of username from Authorization or Proxy-Authorization header
$ad - domain part of username from Authorization or Proxy-Authorization header
$aU - whole username from Authorization or Proxy-Authorization header
$Au - username for accounting purposes. It's a selective pseudo variable (inherited from acc module). It returns $au if exits or From username otherwise.
$br - reference to request's first branch
It is R/W variable (you can assign values to it from routing logic)
$bR - reference to request's all branches
$bf - reference to branch flags of branch 0 (RURI) - decimal output
It is R/W variable (you can assign values to it from routing logic)
$bF - reference to branch flags of branch 0 (RURI) - hexa output
It is R/W variable (you can assign values to it from routing logic)
$ci - reference to body of call-id header
$cl - reference to body of content-length header
$cs - reference to cseq number from cseq header
$ct - reference to body of contact header
$cT - reference to body of content-type header
$dd - reference to domain of destination uri
$di - reference to Diversion header URI
$dip - reference to Diversion header "privacy" parameter value
$dir - reference to Diversion header "reason" parameter value
$dp - reference to port of destination uri
$dP - reference to transport protocol of destination uri
$ds - reference to destination set
$du - reference to destination uri (outbound proxy to be used for sending the request) If loose_route() returns TRUE a destination uri is set according to the first Route header.
It is R/W variable (you can assign values to it from routing logic)
$err.class - the class of error (now is '1' for parsing errors)
$err.level - severity level for the error
$err.info - text describing the error
$err.rcode - recommended reply code
$err.rreason - recommended reply reason phrase
$fd - reference to domain in URI of 'From' header
$fn - reference to display name of 'From' header
$fs - reference to the forced socket for message sending (if any) in the form proto:ip:port
It is R/W variable (you can assign values to it routing script)
$ft - reference to tag parameter of 'From' header
$fu - reference to URI of 'From' header
$fU - reference to username in URI of 'From' header
$mb - reference to SIP message buffer
$mf - reference to message/transaction flags set for current SIP request
It is R/W variable (you can assign values to it from routing logic)
$mF -reference to message/transaction flags set for current SIP request in hexa
It is R/W variable (you can assign values to it from routing logic)
$mi - reference to SIP message id
$ml - reference to SIP message length
$od - reference to domain in request's original R-URI
$op - reference to port of original R-URI
$oP - reference to transport protocol of original R-URI
$ou - reference to request's original URI
$oU - reference to username in request's original URI
$pd - reference to domain in request's P-Preferred-Identity header URI (see RFC 3325)
$pn - reference to Display Name in request's P-Preferred-Identity header (see RFC 3325)
$pp - reference to process id (pid)
$pr or $proto - protocol of received message (UDP, TCP, TLS, SCTP)
$pU - reference to user in request's P-Preferred-Identity header URI (see RFC 3325)
$pu - reference to URI in request's P-Preferred-Identity header (see RFC 3325)
$rd - reference to domain in request's URI
It is R/W variable (you can assign values to it routing script)
$rb - reference to message body
$rc - reference to returned code by last invoked function
$retcode - same as **$rc**
$re - reference to Remote-Party-ID header URI
$rm - reference to request's method
$rp - reference to port of R-URI
It is R/W variable (you can assign values to it routing script)
$rP - reference to transport protocol of R-URI
$rr - reference to reply's reason
$rs - reference to reply's status
$rt - reference to URI of refer-to header
$ru - reference to request's URI
It is R/W variable (you can assign values to it routing script)
$rU - reference to username in request's URI
It is R/W variable (you can assign values to it routing script)
$Ri - reference to IP address of the interface where the request has been received
$Rp - reference to the port where the message was received
$sf - reference to script flags - decimal output
It is R/W variable (you can assign values to it from routing logic)
$sF - reference to script flags - hexa output
It is R/W variable (you can assign values to it from routing logic)
$si - reference to IP source address of the message
$sp - reference to the source port of the message
$td - reference to domain in URI of 'To' header
$tn - reference to display name of 'To' header
$tt - reference to tag parameter of 'To' header
$tu - reference to URI of 'To' header
$tU - reference to username in URI of 'To' header
$T_branch_idx - the index (starting with 1 for the first branch) of the branch for which is executed the branch_route[]. If used outside of branch_route[] block, the value is '0'. This is exported by TM module.
$Tf - reference string formatted time
$Ts - reference to unix time stamp
$ua - reference to user agent header field
$(hdr(name)[N]) - represents the body of the N-th header identified by 'name'. If [N] is omitted then the body of the first header is printed. The first header is got when N=0, for the second N=1, a.s.o. To print the last header of that type, use -1, no other negative values are supported now. No white spaces are allowed inside the specifier (before }, before or after {, [, ] symbols). When N='*', all headers of that type are printed.
The module should identify most of compact header names (the ones recognized by OpenSIPS which should be all at this moment), if not, the compact form has to be specified explicitly. It is recommended to use dedicated specifiers for headers (e.g., %ua for user agent header), if they are available -- they are faster.
It is R/W variable (you can assign values to it routing script)
These sequences are exported, and mainly used, by xlog module to print messages in many colors (foreground and background) using escape sequences.
$C(xy) - reference to an escape sequence. ¿x¿ represents the foreground color and ¿y¿ represents the background color.
Colors could be:
A few examples of usage.
... avp_aliases="uuid=I:50" ... route { ... $avp(uuid)="caller_id"; $avp(i:20)= $avp(uuid) + ": " + $fu; xdbg("$(C(bg))avp(i:20)$(C(xx)) [$avp(i:20)] $(C(br))cseq$(C(xx))=[$hdr(cseq)]\n"); ... } ...