2013-05-21 07:03:05 +03:00
|
|
|
using System;
|
|
|
|
using System.Linq;
|
|
|
|
using NLog;
|
|
|
|
using NzbDrone.Common;
|
|
|
|
using IServiceProvider = NzbDrone.Common.IServiceProvider;
|
|
|
|
|
|
|
|
namespace NzbDrone.Update.UpdateEngine
|
|
|
|
{
|
|
|
|
public interface ITerminateNzbDrone
|
|
|
|
{
|
|
|
|
void Terminate();
|
|
|
|
}
|
|
|
|
|
|
|
|
public class TerminateNzbDrone : ITerminateNzbDrone
|
|
|
|
{
|
|
|
|
private readonly IServiceProvider _serviceProvider;
|
|
|
|
private readonly IProcessProvider _processProvider;
|
|
|
|
private readonly Logger _logger;
|
|
|
|
|
|
|
|
public TerminateNzbDrone(IServiceProvider serviceProvider, IProcessProvider processProvider, Logger logger)
|
|
|
|
{
|
|
|
|
_serviceProvider = serviceProvider;
|
|
|
|
_processProvider = processProvider;
|
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void Terminate()
|
|
|
|
{
|
|
|
|
_logger.Info("Stopping all running services");
|
|
|
|
|
|
|
|
if (_serviceProvider.ServiceExist(ServiceProvider.NZBDRONE_SERVICE_NAME)
|
|
|
|
&& _serviceProvider.IsServiceRunning(ServiceProvider.NZBDRONE_SERVICE_NAME))
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
2013-07-05 21:51:38 +03:00
|
|
|
_logger.Info("NzbDrone Service is installed and running");
|
2013-05-21 07:03:05 +03:00
|
|
|
_serviceProvider.Stop(ServiceProvider.NZBDRONE_SERVICE_NAME);
|
|
|
|
|
|
|
|
}
|
2013-07-05 21:51:38 +03:00
|
|
|
catch (Exception e)
|
2013-05-21 07:03:05 +03:00
|
|
|
{
|
2013-07-05 21:51:38 +03:00
|
|
|
_logger.ErrorException("couldn't stop service", e);
|
2013-05-21 07:03:05 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
_logger.Info("Killing all running processes");
|
|
|
|
|
|
|
|
if (_processProvider.GetProcessByName(ProcessProvider.NzbDroneConsoleProcessName).Any())
|
|
|
|
{
|
|
|
|
_processProvider.KillAll(ProcessProvider.NzbDroneConsoleProcessName);
|
|
|
|
}
|
|
|
|
|
|
|
|
_processProvider.KillAll(ProcessProvider.NzbDroneProcessName);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|