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