2010-10-15 00:10:44 -07:00
|
|
|
using System;
|
2011-07-03 17:19:05 -07:00
|
|
|
using System.Linq;
|
2011-05-30 00:05:45 -07:00
|
|
|
using System.Data.Common;
|
2011-03-29 23:18:35 -07:00
|
|
|
using System.Reflection;
|
2010-10-17 10:22:48 -07:00
|
|
|
using System.Threading;
|
2010-10-15 00:10:44 -07:00
|
|
|
using System.Web;
|
2011-04-21 19:23:31 -07:00
|
|
|
using System.Web.Caching;
|
2010-10-15 00:10:44 -07:00
|
|
|
using System.Web.Mvc;
|
2010-09-22 20:19:47 -07:00
|
|
|
using System.Web.Routing;
|
2011-06-13 18:35:44 -07:00
|
|
|
using MvcMiniProfiler;
|
2010-09-22 20:19:47 -07:00
|
|
|
using Ninject;
|
|
|
|
using Ninject.Web.Mvc;
|
2010-10-15 00:10:44 -07:00
|
|
|
using NLog;
|
2010-09-22 20:19:47 -07:00
|
|
|
using NzbDrone.Core;
|
2010-10-24 00:46:58 -07:00
|
|
|
using NzbDrone.Core.Instrumentation;
|
2011-06-22 23:56:17 -07:00
|
|
|
using Telerik.Web.Mvc;
|
2010-09-22 20:19:47 -07:00
|
|
|
|
|
|
|
namespace NzbDrone.Web
|
|
|
|
{
|
|
|
|
public class MvcApplication : NinjectHttpApplication
|
|
|
|
{
|
2010-10-17 10:22:48 -07:00
|
|
|
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
|
2010-09-22 20:19:47 -07:00
|
|
|
|
|
|
|
public static void RegisterRoutes(RouteCollection routes)
|
|
|
|
{
|
|
|
|
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
|
2011-04-18 17:12:06 -07:00
|
|
|
routes.IgnoreRoute("{*robotstxt}", new { robotstxt = @"(.*/)?robots.txt(/.*)?" });
|
|
|
|
routes.IgnoreRoute("{*favicon}", new { favicon = @"(.*/)?favicon.ico(/.*)?" });
|
2010-09-22 20:19:47 -07:00
|
|
|
|
2011-03-30 18:42:27 -07:00
|
|
|
|
2010-09-22 20:19:47 -07:00
|
|
|
routes.MapRoute(
|
2011-04-09 19:44:01 -07:00
|
|
|
"Default", // Route name
|
|
|
|
"{controller}/{action}/{id}", // URL with parameters
|
2011-04-18 17:12:06 -07:00
|
|
|
new { controller = "Series", action = "Index", id = UrlParameter.Optional } // Parameter defaults
|
2011-04-09 19:44:01 -07:00
|
|
|
);
|
2010-09-22 20:19:47 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
protected override void OnApplicationStarted()
|
|
|
|
{
|
2011-03-29 23:18:35 -07:00
|
|
|
base.OnApplicationStarted();
|
2011-06-22 23:56:17 -07:00
|
|
|
WebAssetDefaultSettings.UseTelerikContentDeliveryNetwork = true;
|
2010-09-22 20:19:47 -07:00
|
|
|
RegisterRoutes(RouteTable.Routes);
|
2011-03-29 23:18:35 -07:00
|
|
|
//base.OnApplicationStarted();
|
|
|
|
AreaRegistration.RegisterAllAreas();
|
2011-07-03 17:19:05 -07:00
|
|
|
|
|
|
|
var razor =ViewEngines.Engines.Where(e => e.GetType() == typeof (RazorViewEngine)).Single();
|
|
|
|
ViewEngines.Engines.Clear();
|
|
|
|
ViewEngines.Engines.Add(razor);
|
|
|
|
|
2011-03-29 23:18:35 -07:00
|
|
|
RegisterGlobalFilters(GlobalFilters.Filters);
|
2011-06-18 10:58:52 -07:00
|
|
|
|
|
|
|
Logger.Debug("Fully initialized and ready.");
|
2010-09-29 10:19:18 -07:00
|
|
|
}
|
2010-09-22 20:19:47 -07:00
|
|
|
|
|
|
|
protected override IKernel CreateKernel()
|
|
|
|
{
|
2011-06-12 20:45:22 -07:00
|
|
|
LogConfiguration.Setup();
|
|
|
|
Logger.Info("NZBDrone Starting up.");
|
|
|
|
CentralDispatch.DedicateToHost();
|
|
|
|
|
2010-10-24 00:46:58 -07:00
|
|
|
var kernel = CentralDispatch.NinjectKernel;
|
|
|
|
|
2011-03-29 23:18:35 -07:00
|
|
|
// kernel.Bind<IRepository>().ToConstant(kernel.Get<IRepository>("LogDb"));
|
|
|
|
kernel.Load(Assembly.GetExecutingAssembly());
|
2010-10-24 00:46:58 -07:00
|
|
|
return kernel;
|
2010-10-15 00:10:44 -07:00
|
|
|
}
|
2010-10-10 12:00:07 -07:00
|
|
|
|
2011-03-29 23:18:35 -07:00
|
|
|
|
|
|
|
public static void RegisterGlobalFilters(GlobalFilterCollection filters)
|
|
|
|
{
|
|
|
|
filters.Add(new HandleErrorAttribute());
|
|
|
|
}
|
|
|
|
|
2010-10-15 00:10:44 -07:00
|
|
|
// ReSharper disable InconsistentNaming
|
|
|
|
protected void Application_Error(object sender, EventArgs e)
|
|
|
|
{
|
2010-10-17 10:22:48 -07:00
|
|
|
var lastError = Server.GetLastError();
|
2011-04-21 19:23:31 -07:00
|
|
|
|
|
|
|
if (lastError is HttpException && lastError.InnerException == null)
|
2010-10-17 10:22:48 -07:00
|
|
|
{
|
2011-03-28 22:50:18 -07:00
|
|
|
Logger.WarnException(String.Format("{0}. URL[{1}]", lastError.Message, Request.Path), lastError);
|
2011-04-09 19:28:54 -07:00
|
|
|
return;
|
2010-10-17 10:22:48 -07:00
|
|
|
}
|
2011-04-09 19:28:54 -07:00
|
|
|
|
2011-04-18 17:12:06 -07:00
|
|
|
Logger.FatalException(lastError.Message + Environment.NewLine + Request.Url.PathAndQuery, lastError);
|
2011-04-09 19:28:54 -07:00
|
|
|
|
2011-05-30 00:05:45 -07:00
|
|
|
if (lastError is DbException)
|
2010-10-17 10:22:48 -07:00
|
|
|
{
|
2011-04-09 19:28:54 -07:00
|
|
|
Logger.Warn("Restarting application");
|
|
|
|
HttpRuntime.UnloadAppDomain();
|
2010-10-17 10:22:48 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void Application_BeginRequest()
|
|
|
|
{
|
|
|
|
Thread.CurrentThread.Name = "UI";
|
2011-06-13 18:35:44 -07:00
|
|
|
var miniprofiler = MiniProfiler.Start();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void Application_EndRequest()
|
|
|
|
{
|
|
|
|
MiniProfiler.Stop();
|
2010-09-22 20:19:47 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|