60 lines
1.5 KiB
C#
60 lines
1.5 KiB
C#
// /**
|
|
// * File: LoggingRouter.cs
|
|
// * Author: haraldwolff
|
|
// *
|
|
// * This file and it's content is copyrighted by the Author and / or copyright holder.
|
|
// * Any use wihtout proper permission is illegal and may lead to legal actions.
|
|
// *
|
|
// *
|
|
// **/
|
|
using System;
|
|
using ln.logging;
|
|
using System.Diagnostics;
|
|
namespace ln.http.router
|
|
{
|
|
public class LoggingRouter : IHttpRouter
|
|
{
|
|
IHttpRouter Next { get; }
|
|
Logger Logger { get; }
|
|
|
|
public LoggingRouter(IHttpRouter next)
|
|
:this(next, Logger.Default)
|
|
{}
|
|
public LoggingRouter(IHttpRouter next,Logger logger)
|
|
{
|
|
Next = next;
|
|
Logger = logger;
|
|
}
|
|
|
|
public HttpResponse Route(HttpRoutingContext routingContext, HttpRequest httpRequest)
|
|
{
|
|
DateTime start = DateTime.Now;
|
|
HttpResponse response = null;
|
|
|
|
try
|
|
{
|
|
response = Next.Route(routingContext, httpRequest);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
throw;
|
|
}
|
|
finally
|
|
{
|
|
DateTime end = DateTime.Now;
|
|
TimeSpan duration = end - start;
|
|
|
|
Logger.Log(LogLevel.INFO, "{0} {1} {2} {3} {4}",
|
|
start,
|
|
duration,
|
|
response?.StatusCode.ToString() ?? "-",
|
|
httpRequest.Method,
|
|
httpRequest.RequestURL
|
|
);
|
|
}
|
|
|
|
return response;
|
|
}
|
|
}
|
|
}
|