Radarr/NzbDrone.Host/Router.cs

123 lines
4.4 KiB
C#
Raw Normal View History

2013-08-14 03:48:50 +00:00
using System.ServiceProcess;
using NLog;
using NzbDrone.Common;
using NzbDrone.Common.EnvironmentInfo;
namespace NzbDrone.Host
{
2011-10-13 02:24:30 +00:00
public class Router
{
2013-04-16 04:52:41 +00:00
private readonly INzbDroneServiceFactory _nzbDroneServiceFactory;
2013-05-10 23:53:50 +00:00
private readonly IServiceProvider _serviceProvider;
private readonly IStartupArguments _startupArguments;
2013-04-16 04:52:41 +00:00
private readonly IConsoleService _consoleService;
private readonly IRuntimeInfo _runtimeInfo;
2013-03-01 00:50:50 +00:00
private readonly Logger _logger;
public Router(INzbDroneServiceFactory nzbDroneServiceFactory, IServiceProvider serviceProvider, IStartupArguments startupArguments,
IConsoleService consoleService, IRuntimeInfo runtimeInfo, Logger logger)
{
2013-04-16 04:52:41 +00:00
_nzbDroneServiceFactory = nzbDroneServiceFactory;
_serviceProvider = serviceProvider;
_startupArguments = startupArguments;
2013-04-16 04:52:41 +00:00
_consoleService = consoleService;
_runtimeInfo = runtimeInfo;
2013-03-01 00:50:50 +00:00
_logger = logger;
}
public void Route()
{
var appMode = GetApplicationMode();
Route(appMode);
}
2013-03-01 00:50:50 +00:00
public void Route(ApplicationModes applicationModes)
{
2013-03-01 00:50:50 +00:00
_logger.Info("Application mode: {0}", applicationModes);
2013-03-01 00:50:50 +00:00
switch (applicationModes)
{
2013-03-01 00:50:50 +00:00
case ApplicationModes.Service:
{
2013-03-01 00:50:50 +00:00
_logger.Trace("Service selected");
2013-04-16 04:52:41 +00:00
_serviceProvider.Run(_nzbDroneServiceFactory.Build());
break;
}
case ApplicationModes.Interactive:
{
2013-03-01 00:50:50 +00:00
_logger.Trace("Console selected");
2013-04-16 04:52:41 +00:00
_nzbDroneServiceFactory.Start();
if (_consoleService.IsConsoleApplication)
{
_consoleService.WaitForClose();
}
break;
}
2013-03-01 00:50:50 +00:00
case ApplicationModes.InstallService:
{
2013-03-01 00:50:50 +00:00
_logger.Trace("Install Service selected");
if (_serviceProvider.ServiceExist(ServiceProvider.NZBDRONE_SERVICE_NAME))
{
2013-04-16 04:52:41 +00:00
_consoleService.PrintServiceAlreadyExist();
}
else
{
_serviceProvider.Install(ServiceProvider.NZBDRONE_SERVICE_NAME);
_serviceProvider.Start(ServiceProvider.NZBDRONE_SERVICE_NAME);
}
break;
}
2013-03-01 00:50:50 +00:00
case ApplicationModes.UninstallService:
{
2013-03-01 00:50:50 +00:00
_logger.Trace("Uninstall Service selected");
if (!_serviceProvider.ServiceExist(ServiceProvider.NZBDRONE_SERVICE_NAME))
{
_consoleService.PrintServiceDoesNotExist();
}
else
{
_serviceProvider.UnInstall(ServiceProvider.NZBDRONE_SERVICE_NAME);
}
break;
}
default:
{
2013-04-16 04:52:41 +00:00
_consoleService.PrintHelp();
break;
}
}
}
private ApplicationModes GetApplicationMode()
{
if (_startupArguments.Flags.Contains(StartupArguments.HELP))
{
return ApplicationModes.Help;
}
2013-07-27 01:25:45 +00:00
if (!OsInfo.IsLinux && _startupArguments.Flags.Contains(StartupArguments.INSTALL_SERVICE))
{
return ApplicationModes.InstallService;
}
2013-07-27 01:25:45 +00:00
if (!OsInfo.IsLinux && _startupArguments.Flags.Contains(StartupArguments.UNINSTALL_SERVICE))
{
return ApplicationModes.UninstallService;
}
2013-08-14 03:48:50 +00:00
if (!_runtimeInfo.IsUserInteractive &&
OsInfo.IsWindows &&
_serviceProvider.ServiceExist(ServiceProvider.NZBDRONE_SERVICE_NAME) &&
_serviceProvider.GetService(ServiceProvider.NZBDRONE_SERVICE_NAME).Status == ServiceControllerStatus.StartPending)
{
return ApplicationModes.Service;
}
return ApplicationModes.Interactive;
}
}
}