2013-01-03 02:09:13 +01:00
|
|
|
|
using Autofac;
|
|
|
|
|
using NLog;
|
2011-10-23 07:26:43 +02:00
|
|
|
|
using NzbDrone.Common;
|
2011-10-11 09:11:05 +02:00
|
|
|
|
using NzbDrone.Providers;
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone
|
|
|
|
|
{
|
|
|
|
|
public static class CentralDispatch
|
|
|
|
|
{
|
2013-01-03 02:09:13 +01:00
|
|
|
|
private static IContainer _container;
|
2011-10-12 04:24:43 +02:00
|
|
|
|
private static readonly Logger Logger = LogManager.GetLogger("Host.CentralDispatch");
|
2011-10-11 09:11:05 +02:00
|
|
|
|
|
|
|
|
|
static CentralDispatch()
|
|
|
|
|
{
|
2013-01-03 02:09:13 +01:00
|
|
|
|
var builder = new ContainerBuilder();
|
|
|
|
|
BindKernel(builder);
|
|
|
|
|
_container = builder.Build();
|
2011-10-13 04:24:30 +02:00
|
|
|
|
InitilizeApp();
|
2011-10-11 09:11:05 +02:00
|
|
|
|
}
|
|
|
|
|
|
2013-01-03 02:09:13 +01:00
|
|
|
|
public static IContainer Container
|
2011-10-11 09:11:05 +02:00
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
2013-01-03 02:09:13 +01:00
|
|
|
|
return _container;
|
2011-10-11 09:11:05 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2013-01-03 02:09:13 +01:00
|
|
|
|
private static void BindKernel(ContainerBuilder builder)
|
2011-10-11 09:11:05 +02:00
|
|
|
|
{
|
2013-01-03 02:09:13 +01:00
|
|
|
|
builder.RegisterAssemblyTypes(typeof(DiskProvider).Assembly).SingleInstance();
|
2013-01-03 04:04:42 +01:00
|
|
|
|
builder.RegisterType<Router>();
|
2011-10-13 04:24:30 +02:00
|
|
|
|
|
2013-01-03 02:09:13 +01: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 09:11:05 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void InitilizeApp()
|
|
|
|
|
{
|
2013-01-03 02:09:13 +01:00
|
|
|
|
var environmentProvider = _container.Resolve<EnvironmentProvider>();
|
2012-03-02 02:57:36 +01:00
|
|
|
|
|
2013-01-03 02:09:13 +01:00
|
|
|
|
ReportingService.RestProvider = _container.Resolve<RestProvider>();
|
2012-04-30 03:24:24 +02:00
|
|
|
|
ReportingService.SetupExceptronDriver();
|
2012-01-23 03:24:16 +01:00
|
|
|
|
|
2012-03-07 03:59:43 +01:00
|
|
|
|
LogConfiguration.RegisterRollingFileLogger(environmentProvider.GetLogFileName(), LogLevel.Info);
|
2011-10-24 07:54:09 +02:00
|
|
|
|
LogConfiguration.RegisterConsoleLogger(LogLevel.Debug);
|
|
|
|
|
LogConfiguration.RegisterUdpLogger();
|
2012-02-05 07:34:36 +01:00
|
|
|
|
LogConfiguration.RegisterRemote();
|
2011-11-13 08:27:16 +01:00
|
|
|
|
LogConfiguration.Reload();
|
2012-03-07 03:59:43 +01:00
|
|
|
|
Logger.Info("Start-up Path:'{0}'", environmentProvider.ApplicationPath);
|
2011-10-11 09:11:05 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|