[sr-dev] git:master:dc84c0aa: dmq_usrloc: init vars earlier to avoid invalid value cleanup on error handling

Daniel-Constantin Mierla miconda at gmail.com
Sat Nov 5 13:33:53 CET 2016


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

Author: Daniel-Constantin Mierla <miconda at gmail.com>
Committer: Daniel-Constantin Mierla <miconda at gmail.com>
Date: 2016-11-05T13:33:36+01:00

dmq_usrloc: init vars earlier to avoid invalid value cleanup on error handling

---

Modified: modules/dmq_usrloc/usrloc_sync.c

---

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

---

diff --git a/modules/dmq_usrloc/usrloc_sync.c b/modules/dmq_usrloc/usrloc_sync.c
index f7fac21..31526d2 100644
--- a/modules/dmq_usrloc/usrloc_sync.c
+++ b/modules/dmq_usrloc/usrloc_sync.c
@@ -321,16 +321,25 @@ int usrloc_dmq_handle_msg(struct sip_msg* msg, peer_reponse_t* resp, dmq_node_t*
 
 	unsigned int action, expires, cseq, flags, cflags, q, last_modified,
 				 methods, reg_id;
-	str aor, ruid, c, received, path, callid, user_agent, instance;
+	str aor=STR_NULL, ruid=STR_NULL, c=STR_NULL, received=STR_NULL,
+		path=STR_NULL, callid=STR_NULL, user_agent=STR_NULL, instance=STR_NULL;
 
 	action = expires = cseq = flags = cflags = q = last_modified
 		= methods = reg_id = 0;
 
-	parse_from_header(msg);
+	srjson_InitDoc(&jdoc, NULL);
+	if(parse_from_header(msg)<0) {
+		LM_ERR("failed to parse from header\n");
+		goto invalid;
+	}
 	body = ((struct to_body*)msg->from->parsed)->uri;
 
 	LM_DBG("dmq message received from %.*s\n", body.len, body.s);
 
+	if(parse_headers(msg, HDR_EOH_F, 0)<0) {
+		LM_ERR("failed to parse the headers\n");
+		goto invalid;
+	}
 	if(!msg->content_length) {
 		LM_ERR("no content length header found\n");
 		goto invalid;
@@ -349,7 +358,6 @@ int usrloc_dmq_handle_msg(struct sip_msg* msg, peer_reponse_t* resp, dmq_node_t*
 		goto error;
 	}
 
-	srjson_InitDoc(&jdoc, NULL);
 	jdoc.buf = body;
 	if(jdoc.root == NULL) {
 		jdoc.root = srjson_Parse(&jdoc, jdoc.buf.s);




More information about the sr-dev mailing list