[sr-dev] git:5.0:f81c128d: jsonrpcs: safety check to see if xhttp transport was initialized

Daniel-Constantin Mierla miconda at gmail.com
Fri Mar 17 07:56:06 CET 2017


Module: kamailio
Branch: 5.0
Commit: f81c128dd3bf11fc52af308f36dabc926cc8ad70
URL: https://github.com/kamailio/kamailio/commit/f81c128dd3bf11fc52af308f36dabc926cc8ad70

Author: Daniel-Constantin Mierla <miconda at gmail.com>
Committer: Daniel-Constantin Mierla <miconda at gmail.com>
Date: 2017-03-17T07:55:30+01:00

jsonrpcs: safety check to see if xhttp transport was initialized

- reported by GH #1030

(cherry picked from commit 7ae5210a7b9fb2d9a61cef496e9abe0da9860bee)

---

Modified: src/modules/jsonrpcs/jsonrpcs_mod.c

---

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

---

diff --git a/src/modules/jsonrpcs/jsonrpcs_mod.c b/src/modules/jsonrpcs/jsonrpcs_mod.c
index e639ab9..34f5f64 100644
--- a/src/modules/jsonrpcs/jsonrpcs_mod.c
+++ b/src/modules/jsonrpcs/jsonrpcs_mod.c
@@ -1050,11 +1050,12 @@ static void jsonrpc_delayed_ctx_close(struct rpc_delayed_ctx* dctx)
 
 static int mod_init(void)
 {
+	memset(&xhttp_api, 0, sizeof(xhttp_api_t));
 
 	/* bind the XHTTP API */
 	if(jsonrpc_transport==0 || (jsonrpc_transport&1)) {
 		if (xhttp_load_api(&xhttp_api) < 0) {
-			if(jsonrpc_transport==1) {
+			if(jsonrpc_transport&1) {
 				LM_ERR("cannot bind to XHTTP API\n");
 				return -1;
 			} else {
@@ -1169,6 +1170,11 @@ static int jsonrpc_dispatch(sip_msg_t* msg, char* s1, char* s2)
 		return NONSIP_MSG_PASS;
 	}
 
+	if(xhttp_api.reply==NULL) {
+		LM_ERR("jsonrpc over http not initialized - check transport param\n");
+		return NONSIP_MSG_ERROR;
+	}
+
 	/* initialize jsonrpc context */
 	ctx = &_jsonrpc_ctx;
 	memset(ctx, 0, sizeof(jsonrpc_ctx_t));




More information about the sr-dev mailing list