2012-01-23 05:24:16 +03:00
|
|
|
using System.IO;
|
|
|
|
using NLog;
|
2011-10-11 10:11:05 +03:00
|
|
|
using Ninject;
|
2011-10-23 08:26:43 +03:00
|
|
|
using NzbDrone.Common;
|
2011-10-11 10:11:05 +03:00
|
|
|
using NzbDrone.Providers;
|
|
|
|
|
|
|
|
namespace NzbDrone
|
|
|
|
{
|
|
|
|
public static class CentralDispatch
|
|
|
|
{
|
|
|
|
private static StandardKernel _kernel;
|
2011-10-12 05:24:43 +03:00
|
|
|
private static readonly Logger Logger = LogManager.GetLogger("Host.CentralDispatch");
|
2011-10-11 10:11:05 +03:00
|
|
|
|
|
|
|
static CentralDispatch()
|
|
|
|
{
|
|
|
|
_kernel = new StandardKernel();
|
2011-10-13 05:24:30 +03:00
|
|
|
BindKernel();
|
|
|
|
InitilizeApp();
|
2011-10-11 10:11:05 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public static StandardKernel Kernel
|
|
|
|
{
|
|
|
|
get
|
|
|
|
{
|
|
|
|
return _kernel;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void BindKernel()
|
|
|
|
{
|
|
|
|
_kernel = new StandardKernel();
|
2011-10-13 05:24:30 +03:00
|
|
|
_kernel.Bind<ApplicationServer>().ToSelf().InSingletonScope();
|
2011-11-13 10:27:16 +03:00
|
|
|
_kernel.Bind<ConfigFileProvider>().ToSelf().InSingletonScope();
|
2011-10-11 10:11:05 +03:00
|
|
|
_kernel.Bind<ConsoleProvider>().ToSelf().InSingletonScope();
|
|
|
|
_kernel.Bind<DebuggerProvider>().ToSelf().InSingletonScope();
|
|
|
|
_kernel.Bind<EnviromentProvider>().ToSelf().InSingletonScope();
|
|
|
|
_kernel.Bind<IISProvider>().ToSelf().InSingletonScope();
|
|
|
|
_kernel.Bind<MonitoringProvider>().ToSelf().InSingletonScope();
|
|
|
|
_kernel.Bind<ProcessProvider>().ToSelf().InSingletonScope();
|
|
|
|
_kernel.Bind<ServiceProvider>().ToSelf().InSingletonScope();
|
|
|
|
_kernel.Bind<WebClientProvider>().ToSelf().InSingletonScope();
|
2011-10-13 05:24:30 +03:00
|
|
|
|
2011-10-11 10:11:05 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
private static void InitilizeApp()
|
|
|
|
{
|
2012-01-23 05:24:16 +03:00
|
|
|
var enviromentProvider = _kernel.Get<EnviromentProvider>();
|
|
|
|
|
|
|
|
LogConfiguration.RegisterRollingFileLogger(enviromentProvider.GetLogFileName(), LogLevel.Info);
|
2011-10-24 08:54:09 +03:00
|
|
|
LogConfiguration.RegisterConsoleLogger(LogLevel.Debug);
|
|
|
|
LogConfiguration.RegisterUdpLogger();
|
2011-11-13 10:27:16 +03:00
|
|
|
LogConfiguration.RegisterExceptioneer();
|
|
|
|
LogConfiguration.Reload();
|
2012-01-23 05:24:16 +03:00
|
|
|
Logger.Info("Start-up Path:'{0}'", enviromentProvider.ApplicationPath);
|
2011-10-11 10:11:05 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|