1
0
Fork 0
mirror of https://github.com/Sonarr/Sonarr synced 2025-03-06 03:34:04 +00:00
Sonarr/NzbDrone/CentralDispatch.cs

62 lines
2.2 KiB
C#
Raw Normal View History

2013-01-02 17:09:13 -08:00
using Autofac;
using NLog;
using NzbDrone.Common;
2011-10-11 00:11:05 -07:00
using NzbDrone.Providers;
namespace NzbDrone
{
public static class CentralDispatch
{
2013-01-02 17:09:13 -08:00
private static IContainer _container;
private static readonly Logger Logger = LogManager.GetLogger("Host.CentralDispatch");
2011-10-11 00:11:05 -07:00
static CentralDispatch()
{
2013-01-02 17:09:13 -08:00
var builder = new ContainerBuilder();
BindKernel(builder);
_container = builder.Build();
2011-10-12 19:24:30 -07:00
InitilizeApp();
2011-10-11 00:11:05 -07:00
}
2013-01-02 17:09:13 -08:00
public static IContainer Container
2011-10-11 00:11:05 -07:00
{
get
{
2013-01-02 17:09:13 -08:00
return _container;
2011-10-11 00:11:05 -07:00
}
}
2013-01-02 17:09:13 -08:00
private static void BindKernel(ContainerBuilder builder)
2011-10-11 00:11:05 -07:00
{
2013-01-02 17:09:13 -08:00
builder.RegisterAssemblyTypes(typeof(DiskProvider).Assembly).SingleInstance();
2013-01-02 19:04:42 -08:00
builder.RegisterType<Router>();
2011-10-12 19:24:30 -07:00
2013-01-02 17:09:13 -08:00
builder.RegisterType<ApplicationServer>().SingleInstance();
builder.RegisterType<ConfigFileProvider>().SingleInstance();
builder.RegisterType<ConsoleProvider>().SingleInstance();
builder.RegisterType<DebuggerProvider>().SingleInstance();
builder.RegisterType<EnvironmentProvider>().SingleInstance();
builder.RegisterType<IISProvider>().SingleInstance();
builder.RegisterType<MonitoringProvider>().SingleInstance();
builder.RegisterType<ProcessProvider>().SingleInstance();
builder.RegisterType<ServiceProvider>().SingleInstance();
builder.RegisterType<HttpProvider>().SingleInstance();
2011-10-11 00:11:05 -07:00
}
private static void InitilizeApp()
{
2013-01-02 17:09:13 -08:00
var environmentProvider = _container.Resolve<EnvironmentProvider>();
2013-01-02 17:09:13 -08:00
ReportingService.RestProvider = _container.Resolve<RestProvider>();
2012-04-29 18:24:24 -07:00
ReportingService.SetupExceptronDriver();
2012-01-22 18:24:16 -08:00
LogConfiguration.RegisterRollingFileLogger(environmentProvider.GetLogFileName(), LogLevel.Info);
2011-10-23 22:54:09 -07:00
LogConfiguration.RegisterConsoleLogger(LogLevel.Debug);
LogConfiguration.RegisterUdpLogger();
LogConfiguration.RegisterRemote();
2011-11-12 23:27:16 -08:00
LogConfiguration.Reload();
Logger.Info("Start-up Path:'{0}'", environmentProvider.ApplicationPath);
2011-10-11 00:11:05 -07:00
}
}
}