Radarr/NzbDrone.Web/Controllers/UpdateController.cs

65 lines
2.2 KiB
C#
Raw Normal View History

2011-11-22 06:55:09 +00:00
using System;
using System.Linq;
2011-11-14 06:01:51 +00:00
using System.Web.Mvc;
2011-11-22 06:55:09 +00:00
using NzbDrone.Common;
2011-12-02 01:33:17 +00:00
using NzbDrone.Core.Jobs;
2011-11-14 06:01:51 +00:00
using NzbDrone.Core.Providers;
using NzbDrone.Web.Models;
namespace NzbDrone.Web.Controllers
{
public class UpdateController : Controller
{
private readonly UpdateProvider _updateProvider;
private readonly JobProvider _jobProvider;
private readonly EnvironmentProvider _environmentProvider;
2011-11-22 06:55:09 +00:00
private readonly DiskProvider _diskProvider;
2011-11-14 06:01:51 +00:00
2011-11-22 06:55:09 +00:00
public UpdateController(UpdateProvider updateProvider, JobProvider jobProvider,
EnvironmentProvider environmentProvider, DiskProvider diskProvider)
2011-11-14 06:01:51 +00:00
{
_updateProvider = updateProvider;
_jobProvider = jobProvider;
_environmentProvider = environmentProvider;
2011-11-22 06:55:09 +00:00
_diskProvider = diskProvider;
2011-11-14 06:01:51 +00:00
}
public ActionResult Index()
{
2011-11-22 06:55:09 +00:00
var updateModel = new UpdateModel();
updateModel.UpdatePackage = _updateProvider.GetAvilableUpdate(_environmentProvider.Version);
2011-11-22 06:55:09 +00:00
updateModel.LogFiles = _updateProvider.UpdateLogFile();
updateModel.LogFolder = _environmentProvider.GetUpdateLogFolder();
2011-11-22 06:55:09 +00:00
return View(updateModel);
2011-11-14 06:01:51 +00:00
}
public ActionResult StartUpdate()
{
_jobProvider.QueueJob(typeof(AppUpdateJob), 0, 0);
return JsonNotificationResult.Info("Update will begin shortly", "NzbDrone will restart automatically.");
2011-11-22 06:55:09 +00:00
}
public ActionResult ViewLog( string filepath)
{
ViewBag.Log = _diskProvider.ReadAllText(filepath).Replace(Environment.NewLine, "<br/>");
return View();
2011-11-14 06:01:51 +00:00
}
[HttpGet]
public ActionResult Post(string expectedVersion)
{
var model = new PostUpgradeModel();
model.CurrentVersion = _environmentProvider.Version;
model.ExpectedVersion = Version.Parse(expectedVersion);
model.Success = model.CurrentVersion >= model.ExpectedVersion;
if (!model.Success)
model.LogFile = _updateProvider.UpdateLogFile().FirstOrDefault();
return View(model);
}
2011-11-14 06:01:51 +00:00
}
}