[sr-dev] Registrar - check for local path

Charles Chance charles.chance at sipcentric.com
Tue Dec 9 16:14:29 CET 2014


Hi Daniel,

Please see attached (I have tested already).

Should it be added, or left up to the user to perform via config? Either
way, at least the patch is available here as an option, in case the
question is asked again.

It would be good to hear others' opinions, too.

Best regards,

Charles


On 8 December 2014 at 20:10, Charles Chance <charles.chance at sipcentric.com>
wrote:

> Hi Daniel,
>
> You are right, it is not trivial to perform via config.
>
> The patch was made quickly to illustrate a point, but I have reworked it
> now to include a parameter for enabling the check, as well as accounting
> for more than one Path header.
>
> If you think it is worthwhile, I will post the full patch for review
> tomorrow.
>
> Best regards,
>
> Charles
>  On 8 Dec 2014 16:28, "Daniel-Constantin Mierla" <miconda at gmail.com>
> wrote:
>
>>
>> On 08/12/14 16:40, Charles Chance wrote:
>>
>>
>>
>> On 8 December 2014 at 15:09, Olle E. Johansson <oej at edvina.net> wrote:
>>
>>>
>>>  On 08 Dec 2014, at 16:00, Charles Chance <charles.chance at sipcentric.com>
>>> wrote:
>>>
>>>  Hi Olle,
>>>
>>>  msg_apply_changes() is for getting the Path saved the first place if
>>> adding/saving on the same instance.
>>>
>>>  My patch is for later on, to avoid looping if lookup is performed on
>>> the same instance that received the register.
>>>
>>>  Scenario is 2 x registrar/location servers, both sharing common DB -
>>> no separate edge proxies, but each adds itself as Path before saving (which
>>> is where msg_apply_changes() comes in).
>>>
>>> Can't you sort that out in the routing script? I don't see why we need
>>> to add this in the code...
>>>
>>>  If the topmost, leftmost routing header in the outbound INVITE points
>>> to me, remove it and move on.
>>> You have the branch route for that kind of manipulation.
>>>
>>>  What am I missing?
>>>
>>
>> If I got it right upon quick read, this case is not trivial to handle via
>> config file -- i.e., it is about saving registration with local address as
>> a Path, the registration can be read by same proxy or another one (the
>> other will have to send the register to this instance, this one will need
>> to ignore the path).
>>
>> After lookup("location"), the first Path appears as outbound proxy
>> address ($du / dst_uri), but it is also added in the lumps to be a Route
>> header for outgoing INVITE. If there are more than on Path header, things
>> can get quite complex to handle from config and might be easier to simplify
>> by adding a module parameter to enable/disable the proposed patch.
>>
>> Cheers,
>> Daniel
>>
>> --
>> Daniel-Constantin Mierlahttp://twitter.com/#!/miconda - http://www.linkedin.com/in/miconda
>>
>>
>> _______________________________________________
>> sr-dev mailing list
>> sr-dev at lists.sip-router.org
>> http://lists.sip-router.org/cgi-bin/mailman/listinfo/sr-dev
>>
>>

-- 
www.sipcentric.com

Follow us on twitter @sipcentric <http://twitter.com/sipcentric>

Sipcentric Ltd. Company registered in England & Wales no. 7365592. Registered 
office: Faraday Wharf, Innovation Birmingham Campus, Holt Street, 
Birmingham Science Park, Birmingham B7 4BB.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.sip-router.org/pipermail/sr-dev/attachments/20141209/d86816a4/attachment.html>
-------------- next part --------------
diff --git a/modules/registrar/lookup.c b/modules/registrar/lookup.c
index 794d968..160b763 100644
--- a/modules/registrar/lookup.c
+++ b/modules/registrar/lookup.c
@@ -41,6 +41,7 @@
 #include "../../action.h"
 #include "../../mod_fix.h"
 #include "../../parser/parse_rr.h"
+#include "../../forward.h"
 #include "../usrloc/usrloc.h"
 #include "common.h"
 #include "regtime.h"
@@ -121,6 +122,7 @@ int lookup_helper(struct sip_msg* _m, udomain_t* _d, str* _uri, int _mode)
 	sr_xavp_t *list=NULL;
 	str xname = {"ruid", 4};
 	sr_xval_t xval;
+	sip_uri_t path_uri;
 
 	ret = -1;
 
@@ -256,6 +258,7 @@ int lookup_helper(struct sip_msg* _m, udomain_t* _d, str* _uri, int _mode)
 				xavp_add_value(&reg_xavp_rcd, &xval, NULL);
 			}
 		}
+
 		/* If a Path is present, use first path-uri in favour of
 		 * received-uri because in that case the last hop towards the uac
 		 * has to handle NAT. - agranig */
@@ -265,6 +268,32 @@ int lookup_helper(struct sip_msg* _m, udomain_t* _d, str* _uri, int _mode)
 				ret = -3;
 				goto done;
 			}
