Lidarr/NzbDrone/Router.cs

121 lines
4.4 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;
using NzbDrone.SysTray;
namespace NzbDrone
{
2011-10-13 02:24:30 +00:00
public class Router
{
2013-04-16 04:52:41 +00:00
private readonly INzbDroneServiceFactory _nzbDroneServiceFactory;
private readonly ServiceProvider _serviceProvider;
2013-04-16 04:52:41 +00:00
private readonly IConsoleService _consoleService;
private readonly EnvironmentProvider _environmentProvider;
private readonly SysTrayProvider _sysTrayProvider;
2013-03-01 00:50:50 +00:00
private readonly Logger _logger;
2013-04-16 04:52:41 +00:00
public Router(INzbDroneServiceFactory nzbDroneServiceFactory, ServiceProvider serviceProvider,
IConsoleService consoleService, EnvironmentProvider environmentProvider, SysTrayProvider sysTrayProvider, 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;
_sysTrayProvider = sysTrayProvider;
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
{
_sysTrayProvider.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;
}
}
}