|
|
@ -12,40 +12,47 @@ namespace NzbDrone.Update.Providers
|
|
|
|
private readonly EnviromentProvider _enviromentProvider;
|
|
|
|
private readonly EnviromentProvider _enviromentProvider;
|
|
|
|
private readonly ServiceProvider _serviceProvider;
|
|
|
|
private readonly ServiceProvider _serviceProvider;
|
|
|
|
private readonly ProcessProvider _processProvider;
|
|
|
|
private readonly ProcessProvider _processProvider;
|
|
|
|
|
|
|
|
private readonly PathProvider _pathProvider;
|
|
|
|
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
|
|
|
|
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
|
|
|
|
|
|
|
|
|
|
|
|
public UpdateProvider(DiskProvider diskProvider, EnviromentProvider enviromentProvider,
|
|
|
|
public UpdateProvider(DiskProvider diskProvider, EnviromentProvider enviromentProvider,
|
|
|
|
ServiceProvider serviceProvider, ProcessProvider processProvider)
|
|
|
|
ServiceProvider serviceProvider, ProcessProvider processProvider, PathProvider pathProvider)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_diskProvider = diskProvider;
|
|
|
|
_diskProvider = diskProvider;
|
|
|
|
_enviromentProvider = enviromentProvider;
|
|
|
|
_enviromentProvider = enviromentProvider;
|
|
|
|
_serviceProvider = serviceProvider;
|
|
|
|
_serviceProvider = serviceProvider;
|
|
|
|
_processProvider = processProvider;
|
|
|
|
_processProvider = processProvider;
|
|
|
|
|
|
|
|
_pathProvider = pathProvider;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void Verify(string targetFolder)
|
|
|
|
private void Verify(string installationFolder)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Logger.Info("Verifying requirements before update...");
|
|
|
|
Logger.Info("Verifying requirements before update...");
|
|
|
|
|
|
|
|
|
|
|
|
if (String.IsNullOrWhiteSpace(targetFolder))
|
|
|
|
if (String.IsNullOrWhiteSpace(installationFolder))
|
|
|
|
throw new ArgumentException("Target folder can not be null or empty");
|
|
|
|
throw new ArgumentException("Target folder can not be null or empty");
|
|
|
|
|
|
|
|
|
|
|
|
if (!_diskProvider.FolderExists(targetFolder))
|
|
|
|
if (!_diskProvider.FolderExists(installationFolder))
|
|
|
|
throw new DirectoryNotFoundException("Target folder doesn't exist" + targetFolder);
|
|
|
|
throw new DirectoryNotFoundException("Target folder doesn't exist" + installationFolder);
|
|
|
|
|
|
|
|
|
|
|
|
var sandboxFolder = Path.Combine(_enviromentProvider.StartUpPath, "nzbdrone_update");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Logger.Info("Verifying Update Folder");
|
|
|
|
Logger.Info("Verifying Update Folder");
|
|
|
|
if (!_diskProvider.FolderExists(sandboxFolder))
|
|
|
|
if (!_diskProvider.FolderExists(_pathProvider.UpdatePackageFolder))
|
|
|
|
throw new DirectoryNotFoundException("Update folder doesn't exist" + sandboxFolder);
|
|
|
|
throw new DirectoryNotFoundException("Update folder doesn't exist" + _pathProvider.UpdateSandboxFolder);
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void Start(string installationFolder)
|
|
|
|
public void Start(string targetFolder)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
Verify(targetFolder);
|
|
|
|
|
|
|
|
bool isService = false;
|
|
|
|
|
|
|
|
|
|
|
|
Logger.Info("Stopping all running services");
|
|
|
|
Logger.Info("Stopping all running services");
|
|
|
|
if (_serviceProvider.ServiceExist(ServiceProvider.NZBDRONE_SERVICE_NAME))
|
|
|
|
if (_serviceProvider.ServiceExist(ServiceProvider.NZBDRONE_SERVICE_NAME))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
if (_serviceProvider.IsServiceRunning(ServiceProvider.NZBDRONE_SERVICE_NAME))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
isService = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
_serviceProvider.Stop(ServiceProvider.NZBDRONE_SERVICE_NAME);
|
|
|
|
_serviceProvider.Stop(ServiceProvider.NZBDRONE_SERVICE_NAME);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -56,17 +63,44 @@ namespace NzbDrone.Update.Providers
|
|
|
|
_processProvider.Kill(processInfo.Id);
|
|
|
|
_processProvider.Kill(processInfo.Id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Logger.Info("Creating backup of existing installation");
|
|
|
|
|
|
|
|
_diskProvider.CopyDirectory(targetFolder, _pathProvider.UpdateBackUpFolder);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//Create backup of current folder
|
|
|
|
Logger.Info("Copying update package to target");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
_diskProvider.CopyDirectory(_pathProvider.UpdatePackageFolder, targetFolder);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
RollBack(targetFolder);
|
|
|
|
|
|
|
|
Logger.Fatal("Failed to copy upgrade package to target folder.", e);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
finally
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StartNzbDrone(isService, targetFolder);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//Copy update folder on top of the existing folder
|
|
|
|
private void RollBack(string targetFolder)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Logger.Info("Attempting to rollback upgrade");
|
|
|
|
|
|
|
|
_diskProvider.CopyDirectory(_pathProvider.UpdateBackUpFolder, targetFolder);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//Happy: Cleanup
|
|
|
|
|
|
|
|
//Happy: Start Service, Process?
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//Sad: delete fucked up folder
|
|
|
|
private void StartNzbDrone(bool isService, string targetFolder)
|
|
|
|
//Sad: restore backup
|
|
|
|
{
|
|
|
|
//Sad: start service, process
|
|
|
|
if (isService)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
_serviceProvider.Start(ServiceProvider.NZBDRONE_SERVICE_NAME);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
_processProvider.Start(Path.Combine(targetFolder, "nzbdrone.exe"));
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|