From b6874cc8d40336fbc9eb6c60e9d1be9313365a58 Mon Sep 17 00:00:00 2001 From: "Alexander A. Klimov" Date: Tue, 16 Jan 2024 17:52:07 +0100 Subject: [PATCH] HttpServerConnection: log request processing time as well --- lib/remote/httpserverconnection.cpp | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/lib/remote/httpserverconnection.cpp b/lib/remote/httpserverconnection.cpp index c07c19a38..76cfd3c52 100644 --- a/lib/remote/httpserverconnection.cpp +++ b/lib/remote/httpserverconnection.cpp @@ -18,6 +18,7 @@ #include "base/timer.hpp" #include "base/tlsstream.hpp" #include "base/utility.hpp" +#include #include #include #include @@ -493,6 +494,7 @@ void HttpServerConnection::ProcessMessages(boost::asio::yield_context yc) { namespace beast = boost::beast; namespace http = beast::http; + namespace ch = std::chrono; try { /* Do not reset the buffer in the state machine. @@ -518,6 +520,7 @@ void HttpServerConnection::ProcessMessages(boost::asio::yield_context yc) } m_Seen = Utility::GetTime(); + auto start (ch::steady_clock::now()); auto& request (parser.get()); @@ -541,13 +544,14 @@ void HttpServerConnection::ProcessMessages(boost::asio::yield_context yc) Log logMsg (LogInformation, "HttpServerConnection"); - logMsg << "Request: " << request.method_string() << ' ' << request.target() + logMsg << "Request " << request.method_string() << ' ' << request.target() << " (from " << m_PeerAddress << "), user: " << (authenticatedUser ? authenticatedUser->GetName() : "") << ", agent: " << request[http::field::user_agent]; //operator[] - Returns the value for a field, or "" if it does not exist. - Defer addRespCode ([&response, &logMsg]() { - logMsg << ", status: " << response.result() << ")."; + Defer addRespCode ([&response, start, &logMsg]() { + logMsg << ", status: " << response.result() << ") took " + << ch::duration_cast(ch::steady_clock::now() - start).count() << "ms."; }); if (!HandleAccessControl(*m_Stream, request, response, yc)) {