From 44570895026eeb1b20df9f14aa685301f834b08c Mon Sep 17 00:00:00 2001 From: XMRig Date: Mon, 1 Apr 2019 02:46:41 +0700 Subject: [PATCH] Added error log to http responses. --- src/base/net/http/HttpResponse.cpp | 33 +++++++++++++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff --git a/src/base/net/http/HttpResponse.cpp b/src/base/net/http/HttpResponse.cpp index 65c0eb04..06b61879 100644 --- a/src/base/net/http/HttpResponse.cpp +++ b/src/base/net/http/HttpResponse.cpp @@ -30,13 +30,15 @@ #include "3rdparty/http-parser/http_parser.h" +#include "base/io/log/Log.h" #include "base/net/http/HttpContext.h" #include "base/net/http/HttpResponse.h" namespace xmrig { -static const char *kCRLF = "\r\n"; +static const char *kCRLF = "\r\n"; +static const char *kUserAgent = "user-agent"; } // namespace xmrig @@ -102,6 +104,35 @@ void xmrig::HttpResponse::end(const char *data, size_t size) } HttpContext *ctx = HttpContext::get(m_id); + +# ifndef APP_DEBUG + if (statusCode() >= 400) +# endif + { + const bool err = statusCode() >= 400; + char ip[46] = {}; + sockaddr_storage addr = {}; + int aSize = sizeof(addr); + + uv_tcp_getpeername(ctx->tcp, reinterpret_cast(&addr), &aSize); + if (reinterpret_cast(&addr)->sin_family == AF_INET6) { + uv_ip6_name(reinterpret_cast(&addr), ip, 45); + } + else { + uv_ip4_name(reinterpret_cast(&addr), ip, 16); + } + + Log::print(err ? Log::ERR : Log::INFO, CYAN("%s ") CLEAR MAGENTA_BOLD("%s") WHITE_BOLD(" %s ") CSI "1;%dm%d " CLEAR WHITE_BOLD("%zu ") BLACK_BOLD("\"%s\""), + ip, + http_method_str(static_cast(ctx->method)), + ctx->url.c_str(), + err ? 31 : 32, + statusCode(), + header.size() + size, + ctx->headers.count(kUserAgent) ? ctx->headers.at(kUserAgent).c_str() : nullptr + ); + } + uv_try_write(ctx->stream(), bufs, data ? 2 : 1); ctx->close();