| Documentation | Documentation.Script-Routes-2-2 HistoryHide minor edits - Show changes to output December 07, 2017, at 09:56 PM 
        by  - Comment added Added lines 327-332: >><< [[#comment5]](:nl:)>>messagehead<< !!!!![[~dom]] — [-07 December 2017, 21:56-] >>messageitem<< hard to understand September 21, 2017, at 09:22 AM 
        by  - Comment added Added lines 321-326: >><< [[#comment4]](:nl:)>>messagehead<< !!!!![[~&#24503;&#29595;&#35199;&#20122;]] — [-21 September 2017, 09:22-] >>messageitem<< &#21346;&#26412;&#20255;&#29275;&#36924; February 14, 2017, at 12:02 PM 
        by  - Comment added Added lines 315-320: >><< [[#comment3]](:nl:)>>messagehead<< !!!!![[~eq]] — [-14 February 2017, 11:02-] >>messageitem<< qqe November 28, 2016, at 11:29 AM 
        by  -  Changed line 1 from: !!!!!Documentation -> [[Documentation.Manuals|Manuals]] -> [[Documentation.Manual-2-2|Manual devel]] -> Types of routes to: !!!!!Documentation -> [[Documentation.Manuals|Manuals]] -> [[Documentation.Manual-2-2|Manual 2.2]] -> Types of routes June 28, 2016, at 01:02 PM 
        by  -  Changed line 1 from: !!!!!Documentation -> [[Documentation.Manuals|Manuals]] -> [[Documentation.Manual-2-2|Manual ]] -> Types of routes to: !!!!!Documentation -> [[Documentation.Manuals|Manuals]] -> [[Documentation.Manual-2-2|Manual devel]] -> Types of routes June 28, 2016, at 01:02 PM 
        by  -  Changed line 1 from: !!!!!Documentation -> [[Documentation.Manuals|Manuals]] -> [[Documentation.Manual-2-2|Manual devel]] -> Types of routes to: !!!!!Documentation -> [[Documentation.Manuals|Manuals]] -> [[Documentation.Manual-2-2|Manual ]] -> Types of routes Changed line 8 from: || %color=#185662%[+'''Types of routes - devel'''+]%% || to: || %color=#185662%[+'''Types of routes - v2.2 '''+]%% || June 13, 2016, at 12:16 PM 
        by  - Comment added Added lines 309-314: >><< [[#comment2]](:nl:)>>messagehead<< !!!!![[~Jonathan]] — [-13 June 2016, 11:16-] >>messageitem<< It would be cool if you guys explained your scripting language better so that those who aren't familiar with OpenSIPs can grasp it a bit more easier. I have extensive SIP and SBC knowledge, but this will take time. December 05, 2015, at 06:31 AM 
        by  - Comment added Added lines 304-309: [[#comment1]](:nl:)>>messagehead<< !!!!![[~Miguel Oyarzo]] — [-05 December 2015, 05:31-] >>messageitem<< You guys should add some graphs to explain better the routing processes, specially for SIP replies. Great works anyway. >><< March 18, 2015, at 11:13 AM 
        by  -  Changed lines 283-285 from: The '''event_route''' is used by the OpenSIPS Event Interface to execute script code when an event is triggered. The name of the route is the event that has to be handled by that route. Since version 1.12 the event handling way can be specified from route definition as will be shown in the example below. If no way to handle the event specified, default will be synchronously. The keywords that can be used are sync and async. '''Triggered by''' : the [[http://www.opensips.org/html/docs/modules/1.12.x/event_route | event_route ]] module when an event raised by the OpenSIPS Event Interface to: The '''event_route''' is used by the OpenSIPS Event Interface to execute script code when an event is triggered. The name of the route is the event that has to be handled by that route. Since version 2.2 the event handling way can be specified from route definition as will be shown in the example below. If no way to handle the event specified, default will be synchronously. The keywords that can be used are sync and async. '''Triggered by''' : the [[http://www.opensips.org/html/docs/modules/2.2.x/event_route | event_route ]] module when an event raised by the OpenSIPS Event Interface March 13, 2015, at 06:55 PM 
        by  -  Changed line 190 from: The error route is executed automatically when a parsing error occurrs during SIP request processing, or when a script [[ http://www.opensips.org/Documentation/Script-CoreFunctions-2-2#toc2 | assert ]] fails. It allows the administrator to decide what to do in such error cases. to: The error route is executed automatically when a parsing error occurs during SIP request processing, or when a script [[ http://www.opensips.org/Documentation/Script-CoreFunctions-2-2#toc2 | assert ]] fails. It allows the administrator to decide what to do in such error cases. March 13, 2015, at 06:55 PM 
        by  -  Changed line 190 from: The error route is executed automatically when a parsing error occurred during SIP request processing. This allow the administrator to decide what to do in case of error. to: The error route is executed automatically when a parsing error occurrs during SIP request processing, or when a script [[ http://www.opensips.org/Documentation/Script-CoreFunctions-2-2#toc2 | assert ]] fails. It allows the administrator to decide what to do in such error cases. October 02, 2014, at 03:10 PM 
        by  -  Changed lines 283-284 from: The '''event_route''' is used by the OpenSIPS Event Interface to execute script code when an event is triggered. The name of the route is the event that has to be handled by that route. Since version 1.12 the event handling way can be specified from route definition as will be shown in the example below. If no way to handle the event specified, default will be synchronously. The keywords that can be used are "sync" and "async". to: The '''event_route''' is used by the OpenSIPS Event Interface to execute script code when an event is triggered. The name of the route is the event that has to be handled by that route. Since version 1.12 the event handling way can be specified from route definition as will be shown in the example below. If no way to handle the event specified, default will be synchronously. The keywords that can be used are sync and async. Changed line 300 from:   event_route[E_PIKE_BLOCKED, "async"] { to:   event_route[E_PIKE_BLOCKED, async] { October 01, 2014, at 04:17 PM 
        by  -  Changed lines 283-284 from: The '''event_route''' is used by the OpenSIPS Event Interface to execute script code when an event is triggered. The name of the route is the event that has to be handled by that route. to: The '''event_route''' is used by the OpenSIPS Event Interface to execute script code when an event is triggered. The name of the route is the event that has to be handled by that route. Since version 1.12 the event handling way can be specified from route definition as will be shown in the example below. If no way to handle the event specified, default will be synchronously. The keywords that can be used are "sync" and "async". Added lines 295-300:     xlog("The E_PIKE_BLOCKED event was raised\n"); } @] [@ event_route[E_PIKE_BLOCKED, "async"] { March 20, 2014, at 08:26 PM 
        by  -  Added lines 1-299: !!!!!Documentation -> [[Documentation.Manuals|Manuals]] -> [[Documentation.Manual-2-2|Manual devel]] -> Types of routes (:title Types of routes - 2.2:) ---- (:allVersions Script-Routes 2.2:) \\ || %color=#185662%[+'''Types of routes - devel'''+]%% || ||[[Script-CoreParameters-2-2|Prev]] || [[Script-Operators-2-2|Next]]|| ---- (:toc-float Table of Content:) '''OpenSIPS''' routing logic uses several types of routes. Each type of route is triggered by a certain event and allows you to process a certain type of message (request or reply). ----- !!!!route Request routing block. It contains a set of actions to be taken for SIP requests. '''Triggered by''' : receiving an external request from the network. '''Processing''' : the triggering SIP request. '''Type''' : initially stateless, may be forced to stateful by using TM functions. '''Default action''' : if the request is not either forwarded nor replied, the route will simply discard the request at the end. The main 'route' block identified by 'route{...}' or 'route[0]{...}' is executed for each SIP request. The implicit action after execution of the main route block is to drop the SIP request. To send a reply or forward the request, explicit actions must be called inside the route block. Example of usage: [@ route { if(is_method("OPTIONS")) { # send reply for each options request sl_send_reply("200", "ok"); exit(); } route(1); } route[1] { # forward according to uri forward(); } @] Note that if a 'route(X)' is called from a 'branch_route[Y]' then in 'route[X]' is just processed each separate branch instead of all branches together as occurs in main route. ---- !!!!branch_route Request's branch routing block. It contains a set of actions to be taken for each branch of a SIP request. '''Triggered by''' : preparation a new branch (of a request); the branch is well formed, but not yet sent out. '''Processing''' : the SIP request (with the branch particularities, like RURI, branch flags) '''Type''' : stateful '''Default action''' : if the branch is not dropped (via "drop" statement), the branch will be automatically sent out. It is executed only by TM module after it was armed via t_on_branch("branch_route_index"). Example of usage: [@ route { lookup("location"); t_on_branch("1"); if(!t_relay()) { sl_send_reply("500", "relaying failed"); } } branch_route[1] { if(uri=~"10\.10\.10\.10") { # discard branches that go to 10.10.10.10 drop(); } } @] ---- !!!!failure_route Failed transaction routing block. It contains a set of actions to be taken each transaction that received only negative replies (>=300) for all branches. '''Triggered by''' : receiving or generation(internal) of a negative reply that completes the transaction (all branches are terminated with negative replies) '''Processing''' : the original SIP request (that was sent out) '''Type''' : stateful '''Default action''' : if no new branch is generated or no reply is forced over, by default, the winning reply will be sent back to UAC. The 'failure_route' is executed only by TM module after it was armed via t_on_failure("failure_route_index"). Note that inside the 'failure_route', the request that initiated the transaction is being processed, and not its reply. Example of usage: [@ route { lookup("location"); t_on_failure("1"); if(!t_relay()) { sl_send_reply("500", "relaying failed"); } } failure_route[1] { if(is_method("INVITE")) { # call failed - relay to voice mail t_relay("udp:voicemail.server.com:5060"); } } @] ---- !!!!onreply_route Reply routing block. It contains a set of actions to be taken for SIP replies. '''Triggered by''' : receiving of a reply from the network '''Processing''' : the received reply '''Type''' : stateful (if bound to a transaction) or stateless (if global reply route). '''Default action''' : if the reply is not dropped (only provisional replies can be), it will be injected and processed by the transaction engine. There are three types of onreply routes: * '''global''' - it catches all replies received by OpenSIPS and does not need any special arming (simple definition is enough) - named 'onreply_route {...}' or 'onreply_route[0] {...}'. * '''per request/transaction''' - it catches all received replies belonging to a certain transaction and need to be armed (via "t_on_reply()" ) at request time, in REQUEST ROUTE - named 'onreply_route[N] {...}'. * '''per branch''' - it catches only the replies that belong to a certain branch from a transaction. It needs to be armed (also via "t_on_reply()" ) at request time, but in BRANCH ROUTE, when a certain outgoing branch is processed - named 'onreply_route[N] {...}'. Certain 'onreply_route' blocks can be executed by TM module for special replies. For this, the 'onreply_route' must be armed for the SIP requests whose replies should be processed within it, via t_on_reply("onreply_route_index"). [@ route { seturi("sip:bob@opensips.org"); # first branch append_branch("sip:alice@opensips.org"); # second branch t_on_reply("global"); # the "global" reply route # is set the whole transaction t_on_branch("1"); t_relay(); } branch_route[1] { if ($rU=="alice") t_on_reply("alice"); # the "alice" reply route # is set only for second branch } onreply_route { xlog("OpenSIPS received a reply from $si\n"); } onreply_route[alice] { xlog("received reply on the branch from alice\n"); } onreply_route[global] { if (t_check_status("1[0-9][0-9]")) { setflag(1); log("provisional reply received\n"); if (t_check_status("183")) drop; } } @] ---- !!!!error_route The error route is executed automatically when a parsing error occurred during SIP request processing. This allow the administrator to decide what to do in case of error. '''Triggered by''' : parsing error in "route" '''Processing''' : failed request '''Type''' : stateless (recommended) '''Default action''' : discard request. In error_route, the following pseudo-variables are available to get access to error details: * $(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 [@ error_route { xlog("--- error route class=$(err.class) level=$(err.level) info=$(err.info) rcode=$(err.rcode) rreason=$(err.rreason) ---\n"); xlog("--- error from [$si:$sp]\n+++++\n$mb\n++++\n"); sl_send_reply("$err.rcode", "$err.rreason"); exit; } @] ---- !!!!local_route The local route is executed automatically when a new SIP request is generated by TM, internally (no UAC side). This is a route intended to be used for message inspection, accounting and for applying last changes on the message headers. Routing and signaling functions are not allowed. '''Triggered by''' : TM generating a brand new request '''Processing''' : the new request '''Type''' : stateful '''Default action''' : send the request out [@ local_route { if (is_method("INVITE") && $ru=~"@foreign.com") { append_hf("P-hint: foreign request\r\n"); exit; } if (is_method("BYE") ) { acc_log_request("internally generated BYE"); } } @] ---- !!!!startup_route The '''startup_route''' is executed only once when OpenSIPS is started and before the processing of SIP messages begins. This is useful if some initiation actions are needed, like loading some data in the cache, to ease up the future processing. Notice that this route, compared to the others is not triggered at the receipt of a message, so the functions that can be called here must not do processing on the message. '''Triggered''' : At startup, before the listener processes are started. '''Processing''' : Initializing functions. [@ startup_route { avp_db_query("select gwlist where ruleid==1",$avp(i:100)); cache_store("local", "rule1", "$avp(i:100)"); } @] ---- !!!!timer_route The '''timer_route''' is as the name suggests, a route executed periodically at a configured interval of time specified next to the name(in seconds). The same as the startup_route, this route does not process a message. You can defined more timer routes. '''Triggered by''' : The time keeper. '''Processing''' : Functions that do refresh actions. [@ timer_route[gw_update, 300] { avp_db_query("select gwlist where ruleid==1",$avp(i:100)); $shv(i:100) =$avp(i:100); } @] ---- !!!! event_route The '''event_route''' is used by the OpenSIPS Event Interface to execute script code when an event is triggered. The name of the route is the event that has to be handled by that route. '''Triggered by''' : the [[http://www.opensips.org/html/docs/modules/1.12.x/event_route | event_route ]] module when an event raised by the OpenSIPS Event Interface '''Processing''' : the event triggered '''Type''' : stateless (recommended) '''Default action''' : no script code is executed when the event is raised. [@ event_route[E_PIKE_BLOCKED] { xlog("The E_PIKE_BLOCKED event was raised\n"); } @] (:commentboxchrono:) | 
Page last modified on December 07, 2017, at 09:56 PM
 
  