2013-05-21 04:03:05 +00:00
|
|
|
using NLog;
|
|
|
|
using NzbDrone.Common;
|
2013-06-28 00:04:52 +00:00
|
|
|
using NzbDrone.Common.EnvironmentInfo;
|
2013-05-21 04:03:05 +00:00
|
|
|
|
|
|
|
namespace NzbDrone.Update.UpdateEngine
|
|
|
|
{
|
|
|
|
public interface IBackupAndRestore
|
|
|
|
{
|
|
|
|
void BackUp(string source);
|
|
|
|
void Restore(string target);
|
|
|
|
}
|
|
|
|
|
|
|
|
public class BackupAndRestore : IBackupAndRestore
|
|
|
|
{
|
|
|
|
private readonly IDiskProvider _diskProvider;
|
2013-06-28 00:04:52 +00:00
|
|
|
private readonly IAppDirectoryInfo _appDirectoryInfo;
|
2013-05-21 04:03:05 +00:00
|
|
|
private readonly Logger _logger;
|
|
|
|
|
2013-06-28 00:04:52 +00:00
|
|
|
public BackupAndRestore(IDiskProvider diskProvider, IAppDirectoryInfo appDirectoryInfo, Logger logger)
|
2013-05-21 04:03:05 +00:00
|
|
|
{
|
|
|
|
_diskProvider = diskProvider;
|
2013-06-28 00:04:52 +00:00
|
|
|
_appDirectoryInfo = appDirectoryInfo;
|
2013-05-21 04:03:05 +00:00
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void BackUp(string source)
|
|
|
|
{
|
|
|
|
_logger.Info("Creating backup of existing installation");
|
2013-06-28 00:04:52 +00:00
|
|
|
_diskProvider.CopyDirectory(source, _appDirectoryInfo.GetUpdateBackUpFolder());
|
2013-05-21 04:03:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public void Restore(string target)
|
|
|
|
{
|
|
|
|
//TODO:this should ignore single file failures.
|
|
|
|
_logger.Info("Attempting to rollback upgrade");
|
2013-06-28 00:04:52 +00:00
|
|
|
_diskProvider.CopyDirectory(_appDirectoryInfo.GetUpdateBackUpFolder(), target);
|
2013-05-21 04:03:05 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|