|
|
|
@ -1,4 +1,7 @@
|
|
|
|
|
using System.Reflection;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Reflection;
|
|
|
|
|
using System.Threading;
|
|
|
|
|
using NLog;
|
|
|
|
|
using NzbDrone.Common.Composition;
|
|
|
|
|
using NzbDrone.Common.EnvironmentInfo;
|
|
|
|
|
using NzbDrone.Common.Instrumentation;
|
|
|
|
@ -7,40 +10,123 @@ using NzbDrone.Core.Datastore;
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Host
|
|
|
|
|
{
|
|
|
|
|
public class Bootstrap
|
|
|
|
|
public static class Bootstrap
|
|
|
|
|
{
|
|
|
|
|
public IContainer Container { get; private set; }
|
|
|
|
|
private static IContainer _container;
|
|
|
|
|
private static readonly Logger Logger = NzbDroneLogger.GetLogger();
|
|
|
|
|
|
|
|
|
|
public Bootstrap(StartupArguments args, IUserAlert userAlert)
|
|
|
|
|
|
|
|
|
|
public static void Start(StartupContext startupContext, IUserAlert userAlert, Action<IContainer> startCallback = null)
|
|
|
|
|
{
|
|
|
|
|
var logger = NzbDroneLogger.GetLogger();
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
GlobalExceptionHandlers.Register();
|
|
|
|
|
IgnoreCertErrorPolicy.Register();
|
|
|
|
|
|
|
|
|
|
Logger.Info("Starting NzbDrone Console. Version {0}", Assembly.GetExecutingAssembly().GetName().Version);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!PlatformValidation.IsValidate(userAlert))
|
|
|
|
|
{
|
|
|
|
|
throw new TerminateApplicationException("Missing system requirements");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
GlobalExceptionHandlers.Register();
|
|
|
|
|
IgnoreCertErrorPolicy.Register();
|
|
|
|
|
_container = MainAppContainerBuilder.BuildContainer(startupContext);
|
|
|
|
|
|
|
|
|
|
logger.Info("Starting NzbDrone Console. Version {0}", Assembly.GetExecutingAssembly().GetName().Version);
|
|
|
|
|
var appMode = GetApplicationMode(startupContext);
|
|
|
|
|
|
|
|
|
|
Start(appMode);
|
|
|
|
|
|
|
|
|
|
if (!PlatformValidation.IsValidate(userAlert))
|
|
|
|
|
if (startCallback != null)
|
|
|
|
|
{
|
|
|
|
|
startCallback(_container);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SpinToExit(appMode);
|
|
|
|
|
}
|
|
|
|
|
catch (TerminateApplicationException e)
|
|
|
|
|
{
|
|
|
|
|
throw new TerminateApplicationException("Missing system requirements");
|
|
|
|
|
Logger.Info("Application has been terminated. Reason " + e.Reason);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Container = MainAppContainerBuilder.BuildContainer(args);
|
|
|
|
|
|
|
|
|
|
private static void Start(ApplicationModes applicationModes)
|
|
|
|
|
{
|
|
|
|
|
if (!IsInUtilityMode(applicationModes))
|
|
|
|
|
{
|
|
|
|
|
EnsureSingleInstance();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DbFactory.RegisterDatabase(_container);
|
|
|
|
|
_container.Resolve<Router>().Route(applicationModes);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void SpinToExit(ApplicationModes applicationModes)
|
|
|
|
|
{
|
|
|
|
|
if (IsInUtilityMode(applicationModes))
|
|
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var serviceFactory = _container.Resolve<INzbDroneServiceFactory>();
|
|
|
|
|
|
|
|
|
|
while (!serviceFactory.IsServiceStopped)
|
|
|
|
|
{
|
|
|
|
|
Thread.Sleep(1000);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Start()
|
|
|
|
|
private static void EnsureSingleInstance()
|
|
|
|
|
{
|
|
|
|
|
DbFactory.RegisterDatabase(Container);
|
|
|
|
|
Container.Resolve<Router>().Route();
|
|
|
|
|
_container.Resolve<ISingleInstancePolicy>().EnforceSingleInstance();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public void EnsureSingleInstance()
|
|
|
|
|
|
|
|
|
|
private static ApplicationModes GetApplicationMode(StartupContext startupContext)
|
|
|
|
|
{
|
|
|
|
|
if (startupContext.Flags.Contains(StartupContext.HELP))
|
|
|
|
|
{
|
|
|
|
|
return ApplicationModes.Help;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!OsInfo.IsLinux && startupContext.InstallService)
|
|
|
|
|
{
|
|
|
|
|
return ApplicationModes.InstallService;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!OsInfo.IsLinux && startupContext.UninstallService)
|
|
|
|
|
{
|
|
|
|
|
return ApplicationModes.UninstallService;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (_container.Resolve<IRuntimeInfo>().IsWindowsService)
|
|
|
|
|
{
|
|
|
|
|
return ApplicationModes.Service;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return ApplicationModes.Interactive;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private static bool IsInUtilityMode(ApplicationModes applicationMode)
|
|
|
|
|
{
|
|
|
|
|
Container.Resolve<ISingleInstancePolicy>().EnforceSingleInstance();
|
|
|
|
|
switch (applicationMode)
|
|
|
|
|
{
|
|
|
|
|
case ApplicationModes.InstallService:
|
|
|
|
|
case ApplicationModes.UninstallService:
|
|
|
|
|
case ApplicationModes.Help:
|
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
default:
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|