| Documentation | Documentation.Script-Syntax-3-2 HistoryShow minor edits - Show changes to markup May 27, 2020, at 04:33 PM 
        by  -  Changed lines 87-89 from: 
 
 to: 
 
 Changed lines 92-93 from: 
 to: 
 November 05, 2019, at 02:24 PM 
        by  -  Changed line 128 from: NOTE: There are some exceptions for the conventions above in the case of string parameters. Some functions require the parameter to be a static string, which means a plain, quoted string containing no variables. Such cases will be noted in the function's documentation. to: NOTE: There still are a few exceptions for the conventions above in the case of string parameters, due to performance optimizations, as some functions still require some parameters to be plain, static strings (e.g. save("location")). Such cases will be noted in the function's documentation. August 29, 2019, at 12:20 PM 
        by  -  Added lines 125-126: \\ August 29, 2019, at 12:19 PM 
        by  -  Added lines 124-125: Literal "$" characters can be included in a format string using the "$$" escape sequence Deleted line 126: August 08, 2019, at 06:11 PM 
        by  -  Added line 94: Changed lines 97-105 from: A significant portion of opensips.cfg scripting logic consists of functions. Currently, there are two types of functions: Core FunctionsThe core functions are always available at script level, since they are baked into the opensips binary. The calling convention for these functions varies greatly from one function to another, since each function is individually provided by the language parser. Example core function calls:to: All OpenSIPS core and module functions internally share the same function interface, such that they benefit from the following calling convention: Added lines 101-102: 
 Changed line 104 from: cache_raw_query("mongodb", "{ \"op\" : \"count\",\"query\": { \"username\" : $rU} }", "$avp(mongo_count_result)"); to: ds_select_dst(1, 1); Changed lines 107-110 from: ... will look up the specified document within MongoDB and return the results in $avp(mongo_count_result). 
 to: ... is equivalent to: Changed lines 110-111 from: cache_fetch("redis:cluster1", "my_counter", $var(redis_counter_val)); to: $var(x) = 1; ds_select_dst($var(x), $var(x)); Deleted lines 113-114: ... will look up "my_counter" within Redis and return the results in $avp(redis_counter_val). Notice how the output parameter is unquoted for this function, while the previous one, cache_raw_query(), had a similar meaning for its equivalent parameter, yet mandated quotes. Added lines 116-117: 
 Changed line 119 from: force_send_socket(tcp:10.10.10.10:5060); to: set_dlg_profile("caller", "$var(country_code)_$var(area)_$fU"); Deleted lines 121-122: ... will force the egress interface to be tcp:10.10.10.10:5060. Notice how its parameter is not a string -- in fact, it's a unique data type (a socket), as the Yacc grammar interprets it. Changed lines 124-129 from: Summary: OpenSIPS core functions are very useful, but are often inflexible: their parameters must have the exact type(s) as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each core function while keeping in mind that consistency across core functions, if any, is only due to careful collaboration between OpenSIPS developers, and is not the result of some internal programming interface. Module FunctionsModule functions become available for OpenSIPS script writers to use once their respective modules are loaded via the loadmodule statement (see the "Script Format" section above). All module functions internally share the same function interface, such that they benefit from the following, more sophisticated calling convention: to: NOTE: There are some exceptions for the conventions above in the case of string parameters. Some functions require the parameter to be a static string, which means a plain, quoted string containing no variables. Such cases will be noted in the function's documentation. Changed lines 129-130 from: 
 to: 
 Changed line 132 from: ds_select_dst(1, 1); to: ds_count(1, "a", $var(out_result)); Changed lines 135-141 from: ... is equivalent to: $var(x) = 1; ds_select_dst($var(x), $var(x)); to: Changed lines 138-139 from: 
 to: 
 
ds_select_dst("1", "1");
Deleted lines 144-163: set_dlg_profile("caller", "$var(country_code)_$var(area)_$fU"); @] 
 
 ds_count(1, "a", $var(out_result)); 
 
 
