using System.Web; using System.Web.Mvc; using System.Linq; using MvcMiniProfiler; using MvcMiniProfiler.MVCHelpers; using Microsoft.Web.Infrastructure.DynamicModuleHelper; using NzbDrone.Common; using NzbDrone.Web.Helpers; //using System.Data; //using System.Data.Entity; //using System.Data.Entity.Infrastructure; //using MvcMiniProfiler.Data.Linq2Sql; [assembly: WebActivator.PreApplicationStartMethod(typeof(NzbDrone.Web.App_Start.MiniProfilerPackage), "PreStart")] [assembly: WebActivator.PostApplicationStartMethod(typeof(NzbDrone.Web.App_Start.MiniProfilerPackage), "PostStart")] namespace NzbDrone.Web.App_Start { public static class MiniProfilerPackage { public static void PreStart() { // Be sure to restart you ASP.NET Developement server, this code will not run until you do that. //TODO: See - _MINIPROFILER UPDATED Layout.cshtml // For profiling to display in the UI you will have to include the line @MvcMiniProfiler.MiniProfiler.RenderIncludes() // in your master layout //TODO: Non SQL Server based installs can use other formatters like: new MvcMiniProfiler.SqlFormatters.InlineFormatter() MiniProfiler.Settings.SqlFormatter = new MvcMiniProfiler.SqlFormatters.SqlServerFormatter(); //TODO: To profile a standard DbConnection: // var profiled = new ProfiledDbConnection(cnn, MiniProfiler.Current); //TODO: If you are profiling EF code first try: // MiniProfilerEF.Initialize(); //Make sure the MiniProfiler handles BeginRequest and EndRequest DynamicModuleUtility.RegisterModule(typeof(MiniProfilerStartupModule)); //Setup profiler for Controllers via a Global ActionFilter GlobalFilters.Filters.Add(new ProfilingActionFilter()); } public static void PostStart() { // Intercept ViewEngines to profile all partial views and regular views. // If you prefer to insert your profiling blocks manually you can comment this out var copy = ViewEngines.Engines.ToList(); ViewEngines.Engines.Clear(); foreach (var item in copy) { ViewEngines.Engines.Add(new ProfilingViewEngine(item)); } } } public class MiniProfilerStartupModule : IHttpModule { public void Init(HttpApplication context) { context.BeginRequest += (sender, e) => { //var request = ((HttpApplication)sender).Request; //TODO: By default only local requests are profiled, optionally you can set it up // so authenticated users are always profiled //if (request.IsLocal) { MiniProfiler.Start(); } if (!EnviromentProvider.IsProduction || ProfilerHelper.Enabled()) { MiniProfiler.Start(); } }; // TODO: You can control who sees the profiling information /* context.AuthenticateRequest += (sender, e) => { if (!CurrentUserIsAllowedToSeeProfiler()) { MvcMiniProfiler.MiniProfiler.Stop(discardResults: true); } }; */ context.EndRequest += (sender, e) => MiniProfiler.Stop(); } public void Dispose() { } } }