Sonarr/NzbDrone.Update/Providers/UpdateProvider.cs

105 lines
3.6 KiB
C#
Raw Normal View History

2011-10-23 18:31:17 +00:00
using System;
using System.IO;
using System.Linq;
using NLog;
using NzbDrone.Common;
namespace NzbDrone.Update.Providers
{
public class UpdateProvider
{
private readonly DiskProvider _diskProvider;
private readonly ServiceProvider _serviceProvider;
2011-10-23 18:31:17 +00:00
private readonly ProcessProvider _processProvider;
2011-11-13 04:07:06 +00:00
private readonly PathProvider _pathProvider;
2011-11-13 04:16:54 +00:00
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
2011-11-13 04:16:54 +00:00
public UpdateProvider(DiskProvider diskProvider,ServiceProvider serviceProvider,
ProcessProvider processProvider, PathProvider pathProvider)
{
_diskProvider = diskProvider;
_serviceProvider = serviceProvider;
2011-10-23 18:31:17 +00:00
_processProvider = processProvider;
2011-11-13 04:07:06 +00:00
_pathProvider = pathProvider;
}
private void Verify(string targetFolder)
{
2011-11-13 04:16:54 +00:00
logger.Info("Verifying requirements before update...");
2011-10-23 18:31:17 +00:00
if (String.IsNullOrWhiteSpace(targetFolder))
2011-10-23 18:31:17 +00:00
throw new ArgumentException("Target folder can not be null or empty");
if (!_diskProvider.FolderExists(targetFolder))
throw new DirectoryNotFoundException("Target folder doesn't exist " + targetFolder);
2011-11-13 04:16:54 +00:00
logger.Info("Verifying Update Folder");
if (!_diskProvider.FolderExists(_pathProvider.GetUpdatePackageFolder()))
throw new DirectoryNotFoundException("Update folder doesn't exist " + _pathProvider.GetUpdatePackageFolder());
2011-10-23 18:31:17 +00:00
}
2011-11-13 04:07:06 +00:00
public void Start(string targetFolder)
2011-10-23 18:31:17 +00:00
{
2011-11-13 04:07:06 +00:00
Verify(targetFolder);
bool isService = false;
2011-11-13 04:16:54 +00:00
logger.Info("Stopping all running services");
if (_serviceProvider.ServiceExist(ServiceProvider.NZBDRONE_SERVICE_NAME))
{
2011-11-13 04:07:06 +00:00
if (_serviceProvider.IsServiceRunning(ServiceProvider.NZBDRONE_SERVICE_NAME))
{
isService = true;
}
_serviceProvider.Stop(ServiceProvider.NZBDRONE_SERVICE_NAME);
}
2011-11-13 04:16:54 +00:00
logger.Info("Killing all running processes");
2011-10-23 18:31:17 +00:00
var processes = _processProvider.GetProcessByName(ProcessProvider.NzbDroneProccessName);
foreach (var processInfo in processes)
{
_processProvider.Kill(processInfo.Id);
}
2011-11-13 04:16:54 +00:00
logger.Info("Creating backup of existing installation");
_diskProvider.CopyDirectory(targetFolder, _pathProvider.GetUpdateBackUpFolder());
2011-11-13 04:07:06 +00:00
2011-11-13 04:16:54 +00:00
logger.Info("Copying update package to target");
2011-11-13 04:07:06 +00:00
try
{
_diskProvider.CopyDirectory(_pathProvider.GetUpdatePackageFolder(), targetFolder);
2011-11-13 04:07:06 +00:00
}
catch (Exception e)
{
RollBack(targetFolder);
2011-11-13 04:16:54 +00:00
logger.Fatal("Failed to copy upgrade package to target folder.", e);
2011-11-13 04:07:06 +00:00
}
finally
{
StartNzbDrone(isService, targetFolder);
}
}
2011-11-13 04:07:06 +00:00
private void RollBack(string targetFolder)
{
2011-11-13 04:16:54 +00:00
logger.Info("Attempting to rollback upgrade");
_diskProvider.CopyDirectory(_pathProvider.GetUpdateBackUpFolder(), targetFolder);
2011-11-13 04:07:06 +00:00
}
2011-11-13 04:07:06 +00:00
private void StartNzbDrone(bool isService, string targetFolder)
{
if (isService)
{
_serviceProvider.Start(ServiceProvider.NZBDRONE_SERVICE_NAME);
}
else
{
_processProvider.Start(Path.Combine(targetFolder, "nzbdrone.exe"));
}
}
}
}