I am new to dependency injection, but happy with Ninject and Ninject.Extensions.Logging to [Inject] my ILogger wherever i need it.
However some DelegatingHandlers are spoiling all the fun.
public class HttpsHandler : DelegatingHandler
{
    [Inject]
    public ILogger Logger { get; set; }
    protected override Task<HttpResponseMessage> SendAsync(
            HttpRequestMessage request, CancellationToken cancellationToken)
        {
            if (!string.Equals(request.RequestUri.Scheme, "https", StringComparison.OrdinalIgnoreCase))
            {
                Logger.Info(String.Format("{0}: is using HTTP", request.RemoteAddress());
                return
                    Task.Factory.StartNew(
                        () =>
                        new HttpResponseMessage(HttpStatusCode.BadRequest)
                        {
                            Content = new StringContent("HTTPS Required")
                        });
            }
            return base.SendAsync(request, cancellationToken);
        }
 }
Could anyone point me in the right direction on how to Inject Ninject.Extensions.Logger.Nlog2 into Ilogger inside the delegatinghandlers?
Update
I think Pete got me in the right direction in the comments (thanks!).
I added the following constructor to the HttpsHandler:
public HttpsHandler()
        {
            var kernel = new StandardKernel();
            var logfactory = kernel.Get<ILoggerFactory>();
            this.Logger = logfactory.GetCurrentClassLogger();
        }
and now i've got the Logger working!
My only question left, is this the right way to do it, or is it a anti-pattern?
 
     
     
     
     
    