ds_select_dst("1", "1");
[@ Changed lines 146-148 from: @] Summary: module functions currently benefit from a more powerful calling convention than core functions. This enables a greater flexibility when passing parameters to these functions, while additionally ensuring a greater degree of consistency across all such functions. to: @] August 04, 2019, at 10:58 AM 
        by  -  Changed line 162 from: 
 to: 
 August 04, 2019, at 10:34 AM 
        by  -  Changed line 162 from: 
 to: 
 August 04, 2019, at 10:33 AM 
        by  -  Changed line 131 from: Summary: OpenSIPS core functions are very useful, but also often inflexible: their parameters must have the exact type(s) as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each core function while keeping in mind that consistency across core functions, if any, is only due to careful collaboration between OpenSIPS developers, and is not the result of some internal programming interface. to: Summary: OpenSIPS core functions are very useful, but are often inflexible: their parameters must have the exact type(s) as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each core function while keeping in mind that consistency across core functions, if any, is only due to careful collaboration between OpenSIPS developers, and is not the result of some internal programming interface. May 24, 2019, at 07:15 PM 
        by  -  Changed line 131 from: Summary: OpenSIPS core functions are very useful, but also inflexible: their parameters must have the exact type(s) as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each core function while keeping in mind that consistency across core functions, if any, is only due to careful collaboration between OpenSIPS developers, and is not the result of some internal programming interface. to: Summary: OpenSIPS core functions are very useful, but also often inflexible: their parameters must have the exact type(s) as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each core function while keeping in mind that consistency across core functions, if any, is only due to careful collaboration between OpenSIPS developers, and is not the result of some internal programming interface. April 25, 2019, at 06:32 PM 
        by  -  Changed lines 99-100 from: Core Functionsto: Core FunctionsChanged line 133 from: Module Functionsto: Module FunctionsApril 17, 2019, at 09:01 AM 
        by  -  Changed line 101 from: The core functions are always available at script level, since they are baked into the opensips binary. Currently, the calling convention for these functions varies greatly from one function to another, since each function is individually provided by the language parser. to: The core functions are always available at script level, since they are baked into the opensips binary. The calling convention for these functions varies greatly from one function to another, since each function is individually provided by the language parser. April 17, 2019, at 08:59 AM 
        by  -  Changed lines 81-83 from: 
 to: Basic
 Changed lines 86-88 from: 
 to: 
 Complex
 April 17, 2019, at 08:51 AM 
        by  -  Added lines 159-170: @] 
 
 