+			if (parse_uri(path_dst.s, path_dst.len, &path_uri) < 0){
+				LM_ERR("failed to parse the Path URI\n");
+				ret = -3;
+				goto done;
+			}
+			if (path_check_local > 0 && check_self(&(path_uri.host), 0, 0)) {
+				/* first hop in path vector is local - check for additional hops and if present, point to next one */
+				if (ptr->path.len > (path_dst.len + 3)) {
+					ptr->path.s = ptr->path.s + path_dst.len + 3;
+					ptr->path.len = ptr->path.len - path_dst.len - 3;
+					if (get_path_dst_uri(&ptr->path, &path_dst) < 0) {
+						LM_ERR("failed to get second dst_uri for Path\n");
+						ret = -3;
+						goto done;
+					}
+				} else {
+					/* no more hops */
+					path_dst.s = NULL;
+					path_dst.len = 0;
+				}
+			}
+		} else {
+			path_dst.s = NULL;
+			path_dst.len = 0;
+		}
+		if (path_dst.s && path_dst.len) {
 			if (set_path_vector(_m, &ptr->path) < 0) {
 				LM_ERR("failed to set path vector\n");
 				ret = -3;
@@ -333,10 +362,33 @@ int lookup_helper(struct sip_msg* _m, udomain_t* _d, str* _uri, int _mode)
 	for( ; ptr ; ptr = ptr->next ) {
 		if (VALID_CONTACT(ptr, act_time) && allowed_method(_m, ptr)) {
 			path_dst.len = 0;
-			if(ptr->path.s && ptr->path.len 
-			&& get_path_dst_uri(&ptr->path, &path_dst) < 0) {
-				LM_ERR("failed to get dst_uri for Path\n");
-				continue;
+			if(ptr->path.s && ptr->path.len) { 
+				if (get_path_dst_uri(&ptr->path, &path_dst) < 0) {
+					LM_ERR("failed to get dst_uri for Path\n");
+					continue;
+				}
+				if (parse_uri(path_dst.s, path_dst.len, &path_uri) < 0) {
+					LM_ERR("failed to parse the Path URI\n");
+					continue;
+				}
+				if (path_check_local > 0 && check_self(&(path_uri.host), 0, 0)) {
+					/* first hop in path vector is local - check for additional hops and if present, point to next one */
+					if (ptr->path.len > (path_dst.len + 3)) {
+						ptr->path.s = ptr->path.s + path_dst.len + 3;
+						ptr->path.len = ptr->path.len - path_dst.len - 3;
+						if (get_path_dst_uri(&ptr->path, &path_dst) < 0) {
+							LM_ERR("failed to get second dst_uri for Path\n");
+							continue;
+						}
+					} else {
+						/* no more hops */
+						path_dst.s = NULL;
+						path_dst.len = 0;
+					}
+				}
+			} else {
+				path_dst.s = NULL;
+				path_dst.len = 0;
 			}
 
 			/* The same as for the first contact applies for branches 
@@ -345,7 +397,7 @@ int lookup_helper(struct sip_msg* _m, udomain_t* _d, str* _uri, int _mode)
 			       ptr->instance.len, ptr->instance.s);
 			if (append_branch(_m, &ptr->c,
 					  path_dst.len?&path_dst:&ptr->received,
-					  &ptr->path, ptr->q, ptr->cflags,
+					  path_dst.len?&ptr->path:0, ptr->q, ptr->cflags,
 					  ptr->sock,
 					  ptr->instance.len?&(ptr->instance):0,
 				          ptr->instance.len?ptr->reg_id:0,
diff --git a/modules/registrar/reg_mod.c b/modules/registrar/reg_mod.c
index f187fb3..83c0d25 100644
--- a/modules/registrar/reg_mod.c
+++ b/modules/registrar/reg_mod.c
@@ -116,6 +116,7 @@ int path_mode = PATH_MODE_STRICT;		/*!< if the Path HF should be inserted in the
 
 int path_use_params = 0;			/*!< if the received- and nat-parameters of last Path uri should be used
  						 * to determine if UAC is nat'ed */
+int path_check_local = 0;
 
 /* sruid to get internal uid */
 sruid_t _reg_sruid;
@@ -233,6 +234,7 @@ static param_export_t params[] = {
 	{"use_path",           INT_PARAM, &path_enabled        					},
 	{"path_mode",          INT_PARAM, &path_mode           					},
 	{"path_use_received",  INT_PARAM, &path_use_params     					},
+        {"path_check_local",   INT_PARAM, &path_check_local                                     },
 	{"xavp_cfg",           PARAM_STR, &reg_xavp_cfg     					},
 	{"xavp_rcd",           PARAM_STR, &reg_xavp_rcd     					},
 	{"gruu_enabled",       INT_PARAM, &reg_gruu_enabled    					},
diff --git a/modules/registrar/reg_mod.h b/modules/registrar/reg_mod.h
index 96def72..5dffa75 100644
--- a/modules/registrar/reg_mod.h
+++ b/modules/registrar/reg_mod.h
@@ -94,6 +94,7 @@ extern int method_filtering;
 extern int path_enabled;
 extern int path_mode;
 extern int path_use_params;
+extern int path_check_local;
 extern int reg_gruu_enabled;
 extern int reg_outbound_mode;
 extern int reg_regid_mode;


More information about the sr-dev mailing list