LoggerUtils.cs 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. using System.Globalization;
  2. using MediaBrowser.Model.Logging;
  3. using System;
  4. using System.Linq;
  5. using System.Net;
  6. using System.Text;
  7. namespace MediaBrowser.Server.Implementations.HttpServer
  8. {
  9. public static class LoggerUtils
  10. {
  11. /// <summary>
  12. /// Logs the request.
  13. /// </summary>
  14. /// <param name="logger">The logger.</param>
  15. /// <param name="request">The request.</param>
  16. /// <param name="workerIndex">Index of the worker.</param>
  17. public static void LogRequest(ILogger logger, HttpListenerRequest request, int workerIndex)
  18. {
  19. var log = new StringBuilder();
  20. //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]));
  21. //log.AppendLine("Ip: " + request.RemoteEndPoint + ". Headers: " + headers);
  22. var type = request.IsWebSocketRequest ? "Web Socket" : "HTTP " + request.HttpMethod;
  23. logger.LogMultiline(type + " " + request.Url, LogSeverity.Debug, log);
  24. }
  25. /// <summary>
  26. /// Logs the response.
  27. /// </summary>
  28. /// <param name="logger">The logger.</param>
  29. /// <param name="response">The response.</param>
  30. /// <param name="url">The URL.</param>
  31. /// <param name="endPoint">The end point.</param>
  32. /// <param name="duration">The duration.</param>
  33. public static void LogResponse(ILogger logger, HttpListenerResponse response, string url, IPEndPoint endPoint, TimeSpan duration)
  34. {
  35. var statusCode = response.StatusCode;
  36. var log = new StringBuilder();
  37. log.AppendLine(string.Format("Url: {0}", url));
  38. //log.AppendLine("Headers: " + string.Join(",", response.Headers.AllKeys.Select(k => k + "=" + response.Headers[k])));
  39. var responseTime = string.Format(". Response time: {0} ms. Content length: {1} bytes.", duration.TotalMilliseconds, response.ContentLength64.ToString(CultureInfo.InvariantCulture));
  40. var msg = "HTTP Response " + statusCode + " to " + endPoint + responseTime;
  41. logger.LogMultiline(msg, LogSeverity.Debug, log);
  42. }
  43. }
  44. }