jellyfin/MediaBrowser.Server.Implementations/HttpServer/LoggerUtils.cs

57 lines
2.3 KiB
C#
Raw Normal View History

2014-06-28 12:35:30 -07:00
using System.Globalization;
using MediaBrowser.Model.Logging;
2013-12-07 08:52:38 -07:00
using System;
using System.Linq;
using System.Net;
using System.Text;
namespace MediaBrowser.Server.Implementations.HttpServer
{
public static class LoggerUtils
{
2014-01-22 15:38:48 -07:00
/// <summary>
/// Logs the request.
/// </summary>
/// <param name="logger">The logger.</param>
/// <param name="request">The request.</param>
/// <param name="workerIndex">Index of the worker.</param>
public static void LogRequest(ILogger logger, HttpListenerRequest request, int workerIndex)
2013-12-07 08:52:38 -07:00
{
var log = new StringBuilder();
2014-01-30 14:23:54 -07:00
//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]));
2014-01-29 14:54:40 -07:00
2014-01-30 14:23:54 -07:00
//log.AppendLine("Ip: " + request.RemoteEndPoint + ". Headers: " + headers);
2013-12-07 08:52:38 -07:00
2014-01-22 15:38:48 -07:00
var type = request.IsWebSocketRequest ? "Web Socket" : "HTTP " + request.HttpMethod;
2013-12-07 08:52:38 -07:00
2014-01-22 15:38:48 -07:00
logger.LogMultiline(type + " " + request.Url, LogSeverity.Debug, log);
2013-12-07 08:52:38 -07:00
}
/// <summary>
/// Logs the response.
/// </summary>
/// <param name="logger">The logger.</param>
2014-01-22 15:38:48 -07:00
/// <param name="response">The response.</param>
2013-12-07 08:52:38 -07:00
/// <param name="url">The URL.</param>
/// <param name="endPoint">The end point.</param>
/// <param name="duration">The duration.</param>
2014-01-22 15:38:48 -07:00
public static void LogResponse(ILogger logger, HttpListenerResponse response, string url, IPEndPoint endPoint, TimeSpan duration)
2013-12-07 08:52:38 -07:00
{
2014-01-22 15:38:48 -07:00
var statusCode = response.StatusCode;
2013-12-07 08:52:38 -07:00
var log = new StringBuilder();
log.AppendLine(string.Format("Url: {0}", url));
2014-01-30 14:23:54 -07:00
//log.AppendLine("Headers: " + string.Join(",", response.Headers.AllKeys.Select(k => k + "=" + response.Headers[k])));
2013-12-07 08:52:38 -07:00
2014-06-28 12:35:30 -07:00
var responseTime = string.Format(". Response time: {0} ms. Content length: {1} bytes.", duration.TotalMilliseconds, response.ContentLength64.ToString(CultureInfo.InvariantCulture));
2013-12-07 08:52:38 -07:00
2014-01-22 15:38:48 -07:00
var msg = "HTTP Response " + statusCode + " to " + endPoint + responseTime;
2013-12-07 08:52:38 -07:00
logger.LogMultiline(msg, LogSeverity.Debug, log);
}
}
}