2013-09-12 15:42:01 -07:00
|
|
|
using NLog;
|
2013-02-18 17:13:42 -08:00
|
|
|
using Nancy.Bootstrapper;
|
|
|
|
using Nancy.Diagnostics;
|
|
|
|
using NzbDrone.Api.ErrorManagement;
|
2013-08-19 22:53:18 -07:00
|
|
|
using NzbDrone.Api.Extensions.Pipelines;
|
2014-02-07 18:21:44 -08:00
|
|
|
using NzbDrone.Common.EnvironmentInfo;
|
2013-08-30 18:42:30 -07:00
|
|
|
using NzbDrone.Common.Instrumentation;
|
2013-05-20 20:20:29 -07:00
|
|
|
using NzbDrone.Core.Instrumentation;
|
2013-02-18 17:13:42 -08:00
|
|
|
using NzbDrone.Core.Lifecycle;
|
2013-09-13 23:36:07 -07:00
|
|
|
using NzbDrone.Core.Messaging.Events;
|
2013-04-02 19:20:05 -07:00
|
|
|
using TinyIoC;
|
2013-02-18 17:13:42 -08:00
|
|
|
|
|
|
|
namespace NzbDrone.Api
|
|
|
|
{
|
2013-04-18 21:46:18 -07:00
|
|
|
public class NancyBootstrapper : TinyIoCNancyBootstrapper
|
2013-02-18 17:13:42 -08:00
|
|
|
{
|
2013-04-02 19:20:05 -07:00
|
|
|
private readonly TinyIoCContainer _tinyIoCContainer;
|
2014-12-16 23:12:26 -08:00
|
|
|
private static readonly Logger Logger = NzbDroneLogger.GetLogger(typeof(NancyBootstrapper));
|
2013-02-18 17:13:42 -08:00
|
|
|
|
2013-04-18 21:46:18 -07:00
|
|
|
public NancyBootstrapper(TinyIoCContainer tinyIoCContainer)
|
2013-02-18 17:13:42 -08:00
|
|
|
{
|
2013-04-02 19:20:05 -07:00
|
|
|
_tinyIoCContainer = tinyIoCContainer;
|
2013-02-18 17:13:42 -08:00
|
|
|
}
|
|
|
|
|
2013-04-02 19:20:05 -07:00
|
|
|
protected override void ApplicationStartup(TinyIoCContainer container, IPipelines pipelines)
|
2013-02-18 17:13:42 -08:00
|
|
|
{
|
2014-12-16 23:12:26 -08:00
|
|
|
Logger.Info("Starting NzbDrone API");
|
2013-04-09 17:47:04 -07:00
|
|
|
|
2014-07-29 23:23:43 -07:00
|
|
|
if (RuntimeInfoBase.IsProduction)
|
2014-02-07 18:21:44 -08:00
|
|
|
{
|
|
|
|
DiagnosticsHook.Disable(pipelines);
|
|
|
|
}
|
|
|
|
|
2013-08-19 22:53:18 -07:00
|
|
|
RegisterPipelines(pipelines);
|
|
|
|
|
2013-05-20 20:20:29 -07:00
|
|
|
container.Resolve<DatabaseTarget>().Register();
|
2013-09-13 23:36:07 -07:00
|
|
|
container.Resolve<IEventAggregator>().PublishEvent(new ApplicationStartedEvent());
|
2013-05-21 21:06:25 -07:00
|
|
|
|
2013-05-10 16:53:50 -07:00
|
|
|
ApplicationPipelines.OnError.AddItemToEndOfPipeline(container.Resolve<NzbDroneErrorPipeline>().HandleException);
|
2013-02-18 17:13:42 -08:00
|
|
|
}
|
|
|
|
|
2013-08-19 22:53:18 -07:00
|
|
|
private void RegisterPipelines(IPipelines pipelines)
|
|
|
|
{
|
|
|
|
var pipelineRegistrars = _tinyIoCContainer.ResolveAll<IRegisterNancyPipeline>();
|
|
|
|
|
|
|
|
foreach (var registerNancyPipeline in pipelineRegistrars)
|
|
|
|
{
|
|
|
|
registerNancyPipeline.Register(pipelines);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-04-02 19:20:05 -07:00
|
|
|
protected override TinyIoCContainer GetApplicationContainer()
|
2013-02-18 17:13:42 -08:00
|
|
|
{
|
2013-04-02 19:20:05 -07:00
|
|
|
return _tinyIoCContainer;
|
2013-02-18 17:13:42 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
protected override DiagnosticsConfiguration DiagnosticsConfiguration
|
|
|
|
{
|
|
|
|
get { return new DiagnosticsConfiguration { Password = @"password" }; }
|
|
|
|
}
|
|
|
|
|
2013-07-06 15:46:11 -07:00
|
|
|
protected override byte[] FavIcon
|
|
|
|
{
|
|
|
|
get
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
2013-02-18 17:13:42 -08:00
|
|
|
}
|
|
|
|
}
|