ds_select_dst("1", "1");
[@ ds_select_dst(1, 1); April 17, 2019, at 12:58 AM 
        by  -  Changed line 84 from: 
 to: 
 April 16, 2019, at 08:13 PM 
        by  -  Changed line 123 from: Summary: OpenSIPS core functions are very useful, but also inflexible: their parameters must have the exact type as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each core function while keeping in mind that consistency across core functions, if any, is only due to careful collaboration between OpenSIPS developers, and is not the result of some internal programming interface. to: Summary: OpenSIPS core functions are very useful, but also inflexible: their parameters must have the exact type(s) as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each core function while keeping in mind that consistency across core functions, if any, is only due to careful collaboration between OpenSIPS developers, and is not the result of some internal programming interface. April 16, 2019, at 08:12 PM 
        by  -  Changed line 123 from: Summary: OpenSIPS core functions are very useful, but also inflexible: their parameters must have the exact type as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each core function while keeping in mind that consistency across core functions, if any, is only due to careful collaboration between OpenSIPS developers, and not imposed by some strict internal programming interface. to: Summary: OpenSIPS core functions are very useful, but also inflexible: their parameters must have the exact type as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each core function while keeping in mind that consistency across core functions, if any, is only due to careful collaboration between OpenSIPS developers, and is not the result of some internal programming interface. April 16, 2019, at 08:11 PM 
        by  -  Changed line 123 from: Summary: OpenSIPS core functions are very useful, but also inflexible: their parameters must have the exact type as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each such function. to: Summary: OpenSIPS core functions are very useful, but also inflexible: their parameters must have the exact type as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each core function while keeping in mind that consistency across core functions, if any, is only due to careful collaboration between OpenSIPS developers, and not imposed by some strict internal programming interface. April 16, 2019, at 08:07 PM 
        by  -  Changed line 89 from: OpenSIPS script writers build their scripting logic using functions. Currently, there are two types of functions: to: A significant portion of opensips.cfg scripting logic consists of functions. Currently, there are two types of functions: April 16, 2019, at 07:57 PM 
        by  -  Added lines 129-130: 
 Added lines 144-145: 
 Added lines 151-152: \\ April 16, 2019, at 07:56 PM 
        by  -  Changed line 93 from: The core functions are always available at script level, since they are part of the opensips binary. Currently, the calling convention for these functions varies greatly from one function to another, since each function is individually provided by the language parser. to: The core functions are always available at script level, since they are baked into the opensips binary. Currently, the calling convention for these functions varies greatly from one function to another, since each function is individually provided by the language parser. April 16, 2019, at 07:55 PM 
        by  -  Changed line 123 from: Summary: OpenSIPS core functions are very useful, but also inflexible: their parameters must have the exact type as expected by the language grammar. In recent years, little to no additional core functions have been added, as the majority of efforts have been focused towards module functions, which have more powerful calling conventions. There are plans to align the core function and module function interfaces -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each such function. to: Summary: OpenSIPS core functions are very useful, but also inflexible: their parameters must have the exact type as expected by the language grammar. There are plans to align the core function and module function interfaces (the latter is more powerful, see below) -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each such function. April 16, 2019, at 07:54 PM 
        by  -  Changed lines 123-125 from: Note: OpenSIPS core functions are NOT flexible: their parameters must have the exact type as expected by the language grammar. In recent years, little to no additional core functions have been added, as the majority of efforts have been focused towards module functions, which have more powerful calling conventions. There are plans to align the core function and module function interfaces -- this work is scheduled for OpenSIPS 3.2. Summary: although core functions are extremely useful, their calling convention is inflexible. Script writers are advised to carefully consult the specifics of each such function. to: Summary: OpenSIPS core functions are very useful, but also inflexible: their parameters must have the exact type as expected by the language grammar. In recent years, little to no additional core functions have been added, as the majority of efforts have been focused towards module functions, which have more powerful calling conventions. There are plans to align the core function and module function interfaces -- this work is scheduled for OpenSIPS 3.2. Script writers are advised to carefully consult the specifics of each such function. April 16, 2019, at 07:53 PM 
        by  -  Changed lines 111-112 from: ... will look up "my_counter" within Redis and return the results in $avp(redis_counter_val). Notice how the output parameter is unquoted for this function, while the initial one had a similar meaning, yet mandated quotes. to: ... will look up "my_counter" within Redis and return the results in $avp(redis_counter_val). Notice how the output parameter is unquoted for this function, while the previous one, cache_raw_query(), had a similar meaning for its equivalent parameter, yet mandated quotes. Changed lines 123-124 from: Note: OpenSIPS core functions are NOT flexible: their parameters must have the exact type as expected by the language grammar. In recent years, very few core functions have been added, as the majority of efforts have been focused towards module functions, which have more powerful calling conventions. There are plans to align the core function and module function interfaces -- this work is scheduled for OpenSIPS 3.2. to: Note: OpenSIPS core functions are NOT flexible: their parameters must have the exact type as expected by the language grammar. In recent years, little to no additional core functions have been added, as the majority of efforts have been focused towards module functions, which have more powerful calling conventions. There are plans to align the core function and module function interfaces -- this work is scheduled for OpenSIPS 3.2. Summary: although core functions are extremely useful, their calling convention is inflexible. Script writers are advised to carefully consult the specifics of each such function. Changed lines 154-156 from: @] to: @] Summary: module functions currently benefit from a more powerful calling convention than core functions. This enables a greater flexibility when passing parameters to these functions, while additionally ensuring a greater degree of consistency across all such functions. April 16, 2019, at 07:37 PM 
        by  -  Added lines 95-96: Example core function calls:Deleted lines 98-100: Example core function calls: Changed lines 111-112 from: ... will look up "my_counter" within Redis and return the results in $avp(redis_counter_val). to: ... will look up "my_counter" within Redis and return the results in $avp(redis_counter_val). Notice how the output parameter is unquoted for this function, while the initial one had a similar meaning, yet mandated quotes. Added lines 120-121: \\ April 16, 2019, at 07:35 PM 
        by  -  Changed line 93 from: The core functions are always available at script level, since they are part of the opensips binary. Currently, the calling convention for these functions varies greatly from one function to another, since each function is directly provided by the internal Yacc parser. to: The core functions are always available at script level, since they are part of the opensips binary. Currently, the calling convention for these functions varies greatly from one function to another, since each function is individually provided by the language parser. April 16, 2019, at 07:34 PM 
        by  -  Changed line 93 from: The core functions are always available at script level, since they are part of the opensips binary. The calling convention for these functions varies greatly from one function to another, since each function is provided by the internal Yacc parser. to: The core functions are always available at script level, since they are part of the opensips binary. Currently, the calling convention for these functions varies greatly from one function to another, since each function is directly provided by the internal Yacc parser. April 16, 2019, at 07:33 PM 
        by  -  Changed lines 8-9 from: 
 to: 
 Added lines 11-12: (:toc-float Table of Content:) Changed lines 15-16 from: The OpenSIPs configuration script has three main logical parts : to: Script FormatThe OpenSIPs configuration script has three main logical parts: Changed lines 75-151 from: See the description of the route directive. to: See the description of the route directive. Data TypesThe OpenSIPS scripting language supports the following data types: 
 Function Calling ConventionsOpenSIPS script writers build their scripting logic using functions. Currently, there are two types of functions: Core FunctionsThe core functions are always available at script level, since they are part of the opensips binary. The calling convention for these functions varies greatly from one function to another, since each function is provided by the internal Yacc parser. 
 
cache_raw_query("mongodb", "{ \"op\" : \"count\",\"query\": { \"username\" : $rU} }", "$avp(mongo_count_result)");
... will look up the specified document within MongoDB and return the results in $avp(mongo_count_result). 
 
