Lidarr/src/NzbDrone.Core/Lifecycle/LifecycleService.cs

69 lines
2.0 KiB
C#
Raw Permalink Normal View History

2014-12-07 05:55:17 +00:00
using NLog;
2014-01-14 01:35:16 +00:00
using NzbDrone.Common;
2014-01-13 01:14:57 +00:00
using NzbDrone.Common.EnvironmentInfo;
using NzbDrone.Core.Lifecycle.Commands;
using NzbDrone.Core.Messaging.Commands;
using NzbDrone.Core.Messaging.Events;
using IServiceProvider = NzbDrone.Common.IServiceProvider;
namespace NzbDrone.Core.Lifecycle
{
public interface ILifecycleService
{
void Shutdown();
void Restart();
}
public class LifecycleService : ILifecycleService, IExecute<ShutdownCommand>, IExecute<RestartCommand>
2014-01-13 01:14:57 +00:00
{
private readonly IEventAggregator _eventAggregator;
private readonly IRuntimeInfo _runtimeInfo;
private readonly IServiceProvider _serviceProvider;
private readonly Logger _logger;
2014-01-13 01:14:57 +00:00
public LifecycleService(IEventAggregator eventAggregator,
2014-01-13 01:14:57 +00:00
IRuntimeInfo runtimeInfo,
IServiceProvider serviceProvider,
Logger logger)
2014-01-13 01:14:57 +00:00
{
_eventAggregator = eventAggregator;
_runtimeInfo = runtimeInfo;
_serviceProvider = serviceProvider;
_logger = logger;
2014-01-13 01:14:57 +00:00
}
public void Shutdown()
2014-01-13 01:14:57 +00:00
{
_logger.Info("Shutdown requested.");
2014-01-14 01:35:16 +00:00
_eventAggregator.PublishEvent(new ApplicationShutdownRequested());
2014-01-13 01:14:57 +00:00
if (_runtimeInfo.IsWindowsService)
{
2017-09-27 02:06:05 +00:00
_serviceProvider.Stop(ServiceProvider.SERVICE_NAME);
2014-01-13 01:14:57 +00:00
}
}
public void Restart()
2014-01-13 01:14:57 +00:00
{
_logger.Info("Restart requested.");
2014-01-14 01:35:16 +00:00
_eventAggregator.PublishEvent(new ApplicationShutdownRequested(true));
2014-01-13 01:14:57 +00:00
if (_runtimeInfo.IsWindowsService)
{
2017-09-27 02:06:05 +00:00
_serviceProvider.Restart(ServiceProvider.SERVICE_NAME);
2014-01-13 01:14:57 +00:00
}
}
public void Execute(ShutdownCommand message)
{
Shutdown();
}
public void Execute(RestartCommand message)
{
Restart();
}
2014-01-13 01:14:57 +00:00
}
}