2012-01-15 02:47:23 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Linq;
|
2011-12-02 01:33:17 +00:00
|
|
|
|
using System.Diagnostics;
|
2011-11-21 02:59:42 +00:00
|
|
|
|
using System.IO;
|
|
|
|
|
using NLog;
|
|
|
|
|
using NzbDrone.Common;
|
2013-02-18 07:59:43 +00:00
|
|
|
|
using NzbDrone.Core.Jobs;
|
2011-11-21 02:59:42 +00:00
|
|
|
|
using NzbDrone.Core.Model.Notification;
|
2011-12-02 01:33:17 +00:00
|
|
|
|
using NzbDrone.Core.Providers;
|
2013-04-13 23:57:10 +00:00
|
|
|
|
using NzbDrone.Core.Update;
|
2011-11-14 02:54:09 +00:00
|
|
|
|
|
2013-02-18 07:59:43 +00:00
|
|
|
|
namespace NzbDrone.Core.Lifecycle
|
2011-11-14 02:54:09 +00:00
|
|
|
|
{
|
|
|
|
|
public class AppUpdateJob : IJob
|
|
|
|
|
{
|
2013-04-13 23:57:10 +00:00
|
|
|
|
private readonly UpdateService _updateService;
|
2012-03-07 02:59:43 +00:00
|
|
|
|
private readonly EnvironmentProvider _environmentProvider;
|
2011-11-21 02:59:42 +00:00
|
|
|
|
private readonly DiskProvider _diskProvider;
|
2013-04-10 23:41:45 +00:00
|
|
|
|
private readonly IHttpProvider _httpProvider;
|
2011-11-21 02:59:42 +00:00
|
|
|
|
private readonly ProcessProvider _processProvider;
|
|
|
|
|
private readonly ArchiveProvider _archiveProvider;
|
|
|
|
|
private readonly ConfigFileProvider _configFileProvider;
|
2011-11-14 02:54:09 +00:00
|
|
|
|
|
2011-11-21 02:59:42 +00:00
|
|
|
|
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
|
|
|
|
|
|
2013-04-13 23:57:10 +00:00
|
|
|
|
public AppUpdateJob(UpdateService updateService, EnvironmentProvider environmentProvider, DiskProvider diskProvider,
|
2013-04-11 05:08:55 +00:00
|
|
|
|
IHttpProvider httpProvider, ProcessProvider processProvider, ArchiveProvider archiveProvider, ConfigFileProvider configFileProvider)
|
2011-11-14 02:54:09 +00:00
|
|
|
|
{
|
2013-04-13 23:57:10 +00:00
|
|
|
|
_updateService = updateService;
|
2012-03-07 02:59:43 +00:00
|
|
|
|
_environmentProvider = environmentProvider;
|
2011-11-21 02:59:42 +00:00
|
|
|
|
_diskProvider = diskProvider;
|
|
|
|
|
_httpProvider = httpProvider;
|
|
|
|
|
_processProvider = processProvider;
|
|
|
|
|
_archiveProvider = archiveProvider;
|
|
|
|
|
_configFileProvider = configFileProvider;
|
2011-11-14 02:54:09 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public string Name
|
|
|
|
|
{
|
|
|
|
|
get { return "Update Application Job"; }
|
|
|
|
|
}
|
|
|
|
|
|
2012-01-15 02:47:23 +00:00
|
|
|
|
public TimeSpan DefaultInterval
|
2011-11-14 02:54:09 +00:00
|
|
|
|
{
|
2012-01-15 02:47:23 +00:00
|
|
|
|
get { return TimeSpan.FromDays(2); }
|
2011-11-14 02:54:09 +00:00
|
|
|
|
}
|
|
|
|
|
|
2012-09-10 19:04:17 +00:00
|
|
|
|
public virtual void Start(ProgressNotification notification, dynamic options)
|
2012-02-26 21:22:35 +00:00
|
|
|
|
{
|
2012-01-27 05:26:39 +00:00
|
|
|
|
notification.CurrentMessage = "Checking for updates";
|
2011-11-14 02:54:09 +00:00
|
|
|
|
|
2013-04-15 01:41:39 +00:00
|
|
|
|
var updatePackage = _updateService.GetAvailableUpdate();
|
2011-11-14 02:54:09 +00:00
|
|
|
|
|
2012-01-16 18:10:18 +00:00
|
|
|
|
//No updates available
|
|
|
|
|
if (updatePackage == null)
|
|
|
|
|
return;
|
|
|
|
|
|
2012-03-07 02:59:43 +00:00
|
|
|
|
var packageDestination = Path.Combine(_environmentProvider.GetUpdateSandboxFolder(), updatePackage.FileName);
|
2011-11-21 02:59:42 +00:00
|
|
|
|
|
2012-03-07 02:59:43 +00:00
|
|
|
|
if (_diskProvider.FolderExists(_environmentProvider.GetUpdateSandboxFolder()))
|
2011-11-21 02:59:42 +00:00
|
|
|
|
{
|
|
|
|
|
logger.Info("Deleting old update files");
|
2012-03-07 02:59:43 +00:00
|
|
|
|
_diskProvider.DeleteFolder(_environmentProvider.GetUpdateSandboxFolder(), true);
|
2011-11-21 02:59:42 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
logger.Info("Downloading update package from [{0}] to [{1}]", updatePackage.Url, packageDestination);
|
|
|
|
|
notification.CurrentMessage = "Downloading Update " + updatePackage.Version;
|
|
|
|
|
_httpProvider.DownloadFile(updatePackage.Url, packageDestination);
|
|
|
|
|
logger.Info("Download completed for update package from [{0}]", updatePackage.FileName);
|
|
|
|
|
|
|
|
|
|
logger.Info("Extracting Update package");
|
|
|
|
|
notification.CurrentMessage = "Extracting Update";
|
2012-03-07 02:59:43 +00:00
|
|
|
|
_archiveProvider.ExtractArchive(packageDestination, _environmentProvider.GetUpdateSandboxFolder());
|
2011-11-21 02:59:42 +00:00
|
|
|
|
logger.Info("Update package extracted successfully");
|
|
|
|
|
|
|
|
|
|
logger.Info("Preparing client");
|
|
|
|
|
notification.CurrentMessage = "Preparing to start Update";
|
2012-03-07 02:59:43 +00:00
|
|
|
|
_diskProvider.MoveDirectory(_environmentProvider.GetUpdateClientFolder(), _environmentProvider.GetUpdateSandboxFolder());
|
2011-11-21 02:59:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
logger.Info("Starting update client");
|
2012-01-16 18:10:18 +00:00
|
|
|
|
var startInfo = new ProcessStartInfo
|
|
|
|
|
{
|
2012-03-07 02:59:43 +00:00
|
|
|
|
FileName = _environmentProvider.GetUpdateClientExePath(),
|
2013-03-30 21:29:02 +00:00
|
|
|
|
Arguments = string.Format("{0} {1}", _environmentProvider.NzbDroneProcessIdFromEnvironment, _configFileProvider.Guid)
|
2012-02-26 21:22:35 +00:00
|
|
|
|
};
|
2011-11-21 02:59:42 +00:00
|
|
|
|
|
2012-02-26 21:22:35 +00:00
|
|
|
|
var process = _processProvider.Start(startInfo);
|
2011-11-21 06:21:36 +00:00
|
|
|
|
notification.CurrentMessage = "Update in progress. NzbDrone will restart shortly.";
|
2012-02-26 21:22:35 +00:00
|
|
|
|
|
2013-04-15 01:41:39 +00:00
|
|
|
|
_processProvider.WaitForExit(process);
|
2011-11-14 02:54:09 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|