From aa865937026355e7e9e82b8889e40cdf5d559c41 Mon Sep 17 00:00:00 2001 From: orignal Date: Fri, 27 Jan 2017 14:51:06 -0500 Subject: [PATCH] send correct response if JSON parse error --- I2PControl.cpp | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/I2PControl.cpp b/I2PControl.cpp index 6ffe8936..23503906 100644 --- a/I2PControl.cpp +++ b/I2PControl.cpp @@ -187,13 +187,16 @@ namespace client size_t bytes_transferred, std::shared_ptr socket, std::shared_ptr buf) { - if (ecode) { + if (ecode) + { LogPrint (eLogError, "I2PControl: read error: ", ecode.message ()); return; - } else { + } + else + { + bool isHtml = !memcmp (buf->data (), "POST", 4); try { - bool isHtml = !memcmp (buf->data (), "POST", 4); std::stringstream ss; ss.write (buf->data (), bytes_transferred); if (isHtml) @@ -237,7 +240,9 @@ namespace client response << "{\"id\":" << id << ",\"result\":{"; (this->*(it->second))(pt.get_child ("params"), response); response << "},\"jsonrpc\":\"2.0\"}"; - } else { + } + else + { LogPrint (eLogWarning, "I2PControl: unknown method ", method); response << "{\"id\":null,\"error\":"; response << "{\"code\":-32601,\"message\":\"Method not found\"},"; @@ -249,6 +254,11 @@ namespace client catch (std::exception& ex) { LogPrint (eLogError, "I2PControl: exception when handle request: ", ex.what ()); + std::ostringstream response; + response << "{\"id\":null,\"error\":"; + response << "{\"code\":-32700,\"message\":\"" << ex.what () << "\"},"; + response << "\"jsonrpc\":\"2.0\"}"; + SendResponse (socket, buf, response, isHtml); } catch (...) {