sonarr-repo-only/NzbDrone/Router.cs

124 lines
4.5 KiB
C#
Raw Normal View History

using System;
using System.Collections.Generic;
using System.Linq;
2011-10-13 02:24:30 +00:00
using NLog;
using NzbDrone.Common;
2013-05-10 23:53:50 +00:00
using NzbDrone.Common.Composition;
using NzbDrone.SysTray;
2013-05-10 23:53:50 +00:00
using IServiceProvider = NzbDrone.Common.IServiceProvider;
namespace NzbDrone
{
2013-05-10 23:53:50 +00:00
[Singleton]
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;
2013-04-16 04:52:41 +00:00
private readonly IConsoleService _consoleService;
2013-05-10 23:53:50 +00:00
private readonly IEnvironmentProvider _environmentProvider;
private readonly ISystemTrayApp _systemTrayProvider;
2013-03-01 00:50:50 +00:00
private readonly Logger _logger;
2013-05-10 23:53:50 +00:00
public Router(INzbDroneServiceFactory nzbDroneServiceFactory, IServiceProvider serviceProvider,
IConsoleService consoleService, IEnvironmentProvider environmentProvider, ISystemTrayApp systemTrayProvider, Logger logger)
{
2013-04-16 04:52:41 +00:00
_nzbDroneServiceFactory = nzbDroneServiceFactory;
_serviceProvider = serviceProvider;
2013-04-16 04:52:41 +00:00
_consoleService = consoleService;
_environmentProvider = environmentProvider;
2013-05-10 23:53:50 +00:00
_systemTrayProvider = systemTrayProvider;
2013-03-01 00:50:50 +00:00
_logger = logger;
}
public void Route(IEnumerable<string> args)
{
Route(GetApplicationMode(args));
}
2013-03-01 00:50:50 +00:00
public void Route(ApplicationModes applicationModes)
{
if (!_environmentProvider.IsUserInteractive)
{
2013-03-01 00:50:50 +00:00
applicationModes = ApplicationModes.Service;
}
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;
}
2013-03-01 00:50:50 +00:00
case ApplicationModes.Console:
{
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();
}
else
{
2013-05-10 23:53:50 +00:00
_systemTrayProvider.Start();
}
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))
{
2013-04-16 04:52:41 +00:00
_consoleService.PrintServiceDoestExist();
}
else
{
_serviceProvider.UnInstall(ServiceProvider.NZBDRONE_SERVICE_NAME);
}
break;
}
default:
{
2013-04-16 04:52:41 +00:00
_consoleService.PrintHelp();
break;
}
}
}
2013-03-01 00:50:50 +00:00
public static ApplicationModes GetApplicationMode(IEnumerable<string> args)
{
2013-03-01 00:50:50 +00:00
if (args == null) return ApplicationModes.Console;
var cleanArgs = args.Where(c => c != null && !String.IsNullOrWhiteSpace(c)).ToList();
2013-03-01 00:50:50 +00:00
if (cleanArgs.Count == 0) return ApplicationModes.Console;
if (cleanArgs.Count != 1) return ApplicationModes.Help;
var arg = cleanArgs.First().Trim('/', '\\', '-').ToLower();
2013-03-01 00:50:50 +00:00
if (arg == "i") return ApplicationModes.InstallService;
if (arg == "u") return ApplicationModes.UninstallService;
2013-03-01 00:50:50 +00:00
return ApplicationModes.Help;
}
}
}