1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2024-12-12 11:15:43 +02:00
Sonarr/NzbDrone.Web/Global.asax.cs

92 lines
2.9 KiB
C#
Raw Normal View History

2010-10-15 10:10:44 +03:00
using System;
using System.Data.SQLite;
2011-03-30 09:18:35 +03:00
using System.Reflection;
using System.Threading;
2010-10-15 10:10:44 +03:00
using System.Web;
using System.Web.Mvc;
2010-09-23 06:19:47 +03:00
using System.Web.Routing;
using Ninject;
using Ninject.Web.Mvc;
2010-10-15 10:10:44 +03:00
using NLog;
2010-09-23 06:19:47 +03:00
using NzbDrone.Core;
using NzbDrone.Core.Instrumentation;
2010-09-23 06:19:47 +03:00
namespace NzbDrone.Web
{
public class MvcApplication : NinjectHttpApplication
{
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
2010-09-23 06:19:47 +03:00
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
2011-04-10 05:44:01 +03:00
routes.IgnoreRoute("{*robotstxt}", new {robotstxt = @"(.*/)?robots.txt(/.*)?"});
routes.IgnoreRoute("{*favicon}", new {favicon = @"(.*/)?favicon.ico(/.*)?"});
2010-09-23 06:19:47 +03:00
2010-09-23 06:19:47 +03:00
routes.MapRoute(
2011-04-10 05:44:01 +03:00
"Default", // Route name
"{controller}/{action}/{id}", // URL with parameters
new {controller = "Series", action = "Index", id = UrlParameter.Optional} // Parameter defaults
);
2010-09-23 06:19:47 +03:00
}
protected override void OnApplicationStarted()
{
2011-03-30 09:18:35 +03:00
base.OnApplicationStarted();
LogConfiguration.Setup();
Logger.Info("NZBDrone Starting up.");
CentralDispatch.DedicateToHost();
2011-03-30 09:18:35 +03:00
2010-09-23 06:19:47 +03:00
RegisterRoutes(RouteTable.Routes);
2011-03-30 09:18:35 +03:00
//base.OnApplicationStarted();
AreaRegistration.RegisterAllAreas();
RegisterGlobalFilters(GlobalFilters.Filters);
//RegisterRoutes(RouteTable.Routes);
2010-09-29 20:19:18 +03:00
}
2010-09-23 06:19:47 +03:00
protected override IKernel CreateKernel()
{
var kernel = CentralDispatch.NinjectKernel;
2011-03-30 09:18:35 +03:00
// kernel.Bind<IRepository>().ToConstant(kernel.Get<IRepository>("LogDb"));
kernel.Load(Assembly.GetExecutingAssembly());
return kernel;
2010-10-15 10:10:44 +03:00
}
2010-10-10 22:00:07 +03:00
2011-03-30 09:18:35 +03:00
public static void RegisterGlobalFilters(GlobalFilterCollection filters)
{
filters.Add(new HandleErrorAttribute());
}
2010-10-15 10:10:44 +03:00
// ReSharper disable InconsistentNaming
protected void Application_Error(object sender, EventArgs e)
{
var lastError = Server.GetLastError();
if (lastError is HttpException)
{
2011-03-29 08:50:18 +03:00
Logger.WarnException(String.Format("{0}. URL[{1}]", lastError.Message, Request.Path), lastError);
if (Request.Path.EndsWith(".aspx", StringComparison.InvariantCultureIgnoreCase))
{
Response.Redirect(Request.ApplicationPath);
}
return;
}
Logger.FatalException(lastError.Message, lastError);
if (lastError is SQLiteException)
{
Logger.Warn("Restarting application");
HttpRuntime.UnloadAppDomain();
}
}
protected void Application_BeginRequest()
{
Thread.CurrentThread.Name = "UI";
2010-09-23 06:19:47 +03:00
}
}
}