Radarr/NzbDrone.Api/NancyBootstrapper.cs

95 lines
3.1 KiB
C#
Raw Normal View History

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;
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;
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-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
{
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);
var processors = ApplicationContainer.Resolve<IProcessStaticResource>();
Conventions.StaticContentsConventions.Add(processors.ProcessStaticResourceRequest);
2013-02-19 01:13:42 +00:00
}
}
}