LoggerUtils.cs 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. using MediaBrowser.Model.Logging;
  2. using System;
  3. using System.Linq;
  4. using System.Net;
  5. using System.Text;
  6. namespace MediaBrowser.Server.Implementations.HttpServer
  7. {
  8. public static class LoggerUtils
  9. {
  10. public static void LogRequest(ILogger logger, HttpListenerContext ctx, int workerIndex)
  11. {
  12. var log = new StringBuilder();
  13. log.AppendLine("Url: " + ctx.Request.Url);
  14. log.AppendLine("Headers: " + string.Join(",", ctx.Request.Headers.AllKeys.Select(k => k + "=" + ctx.Request.Headers[k])));
  15. var type = ctx.Request.IsWebSocketRequest ? "Web Socket" : "HTTP " + ctx.Request.HttpMethod;
  16. logger.LogMultiline(type + " request received on worker " + workerIndex + " from " + ctx.Request.RemoteEndPoint, LogSeverity.Debug, log);
  17. }
  18. /// <summary>
  19. /// Logs the response.
  20. /// </summary>
  21. /// <param name="logger">The logger.</param>
  22. /// <param name="ctx">The CTX.</param>
  23. /// <param name="url">The URL.</param>
  24. /// <param name="endPoint">The end point.</param>
  25. /// <param name="duration">The duration.</param>
  26. public static void LogResponse(ILogger logger, HttpListenerContext ctx, string url, IPEndPoint endPoint, TimeSpan duration)
  27. {
  28. var statusCode = ctx.Response.StatusCode;
  29. var log = new StringBuilder();
  30. log.AppendLine(string.Format("Url: {0}", url));
  31. log.AppendLine("Headers: " + string.Join(",", ctx.Response.Headers.AllKeys.Select(k => k + "=" + ctx.Response.Headers[k])));
  32. var responseTime = string.Format(". Response time: {0} ms", duration.TotalMilliseconds);
  33. var msg = "Response code " + statusCode + " sent to " + endPoint + responseTime;
  34. logger.LogMultiline(msg, LogSeverity.Debug, log);
  35. }
  36. }
  37. }