Radarr/src/NzbDrone.Host/Bootstrap.cs

172 lines
5.3 KiB
C#
Raw Normal View History

using System;
2021-01-24 22:05:08 +00:00
using System.Diagnostics;
2013-11-26 06:53:36 +00:00
using System.Reflection;
using System.Text;
2013-11-26 06:53:36 +00:00
using System.Threading;
using NLog;
using NzbDrone.Common.Composition;
using NzbDrone.Common.EnvironmentInfo;
2018-11-23 07:03:32 +00:00
using NzbDrone.Common.Exceptions;
2013-05-24 03:23:59 +00:00
using NzbDrone.Common.Instrumentation;
using NzbDrone.Common.Processes;
2018-11-23 07:03:32 +00:00
using NzbDrone.Core.Configuration;
using NzbDrone.Core.Instrumentation;
2017-01-05 19:42:02 +00:00
namespace Radarr.Host
{
2013-11-26 06:53:36 +00:00
public static class Bootstrap
{
2014-12-17 07:12:26 +00:00
private static readonly Logger Logger = NzbDroneLogger.GetLogger(typeof(Bootstrap));
2019-12-22 22:08:53 +00:00
private static IContainer _container;
2013-11-26 02:46:12 +00:00
2013-11-26 06:53:36 +00:00
public static void Start(StartupContext startupContext, IUserAlert userAlert, Action<IContainer> startCallback = null)
{
2013-11-26 06:53:36 +00:00
try
{
2021-01-24 22:05:08 +00:00
Logger.Info("Starting Radarr - {0} - Version {1}",
Process.GetCurrentProcess().MainModule.FileName,
Assembly.GetExecutingAssembly().GetName().Version);
2013-11-26 06:53:36 +00:00
if (!PlatformValidation.IsValidate(userAlert))
{
throw new TerminateApplicationException("Missing system requirements");
}
Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);
2013-11-26 06:53:36 +00:00
_container = MainAppContainerBuilder.BuildContainer(startupContext);
_container.Resolve<InitializeLogger>().Initialize();
_container.Resolve<IAppFolderFactory>().Register();
_container.Resolve<IProvidePidFile>().Write();
2013-11-26 06:53:36 +00:00
var appMode = GetApplicationMode(startupContext);
2013-03-01 00:50:50 +00:00
2014-01-14 01:35:16 +00:00
Start(appMode, startupContext);
_container.Resolve<ICancelHandler>().Attach();
2013-11-26 06:53:36 +00:00
if (startCallback != null)
{
startCallback(_container);
}
2014-01-10 04:32:21 +00:00
else
{
SpinToExit(appMode);
}
2013-11-26 06:53:36 +00:00
}
2018-11-23 07:03:32 +00:00
catch (InvalidConfigFileException ex)
{
throw new RadarrStartupException(ex);
}
2013-11-26 06:53:36 +00:00
catch (TerminateApplicationException e)
{
Logger.Info(e.Message);
LogManager.Configuration = null;
}
2013-11-26 06:53:36 +00:00
}
2014-01-14 01:35:16 +00:00
private static void Start(ApplicationModes applicationModes, StartupContext startupContext)
2013-11-26 06:53:36 +00:00
{
_container.Resolve<ReconfigureLogging>().Reconfigure();
2013-11-26 06:53:36 +00:00
if (!IsInUtilityMode(applicationModes))
{
if (startupContext.Flags.Contains(StartupContext.RESTART))
{
Thread.Sleep(2000);
}
2014-01-14 01:35:16 +00:00
EnsureSingleInstance(applicationModes == ApplicationModes.Service, startupContext);
2013-11-26 06:53:36 +00:00
}
2019-12-22 21:24:11 +00:00
2013-11-26 06:53:36 +00:00
_container.Resolve<Router>().Route(applicationModes);
}
private static void SpinToExit(ApplicationModes applicationModes)
{
if (IsInUtilityMode(applicationModes))
{
return;
}
_container.Resolve<IWaitForExit>().Spin();
}
2013-11-26 02:46:12 +00:00
private static void EnsureSingleInstance(bool isService, IStartupContext startupContext)
2013-11-26 02:46:12 +00:00
{
if (startupContext.Flags.Contains(StartupContext.NO_SINGLE_INSTANCE_CHECK))
{
return;
}
var instancePolicy = _container.Resolve<ISingleInstancePolicy>();
if (startupContext.Flags.Contains(StartupContext.TERMINATE))
{
instancePolicy.KillAllOtherInstance();
}
else if (startupContext.Args.ContainsKey(StartupContext.APPDATA))
{
instancePolicy.WarnIfAlreadyRunning();
}
else if (isService)
2014-01-14 01:35:16 +00:00
{
instancePolicy.KillAllOtherInstance();
}
else
{
instancePolicy.PreventStartIfAlreadyRunning();
}
2013-11-26 02:46:12 +00:00
}
private static ApplicationModes GetApplicationMode(IStartupContext startupContext)
2013-11-26 06:53:36 +00:00
{
if (startupContext.Help)
2013-11-26 06:53:36 +00:00
{
return ApplicationModes.Help;
}
if (OsInfo.IsWindows && startupContext.RegisterUrl)
{
return ApplicationModes.RegisterUrl;
}
2014-12-07 20:54:07 +00:00
if (OsInfo.IsWindows && startupContext.InstallService)
2013-11-26 06:53:36 +00:00
{
return ApplicationModes.InstallService;
}
2014-12-07 20:54:07 +00:00
if (OsInfo.IsWindows && startupContext.UninstallService)
2013-11-26 06:53:36 +00:00
{
return ApplicationModes.UninstallService;
}
if (_container.Resolve<IRuntimeInfo>().IsWindowsService)
{
return ApplicationModes.Service;
}
return ApplicationModes.Interactive;
}
private static bool IsInUtilityMode(ApplicationModes applicationMode)
2013-11-26 02:46:12 +00:00
{
2013-11-26 06:53:36 +00:00
switch (applicationMode)
{
case ApplicationModes.InstallService:
case ApplicationModes.UninstallService:
case ApplicationModes.RegisterUrl:
2013-11-26 06:53:36 +00:00
case ApplicationModes.Help:
{
return true;
}
2019-12-22 22:08:53 +00:00
2013-11-26 06:53:36 +00:00
default:
{
return false;
}
}
2013-11-26 02:46:12 +00:00
}
}
}