한국어

소프트스위치

온누리070 플레이스토어 다운로드
    acrobits softphone
     온누리 070 카카오 프러스 친구추가온누리 070 카카오 프러스 친구추가친추
     카카오톡 채팅 상담 카카오톡 채팅 상담카톡
    
     라인상담
     라인으로 공유

     페북공유

   ◎위챗 : speedseoul


  
     PAYPAL
     
     PRICE
     

pixel.gif

    before pay call 0088 from app


https://voipmagazine.wordpress.com/2014/12/05/strict-and-loose-routing-of-sip-sequential-requests/


http://www.opensips.org/html/docs/modules/1.11.x/rr.html#loose-route-id


sequential-requests-routing1.png


1.5.1.  loose_route()

The function performs routing of SIP requests which contain a route set. The name is a little bit confusing, as this function also routes requests which are in the strict router format.

This function is usually used to route in-dialog requests (like ACK, BYE, reINVITE). Nevertheless also out-of-dialog requests can have a pre-loaded route set and my be routed with loose_route. It also takes care of translating between strict-routers and loose-router.

The loose_route() function analyzes the Route headers in the requests. If there is no Route header, the function returns FALSE and routing should be done exclusivly via RURI. If a Route header is found, the function returns TRUE and behaves as described in section 16.12 of RFC 3261. The only exception is for requests with preload Route headers (intial requests, carrying a Route header): if there is only one Route header indicating the local proxy, then the Route header is removed and the function returns FALSE.

If there is a Route header but other parsing errors occur ( like parsing the TO header to get the TAG ), the function also returns FALSE.

Make sure your loose_routing function can't be used by attackers to bypass proxy authorization.

The loose_routing topic is very complex. See the RFC3261 for more details (grep for route set is a good starting point in this comprehensive RFC).

This function can be used from REQUEST_ROUTE.

Example 1.6. loose_route usage

...
loose_route();
...





Strict Routing of SIP Sequential Requests

Sequential requests within a dialog (like ACK, BYE, reINVITE) must take the path determined by record-routing and represented by Route set. In other words strict routing exactly follows the path represented by the Route set. Each strict router on the routing path, will route the SIP message as following: Rewrite the Request-URI with the topmost Route header field value and forward the message to the new Request URI. The Request-URI always contains the URI of the next hop. The next hop can be another SIP router or destination user agent. Strict Routing is legacy approach. 

Loose Routing of SIP Sequential Requests

Sequential requests within a dialog should take the path determined by record-routing and represented by Route set. Loose routing of the sequential requests leaves the Request-URI and does not change it.

  • The sequential request has “To-tag” (i.e. belongs to a dialog) whereas the initial request does not have “To-tag” (does not belong to any dialog). The initial request (Method: INVITE, or SUBSCRIBE) creates the dialog.
  • The Request-URI of the sequential request contains the URI of the destination user agent (username@FQDN/IP) whereas the initial request has AOR (username@proxyDomain).
  • Taking a simple case where all routers on the routing path are loose routers and the user agents support loose routing (i.e. The user agent will not insert its URI (user@FQDN) in a Record-Route). According to this, we can say:

 The Request-URI of the sequential request will not be changed by any proxy at all because the one who is responsible for the resource associated with this Request-URI is the destination user agent. Whereas the Request-URI of the initial request will be changed once by the proxy which is responsible for the domain in the Request-URI.

 The last Route header field value will be for the last proxy in the routing path.

Upon this, the routing procedure will look like following:

sequential-requests-routing1.png?w=637&h=546

The Pre-loaded Route header field values (Route Set in an initial SIP Request) should not be allowed for security reasons.

Note: Transition from strict routing to loose routing would break the compatibility with the older user agents. Avoiding this problem adds lot of overhead and causes problems.

Routing Path (Route Set) in SIP Message

Assume a set of loose proxies {P1 -> P2 -> P3}.

The Route set which will be included in the SIP sequential requests , will look like this:

Route: <sip:p1.domain.com;lr>,<sip:p2.domain.com;lr>,<sip:p3.domain.com;lr>

lr parameter is added to indicate that the router is a loose router. If the SIP router is strict, then the URI will not have the lr parameter.

In the strict routing,the Request-URI is overwritten so we keep the destination user agent (the contact address) in an additional Route header field value.

OpenSIPS Route Processing

In OpenSIPS, I would like to mention two important functions in “rr” module:

  • The function loose_route() which used in routing SIP requests that contain Route Set. For example to route the sequential requests we call this function as following:

if (has_totag()){

loose_route()

 # route it out to whatever destination was set by loose_route()
# in $du (destination URI).
route(relay);

}

If Route set is not empty the loose_route() returns TRUE and the destination uri ($du) is set to the first Route header field value.

  • The function record_route() which used for building the routing path by adding Record-Route header field value upon passing each proxy in a way the initial request follows to reach the destination user agent.



List of Articles
번호 제목 글쓴이 조회 수 추천 수 날짜
112 Opensips 2.32 download admin 20354   2017-09-01
 
111 OpenSIPS 2.3 install admin 25917   2017-09-01
 
110 JsSIP: The JavaScript SIP Library admin 22180   2017-09-01
 
109 WebSocket Transport using OpenSIPS admin 25589   2017-09-01
 
108 A2Billing and OpenSIPS – Part 1 admin 33320   2017-08-29
 
107 A2Billing and OpenSIPS – Part 2 admin 35226   2017-08-29
 
106 A2Billing and OpenSIPS – Part 3 admin 22820   2017-08-29
 
105 OpenSIPS 2.3 philosophy admin 22868   2017-08-17
 
104 The timeline for OpenSIPS 2.3 is admin 23921   2017-08-17
 
103 OpenSIPS Control Panel and Homer integration admin 44145   2017-08-17
 
102 Opensips sip capture re designed admin 22590   2017-07-16
 
101 WebRTC with OpenSIPS WebSocket is a protocol provides full-duplex admin 34905   2015-04-04
 
100 WebSocket Support in OpenSIPS 2.1 admin 33102   2015-04-04
 
99 OpenSIPS 2.1 (rc) is available, download now! admin 26720   2015-03-22
 
98 Service Provision Using Asterisk & OpenSIPS - AstriCon 2014 admin 34953   2015-02-25
 
97 SIP Signaling-Messages OpenSIPS Running On Multicore Server file admin 43033   2014-11-02
 
96 opensips.cfg for Asterisk admin 38638   2014-10-20
 
95 A2Billing and OpenSIPS config admin 39250   2014-10-20
 
94 Jitsi Videobridge meets WebRTC admin 46452   2014-10-18
 
93 A Survey of Open Source Products for Building a SIP Communication Platform admin 41011   2014-10-18
 
92 Script Function , Module Index v1.11 함수 모듈 opensips admin 36948   2014-10-14
 
91 Opensips TM module enables stateful processing of SIP transactions admin 46565   2014-10-04
 
90 kamailio.cfg configuration Example admin 38002   2014-10-04
 
89 opensips NAT Traversal Module admin 38282   2014-10-02
 
88 UAC Registrant Module admin 40348   2014-09-28
 
87 MediaProxy 2.3.x & OpenSIPS 1.5.x Integration admin 41084   2014-08-24
 
86 RTPPROXY Admin Guide admin 42385   2014-08-24
 
85 CANCEL MESSAGE not handled correctly admin 39975   2014-08-23
 
84 [Sipdroid] SIP data collection study tour admin 40415   2014-08-23
 
83 [OpenSIPS-Users] Opensips 1.10 NAT radius aaa admin 37581   2014-08-23