2013-02-19 01:13:42 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using NLog;
|
|
|
|
|
using Nancy.Bootstrapper;
|
|
|
|
|
using Nancy.Conventions;
|
|
|
|
|
using Nancy.Diagnostics;
|
|
|
|
|
using NzbDrone.Api.ErrorManagement;
|
2013-02-23 20:35:26 +00:00
|
|
|
|
using NzbDrone.Api.Extensions;
|
2013-03-29 23:00:38 +00:00
|
|
|
|
using NzbDrone.Api.Frontend;
|
2013-02-19 01:13:42 +00:00
|
|
|
|
using NzbDrone.Common;
|
2013-02-24 06:48:52 +00:00
|
|
|
|
using NzbDrone.Core.Configuration;
|
2013-02-19 01:13:42 +00:00
|
|
|
|
using NzbDrone.Core.Lifecycle;
|
2013-04-03 02:20:05 +00:00
|
|
|
|
using TinyIoC;
|
2013-03-29 23:00:38 +00:00
|
|
|
|
using ErrorPipeline = NzbDrone.Api.ErrorManagement.ErrorPipeline;
|
2013-02-19 01:13:42 +00:00
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Api
|
|
|
|
|
{
|
2013-04-03 02:20:05 +00:00
|
|
|
|
public class TinyNancyBootstrapper : TinyIoCNancyBootstrapper
|
2013-02-19 01:13:42 +00:00
|
|
|
|
{
|
2013-04-03 02:20:05 +00:00
|
|
|
|
private readonly TinyIoCContainer _tinyIoCContainer;
|
2013-02-19 01:13:42 +00:00
|
|
|
|
private readonly Logger _logger;
|
|
|
|
|
|
2013-04-03 02:20:05 +00:00
|
|
|
|
public TinyNancyBootstrapper(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
|
|
|
|
_logger = LogManager.GetCurrentClassLogger();
|
|
|
|
|
}
|
|
|
|
|
|
2013-04-03 02:20:05 +00:00
|
|
|
|
protected override void ApplicationStartup(TinyIoCContainer container, IPipelines pipelines)
|
2013-02-19 01:13:42 +00:00
|
|
|
|
{
|
|
|
|
|
_logger.Info("Starting NzbDrone API");
|
|
|
|
|
AutomapperBootstraper.InitializeAutomapper();
|
|
|
|
|
RegisterReporting(container);
|
|
|
|
|
KickoffInitilizables(container);
|
2013-03-29 23:00:38 +00:00
|
|
|
|
|
2013-02-19 01:13:42 +00:00
|
|
|
|
ApplicationPipelines.OnError.AddItemToEndOfPipeline(container.Resolve<ErrorPipeline>().HandleException);
|
|
|
|
|
}
|
|
|
|
|
|
2013-04-03 02:20:05 +00:00
|
|
|
|
private void RegisterReporting(TinyIoCContainer container)
|
|
|
|
|
{
|
|
|
|
|
EnvironmentProvider.UGuid = container.Resolve<ConfigService>().UGuid;
|
|
|
|
|
ReportingService.RestProvider = container.Resolve<RestProvider>();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void KickoffInitilizables(TinyIoCContainer container)
|
2013-02-19 01:13:42 +00:00
|
|
|
|
{
|
2013-04-06 01:03:14 +00:00
|
|
|
|
var initilizables = container.ResolveAll<IInitializable>();
|
2013-02-19 01:13:42 +00:00
|
|
|
|
|
|
|
|
|
foreach (var initializable in initilizables)
|
|
|
|
|
{
|
|
|
|
|
_logger.Debug("Initializing {0}", initializable.GetType().Name);
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
initializable.Init();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
{
|
|
|
|
|
_logger.FatalException("An error occurred while initializing " + initializable.GetType().Name, e);
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
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 NancyInternalConfiguration InternalConfiguration
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
var internalConfig = NancyInternalConfiguration.Default;
|
|
|
|
|
|
|
|
|
|
internalConfig.StatusCodeHandlers.Add(typeof(ErrorHandler));
|
|
|
|
|
internalConfig.Serializers.Add(typeof(NancyJsonSerializer));
|
|
|
|
|
|
|
|
|
|
return internalConfig;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected override DiagnosticsConfiguration DiagnosticsConfiguration
|
|
|
|
|
{
|
|
|
|
|
get { return new DiagnosticsConfiguration { Password = @"password" }; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected override void ConfigureConventions(NancyConventions nancyConventions)
|
|
|
|
|
{
|
|
|
|
|
base.ConfigureConventions(nancyConventions);
|
2013-03-29 23:00:38 +00:00
|
|
|
|
var processors = ApplicationContainer.Resolve<IProcessStaticResource>();
|
|
|
|
|
Conventions.StaticContentsConventions.Add(processors.ProcessStaticResourceRequest);
|
2013-02-19 01:13:42 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|