cache_fetch("redis:cluster1", "my_counter", $var(redis_counter_val));
... will look up "my_counter" within Redis and return the results in $avp(redis_counter_val). 
 force_send_socket(tcp:10.10.10.10:5060); ... will force the egress interface to be tcp:10.10.10.10:5060. Notice how its parameter is not a string -- in fact, it's a unique data type (a socket), as the Yacc grammar interprets it. Note: OpenSIPS core functions are NOT flexible: their parameters must have the exact type as expected by the language grammar. In recent years, very few core functions have been added, as the majority of efforts have been focused towards module functions, which have more powerful calling conventions. There are plans to align the core function and module function interfaces -- this work is scheduled for OpenSIPS 3.2. Module FunctionsModule functions become available for OpenSIPS script writers to use once their respective modules are loaded via the loadmodule statement (see the "Script Format" section above). All module functions internally share the same function interface, such that they benefit from the following, more sophisticated calling convention: 
 ds_select_dst(1, 1); ... is equivalent to: $var(x) = 1; ds_select_dst($var(x), $var(x)); 
 
set_dlg_profile("caller", "$var(country_code)_$var(area)_$fU");
 ds_count(1, "a", $var(out_result)); April 16, 2019, at 06:46 PM 
        by  -  Changed lines 1-2 from: Documentation -> Manuals -> Manual 3.2 -> Script Format(:title Script Format - 3.2:) to: Documentation -> Manuals -> Manual 3.2 -> Script Syntax(:title Script Syntax - 3.2:) Changed line 4 from: (:allVersions Script-Format 3.2:) to: (:allVersions Script-Syntax 3.2:) May 03, 2016, at 08:40 AM 
        by  - fixed wrong ip addresses (368 => 168) Changed lines 30-31 from: listen = udp:193.268.3.20:5060 listen = udp:193.268.3.20:5070 to: listen = udp:192.168.3.20:5060 listen = udp:192.168.3.20:5070 March 20, 2014, at 08:21 PM 
        by  -  Changed line 40 from: In regards to the OpenSIPS modules,the modules that are to be loaded (no module is loaded by default) are specified by using the directive loadmodule. Modules are to be specified by name and an optional path (to the .so file). If no path is provided (and just the name of the module), the default path will be assumed for locating the loading the module (default path is /usr/lib/opensips/modules if not other one configured at compile time?. For configuring a different path, either the path is pushed directly with the module name (to get control per module) or it can be globally (for all modules) configured via the mpath global parameter.\\\ to: In regards to the OpenSIPS modules,the modules that are to be loaded (no module is loaded by default) are specified by using the directive loadmodule. Modules are to be specified by name and an optional path (to the .so file). If no path is provided (and just the name of the module), the default path will be assumed for locating the loading the module (default path is /usr/lib/opensips/modules if not other one configured at compile time. For configuring a different path, either the path is pushed directly with the module name (to get control per module) or it can be globally (for all modules) configured via the mpath global parameter.\\\ March 20, 2014, at 08:18 PM 
        by  -  Added lines 1-71: Documentation -> Manuals -> Manual 3.2 -> Script Format(:title Script Format - 3.2:) (:allVersions Script-Format 3.2:) 
 
 
 The OpenSIPs configuration script has three main logical parts : 
 Global parametersUsually, in the first part, you declare the OpenSIPS global parameters - these global or core parameters are affecting the OpenSIPS core and possible the modules. Configuring the network listeners, available transport protocols, forking (and number of processes), the logging and other global stuff is provided by these global parameters. Example: disable_tcp = yes listen = udp:193.268.3.20:5060 listen = udp:193.268.3.20:5070 fork = yes children = 4 log_stderror = no Modules sectionIn regards to the OpenSIPS modules,the modules that are to be loaded (no module is loaded by default) are specified by using the directive loadmodule. Modules are to be specified by name and an optional path (to the .so file). If no path is provided (and just the name of the module), the default path will be assumed for locating the loading the module (default path is /usr/lib/opensips/modules if not other one configured at compile time?. For configuring a different path, either the path is pushed directly with the module name (to get control per module) or it can be globally (for all modules) configured via the mpath global parameter. Examples: 
loadmodule "modules/mi_datagram/mi_datagram.so"
modparam("mi_datagram", "socket_name", "udp:127.0.0.1:4343")
modparam("mi_datagram", "children_count", 3)
or 
mpath="/usr/local/opensips_proxy/lib/modules"
loadmodule "mi_datagram.so"
modparam("mi_datagram", "socket_name", "udp:127.0.0.1:4343")
modparam("mi_datagram", "children_count", 3)
loadmodule "mi_fifo.so"
modparam("mi_fifo", "fifo_name", "/tmp/opensips_fifo")
Routing logicThe routing logic is actually a sum of routes (script routes) that contain the OpenSIPS logic for routing SIP traffic. The description of OpenSIPS behavior in relation to the SIP traffic is done via this routes. 
 
 | 
 
  