|
|
@ -8,39 +8,44 @@ namespace MediaBrowser.Server.Implementations.HttpServer
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public static class LoggerUtils
|
|
|
|
public static class LoggerUtils
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public static void LogRequest(ILogger logger, HttpListenerContext ctx, int workerIndex)
|
|
|
|
/// <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)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var log = new StringBuilder();
|
|
|
|
var log = new StringBuilder();
|
|
|
|
|
|
|
|
|
|
|
|
log.AppendLine("Url: " + ctx.Request.Url);
|
|
|
|
log.AppendLine("Ip: " + request.RemoteEndPoint + ". Headers: " + string.Join(",", request.Headers.AllKeys.Select(k => k + "=" + request.Headers[k])));
|
|
|
|
log.AppendLine("Headers: " + string.Join(",", ctx.Request.Headers.AllKeys.Select(k => k + "=" + ctx.Request.Headers[k])));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var type = ctx.Request.IsWebSocketRequest ? "Web Socket" : "HTTP " + ctx.Request.HttpMethod;
|
|
|
|
var type = request.IsWebSocketRequest ? "Web Socket" : "HTTP " + request.HttpMethod;
|
|
|
|
|
|
|
|
|
|
|
|
logger.LogMultiline(type + " request received on worker " + workerIndex + " from " + ctx.Request.RemoteEndPoint, LogSeverity.Debug, log);
|
|
|
|
logger.LogMultiline(type + " " + request.Url, LogSeverity.Debug, log);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// <summary>
|
|
|
|
/// Logs the response.
|
|
|
|
/// Logs the response.
|
|
|
|
/// </summary>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="logger">The logger.</param>
|
|
|
|
/// <param name="logger">The logger.</param>
|
|
|
|
/// <param name="ctx">The CTX.</param>
|
|
|
|
/// <param name="response">The response.</param>
|
|
|
|
/// <param name="url">The URL.</param>
|
|
|
|
/// <param name="url">The URL.</param>
|
|
|
|
/// <param name="endPoint">The end point.</param>
|
|
|
|
/// <param name="endPoint">The end point.</param>
|
|
|
|
/// <param name="duration">The duration.</param>
|
|
|
|
/// <param name="duration">The duration.</param>
|
|
|
|
public static void LogResponse(ILogger logger, HttpListenerContext ctx, string url, IPEndPoint endPoint, TimeSpan duration)
|
|
|
|
public static void LogResponse(ILogger logger, HttpListenerResponse response, string url, IPEndPoint endPoint, TimeSpan duration)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var statusCode = ctx.Response.StatusCode;
|
|
|
|
var statusCode = response.StatusCode;
|
|
|
|
|
|
|
|
|
|
|
|
var log = new StringBuilder();
|
|
|
|
var log = new StringBuilder();
|
|
|
|
|
|
|
|
|
|
|
|
log.AppendLine(string.Format("Url: {0}", url));
|
|
|
|
log.AppendLine(string.Format("Url: {0}", url));
|
|
|
|
|
|
|
|
|
|
|
|
log.AppendLine("Headers: " + string.Join(",", ctx.Response.Headers.AllKeys.Select(k => k + "=" + ctx.Response.Headers[k])));
|
|
|
|
log.AppendLine("Headers: " + string.Join(",", response.Headers.AllKeys.Select(k => k + "=" + response.Headers[k])));
|
|
|
|
|
|
|
|
|
|
|
|
var responseTime = string.Format(". Response time: {0} ms", duration.TotalMilliseconds);
|
|
|
|
var responseTime = string.Format(". Response time: {0} ms", duration.TotalMilliseconds);
|
|
|
|
|
|
|
|
|
|
|
|
var msg = "Response code " + statusCode + " sent to " + endPoint + responseTime;
|
|
|
|
var msg = "HTTP Response " + statusCode + " to " + endPoint + responseTime;
|
|
|
|
|
|
|
|
|
|
|
|
logger.LogMultiline(msg, LogSeverity.Debug, log);
|
|
|
|
logger.LogMultiline(msg, LogSeverity.Debug, log);
|
|
|
|
}
|
|
|
|
}
|
|
|
|