LoggerUtils.cs 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. using MediaBrowser.Model.Logging;
  2. using System;
  3. using System.Net;
  4. using System.Text;
  5. namespace MediaBrowser.Server.Implementations.HttpServer
  6. {
  7. public static class LoggerUtils
  8. {
  9. /// <summary>
  10. /// Logs the request.
  11. /// </summary>
  12. /// <param name="logger">The logger.</param>
  13. /// <param name="request">The request.</param>
  14. public static void LogRequest(ILogger logger, HttpListenerRequest request)
  15. {
  16. var log = new StringBuilder();
  17. //var headers = string.Join(",", request.Headers.AllKeys.Where(i => !string.Equals(i, "cookie", StringComparison.OrdinalIgnoreCase) && !string.Equals(i, "Referer", StringComparison.OrdinalIgnoreCase)).Select(k => k + "=" + request.Headers[k]));
  18. //log.AppendLine("Ip: " + request.RemoteEndPoint + ". Headers: " + headers);
  19. var type = request.IsWebSocketRequest ? "Web Socket" : "HTTP " + request.HttpMethod;
  20. logger.LogMultiline(type + " " + request.Url, LogSeverity.Debug, log);
  21. }
  22. /// <summary>
  23. /// Logs the response.
  24. /// </summary>
  25. /// <param name="logger">The logger.</param>
  26. /// <param name="statusCode">The status code.</param>
  27. /// <param name="url">The URL.</param>
  28. /// <param name="endPoint">The end point.</param>
  29. /// <param name="duration">The duration.</param>
  30. public static void LogResponse(ILogger logger, int statusCode, string url, string endPoint, TimeSpan duration)
  31. {
  32. var log = new StringBuilder();
  33. log.AppendLine(string.Format("Url: {0}", url));
  34. //log.AppendLine("Headers: " + string.Join(",", response.Headers.AllKeys.Select(k => k + "=" + response.Headers[k])));
  35. var responseTime = string.Format(". Response time: {0} ms.", duration.TotalMilliseconds);
  36. var msg = "HTTP Response " + statusCode + " to " + endPoint + responseTime;
  37. logger.LogMultiline(msg, LogSeverity.Debug, log);
  38. }
  39. }
  40. }