2013-02-19 07:20:51 +00:00
|
|
|
|
using System.Reflection;
|
|
|
|
|
using Autofac;
|
2013-01-03 01:09:13 +00:00
|
|
|
|
using NLog;
|
2013-02-19 01:13:42 +00:00
|
|
|
|
using NzbDrone.Api;
|
2011-10-23 05:26:43 +00:00
|
|
|
|
using NzbDrone.Common;
|
2013-02-19 01:13:42 +00:00
|
|
|
|
using NzbDrone.Core.Instrumentation;
|
2011-10-11 07:11:05 +00:00
|
|
|
|
|
|
|
|
|
namespace NzbDrone
|
|
|
|
|
{
|
2013-03-01 00:50:50 +00:00
|
|
|
|
public static class NzbDroneBootstrapper
|
2011-10-11 07:11:05 +00:00
|
|
|
|
{
|
2013-02-19 01:57:08 +00:00
|
|
|
|
private static readonly IContainer container;
|
2013-03-01 00:50:50 +00:00
|
|
|
|
private static readonly Logger logger = LogManager.GetLogger("NzbDroneBootstrapper");
|
2011-10-11 07:11:05 +00:00
|
|
|
|
|
2013-03-01 00:50:50 +00:00
|
|
|
|
static NzbDroneBootstrapper()
|
2011-10-11 07:11:05 +00:00
|
|
|
|
{
|
2013-01-03 01:09:13 +00:00
|
|
|
|
var builder = new ContainerBuilder();
|
|
|
|
|
BindKernel(builder);
|
2013-02-19 01:57:08 +00:00
|
|
|
|
container = builder.Build();
|
2013-02-28 06:59:08 +00:00
|
|
|
|
InitializeApp();
|
2011-10-11 07:11:05 +00:00
|
|
|
|
}
|
|
|
|
|
|
2013-01-03 01:09:13 +00:00
|
|
|
|
public static IContainer Container
|
2011-10-11 07:11:05 +00:00
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
2013-02-19 01:57:08 +00:00
|
|
|
|
return container;
|
2011-10-11 07:11:05 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2013-01-03 01:09:13 +00:00
|
|
|
|
private static void BindKernel(ContainerBuilder builder)
|
2011-10-11 07:11:05 +00:00
|
|
|
|
{
|
2013-02-19 01:13:42 +00:00
|
|
|
|
builder.RegisterModule<LogInjectionModule>();
|
|
|
|
|
|
2013-02-19 01:57:08 +00:00
|
|
|
|
builder.RegisterCommonServices();
|
|
|
|
|
builder.RegisterApiServices();
|
2013-02-19 07:20:51 +00:00
|
|
|
|
builder.RegisterAssemblyTypes(Assembly.GetExecutingAssembly());
|
2011-10-11 07:11:05 +00:00
|
|
|
|
}
|
|
|
|
|
|
2013-02-28 06:59:08 +00:00
|
|
|
|
private static void InitializeApp()
|
2011-10-11 07:11:05 +00:00
|
|
|
|
{
|
2013-02-19 01:57:08 +00:00
|
|
|
|
var environmentProvider = container.Resolve<EnvironmentProvider>();
|
|
|
|
|
|
|
|
|
|
ReportingService.RestProvider = container.Resolve<RestProvider>();
|
2012-01-23 02:24:16 +00:00
|
|
|
|
|
2013-02-19 01:57:08 +00:00
|
|
|
|
logger.Info("Start-up Path:'{0}'", environmentProvider.ApplicationPath);
|
2011-10-11 07:11:05 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|