[sr-dev] git:master:c0c374ef: lcr: safety checks for parms of kemi functions

Daniel-Constantin Mierla miconda at gmail.com
Fri Dec 8 09:39:45 CET 2017


Module: kamailio
Branch: master
Commit: c0c374ef15a99eef745570dd78926f6248187493
URL: https://github.com/kamailio/kamailio/commit/c0c374ef15a99eef745570dd78926f6248187493

Author: Daniel-Constantin Mierla <miconda at gmail.com>
Committer: Daniel-Constantin Mierla <miconda at gmail.com>
Date: 2017-12-08T09:20:02+01:00

lcr: safety checks for parms of kemi functions

---

Modified: src/modules/lcr/lcr_mod.c

---

Diff:  https://github.com/kamailio/kamailio/commit/c0c374ef15a99eef745570dd78926f6248187493.diff
Patch: https://github.com/kamailio/kamailio/commit/c0c374ef15a99eef745570dd78926f6248187493.patch

---

diff --git a/src/modules/lcr/lcr_mod.c b/src/modules/lcr/lcr_mod.c
index eecab748f6..beeeec0e23 100644
--- a/src/modules/lcr/lcr_mod.c
+++ b/src/modules/lcr/lcr_mod.c
@@ -2201,8 +2201,9 @@ static int ki_load_gws_furi(sip_msg_t *_m, int lcr_id, str *ruri_user,
 	struct usr_avp *avp;
 	struct search_state st;
 
-	LM_DBG("load_gws(%u, %.*s, %.*s)\n", lcr_id, ruri_user->len, ruri_user->s,
-			from_uri->len, from_uri->s);
+	LM_DBG("load_gws(%u, %.*s, %.*s)\n", lcr_id,
+			ruri_user->len, ZSW(ruri_user->s),
+			from_uri->len, ZSW(from_uri->s));
 
 	request_uri = GET_RURI(_m);
 
@@ -2363,6 +2364,10 @@ static int ki_load_gws_ruser(sip_msg_t *_m, int lcr_id, str *ruri_user)
 {
 	str from_uri = STR_NULL;
 
+	if(ruri_user==NULL || ruri_user->s==NULL) {
+		LM_ERR("invalid parameter\n");
+		return -1;
+	}
 	return ki_load_gws_furi(_m, lcr_id, ruri_user, &from_uri);
 }
 
@@ -2371,9 +2376,15 @@ static int ki_load_gws_ruser(sip_msg_t *_m, int lcr_id, str *ruri_user)
  */
 static int ki_load_gws(sip_msg_t *_m, int lcr_id)
 {
-	str ruri_user = STR_NULL;
+	str ruri_user;
 	str from_uri = STR_NULL;
 
+	if ((parse_sip_msg_uri(_m) < 0) || (!_m->parsed_uri.user.s)) {
+	    LM_ERR("error while parsing R-URI\n");
+	    return -1;
+	}
+	ruri_user = _m->parsed_uri.user;
+
 	return ki_load_gws_furi(_m, lcr_id, &ruri_user, &from_uri);
 }
 
@@ -3444,4 +3455,4 @@ int mod_register(char *path, int *dlflags, void *p1, void *p2)
 {
 	sr_kemi_modules_add(sr_kemi_lcr_exports);
 	return 0;
-}
\ No newline at end of file
+}




More information about the sr-dev mailing list