mirror of
https://github.com/Artemis-RGB/Artemis
synced 2025-12-12 21:38:38 +00:00
Clean up old releases
This commit is contained in:
parent
5d01665d6e
commit
ee19776afa
@ -7,6 +7,7 @@ public class ReleaseEntity
|
||||
public Guid Id { get; set; }
|
||||
|
||||
public string Version { get; set; }
|
||||
public string ReleaseId { get; set; }
|
||||
public ReleaseEntityStatus Status { get; set; }
|
||||
public DateTimeOffset? InstalledAt { get; set; }
|
||||
}
|
||||
@ -15,5 +16,6 @@ public enum ReleaseEntityStatus
|
||||
{
|
||||
Queued,
|
||||
Installed,
|
||||
Historical
|
||||
Historical,
|
||||
Unknown
|
||||
}
|
||||
@ -1,6 +1,5 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using Artemis.Storage.Entities.General;
|
||||
using Artemis.Storage.Repositories.Interfaces;
|
||||
using LiteDB;
|
||||
@ -18,25 +17,25 @@ public class ReleaseRepository : IReleaseRepository
|
||||
_repository.Database.GetCollection<ReleaseEntity>().EnsureIndex(s => s.Status);
|
||||
}
|
||||
|
||||
public string GetQueuedVersion()
|
||||
public ReleaseEntity GetQueuedVersion()
|
||||
{
|
||||
return _repository.Query<ReleaseEntity>().Where(r => r.Status == ReleaseEntityStatus.Queued).FirstOrDefault()?.Version;
|
||||
return _repository.Query<ReleaseEntity>().Where(r => r.Status == ReleaseEntityStatus.Queued).FirstOrDefault();
|
||||
}
|
||||
|
||||
public string GetInstalledVersion()
|
||||
public ReleaseEntity GetInstalledVersion()
|
||||
{
|
||||
return _repository.Query<ReleaseEntity>().Where(r => r.Status == ReleaseEntityStatus.Installed).FirstOrDefault()?.Version;
|
||||
return _repository.Query<ReleaseEntity>().Where(r => r.Status == ReleaseEntityStatus.Installed).FirstOrDefault();
|
||||
}
|
||||
|
||||
public string GetPreviousInstalledVersion()
|
||||
public ReleaseEntity GetPreviousInstalledVersion()
|
||||
{
|
||||
return _repository.Query<ReleaseEntity>().Where(r => r.Status == ReleaseEntityStatus.Historical).OrderByDescending(r => r.InstalledAt).FirstOrDefault()?.Version;
|
||||
return _repository.Query<ReleaseEntity>().Where(r => r.Status == ReleaseEntityStatus.Historical).OrderByDescending(r => r.InstalledAt).FirstOrDefault();
|
||||
}
|
||||
|
||||
public void QueueInstallation(string version)
|
||||
|
||||
public void QueueInstallation(string version, string releaseId)
|
||||
{
|
||||
// Mark release as queued and add if missing
|
||||
ReleaseEntity release = _repository.Query<ReleaseEntity>().Where(r => r.Version == version).FirstOrDefault() ?? new ReleaseEntity {Version = version};
|
||||
ReleaseEntity release = _repository.Query<ReleaseEntity>().Where(r => r.Version == version).FirstOrDefault() ?? new ReleaseEntity {Version = version, ReleaseId = releaseId};
|
||||
release.Status = ReleaseEntityStatus.Queued;
|
||||
_repository.Upsert(release);
|
||||
}
|
||||
@ -50,10 +49,7 @@ public class ReleaseRepository : IReleaseRepository
|
||||
_repository.Upsert(release);
|
||||
|
||||
// Mark other releases as historical
|
||||
List<ReleaseEntity> oldReleases = _repository.Query<ReleaseEntity>().Where(r => r.Version != version && r.Status == ReleaseEntityStatus.Installed).ToList();
|
||||
if (!oldReleases.Any())
|
||||
return;
|
||||
|
||||
List<ReleaseEntity> oldReleases = _repository.Query<ReleaseEntity>().Where(r => r.Version != version && r.Status != ReleaseEntityStatus.Historical).ToList();
|
||||
foreach (ReleaseEntity oldRelease in oldReleases)
|
||||
oldRelease.Status = ReleaseEntityStatus.Historical;
|
||||
_repository.Update<ReleaseEntity>(oldReleases);
|
||||
@ -61,16 +57,20 @@ public class ReleaseRepository : IReleaseRepository
|
||||
|
||||
public void DequeueInstallation()
|
||||
{
|
||||
_repository.DeleteMany<ReleaseEntity>(r => r.Status == ReleaseEntityStatus.Queued);
|
||||
// Mark all queued releases as unknown, until FinishInstallation is called we don't know the status
|
||||
List<ReleaseEntity> queuedReleases = _repository.Query<ReleaseEntity>().Where(r => r.Status == ReleaseEntityStatus.Queued).ToList();
|
||||
foreach (ReleaseEntity queuedRelease in queuedReleases)
|
||||
queuedRelease.Status = ReleaseEntityStatus.Unknown;
|
||||
_repository.Update<ReleaseEntity>(queuedReleases);
|
||||
}
|
||||
}
|
||||
|
||||
public interface IReleaseRepository : IRepository
|
||||
{
|
||||
string GetQueuedVersion();
|
||||
string GetInstalledVersion();
|
||||
string GetPreviousInstalledVersion();
|
||||
void QueueInstallation(string version);
|
||||
ReleaseEntity GetQueuedVersion();
|
||||
ReleaseEntity GetInstalledVersion();
|
||||
ReleaseEntity GetPreviousInstalledVersion();
|
||||
void QueueInstallation(string version, string releaseId);
|
||||
void FinishInstallation(string version);
|
||||
void DequeueInstallation();
|
||||
}
|
||||
@ -128,7 +128,7 @@ public class WindowsUpdateNotificationProvider : IUpdateNotificationProvider
|
||||
}
|
||||
|
||||
// Queue an update in case the user interrupts the process after everything has been prepared
|
||||
_updateService.QueueUpdate(releaseVersion);
|
||||
_updateService.QueueUpdate(releaseVersion, releaseId);
|
||||
|
||||
GetBuilderForRelease(releaseId, releaseVersion)
|
||||
.AddAudio(new ToastAudio {Silent = true})
|
||||
|
||||
@ -158,7 +158,7 @@ public class ReleaseViewModel : ActivatableViewModelBase
|
||||
{
|
||||
InstallationInProgress = true;
|
||||
await ReleaseInstaller.InstallAsync(_installerCts.Token);
|
||||
_updateService.QueueUpdate(Version);
|
||||
_updateService.QueueUpdate(Version, ReleaseId);
|
||||
InstallationFinished = true;
|
||||
}
|
||||
catch (Exception e)
|
||||
|
||||
@ -12,7 +12,7 @@ public interface IUpdateService : IArtemisUIService
|
||||
|
||||
Task CacheLatestRelease();
|
||||
Task<bool> CheckForUpdate();
|
||||
void QueueUpdate(string version);
|
||||
void QueueUpdate(string version, string releaseId);
|
||||
|
||||
ReleaseInstaller GetReleaseInstaller(string releaseId);
|
||||
void RestartForUpdate(bool silent);
|
||||
|
||||
@ -1,9 +1,11 @@
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using Artemis.Core;
|
||||
using Artemis.Core.Services;
|
||||
using Artemis.Storage.Entities.General;
|
||||
using Artemis.Storage.Repositories;
|
||||
using Artemis.UI.Shared.Services.MainWindow;
|
||||
using Artemis.WebClient.Updating;
|
||||
@ -18,13 +20,13 @@ public class UpdateService : IUpdateService
|
||||
private const double UPDATE_CHECK_INTERVAL = 3_600_000; // once per hour
|
||||
private readonly PluginSetting<bool> _autoCheck;
|
||||
private readonly PluginSetting<bool> _autoInstall;
|
||||
private readonly Platform _updatePlatform;
|
||||
private readonly Func<string, ReleaseInstaller> _getReleaseInstaller;
|
||||
|
||||
private readonly ILogger _logger;
|
||||
private readonly IUpdatingClient _updatingClient;
|
||||
private readonly IReleaseRepository _releaseRepository;
|
||||
private readonly Lazy<IUpdateNotificationProvider> _updateNotificationProvider;
|
||||
private readonly Func<string, ReleaseInstaller> _getReleaseInstaller;
|
||||
private readonly Platform _updatePlatform;
|
||||
private readonly IUpdatingClient _updatingClient;
|
||||
|
||||
private bool _suspendAutoCheck;
|
||||
|
||||
@ -69,28 +71,46 @@ public class UpdateService : IUpdateService
|
||||
ProcessReleaseStatus();
|
||||
}
|
||||
|
||||
public string Channel { get; }
|
||||
public string? PreviousVersion { get; set; }
|
||||
public IGetNextRelease_NextPublishedRelease? CachedLatestRelease { get; private set; }
|
||||
|
||||
private void ProcessReleaseStatus()
|
||||
{
|
||||
// If an update is queued, don't bother with anything else
|
||||
string? queued = _releaseRepository.GetQueuedVersion();
|
||||
ReleaseEntity? queued = _releaseRepository.GetQueuedVersion();
|
||||
if (queued != null)
|
||||
{
|
||||
// Remove the queued installation, in case something goes wrong then at least we don't end up in a loop
|
||||
_logger.Information("Installing queued version {Version}", queued);
|
||||
_logger.Information("Installing queued version {Version}", queued.Version);
|
||||
RestartForUpdate(true);
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
// If a different version was installed, mark it as such
|
||||
string? installed = _releaseRepository.GetInstalledVersion();
|
||||
if (installed != Constants.CurrentVersion)
|
||||
ReleaseEntity? installed = _releaseRepository.GetInstalledVersion();
|
||||
if (installed?.Version != Constants.CurrentVersion)
|
||||
_releaseRepository.FinishInstallation(Constants.CurrentVersion);
|
||||
|
||||
PreviousVersion = _releaseRepository.GetPreviousInstalledVersion();
|
||||
PreviousVersion = _releaseRepository.GetPreviousInstalledVersion()?.Version;
|
||||
|
||||
if (!Directory.Exists(Path.Combine(Constants.DataFolder, "updating")))
|
||||
return;
|
||||
|
||||
// Clean up the update folder, leaving only the last ZIP
|
||||
foreach (string file in Directory.GetFiles(Path.Combine(Constants.DataFolder, "updating")))
|
||||
{
|
||||
if (Path.GetExtension(file) != ".zip")
|
||||
continue;
|
||||
if (installed != null && Path.GetFileName(file) == $"{installed.ReleaseId}.zip")
|
||||
continue;
|
||||
|
||||
try
|
||||
{
|
||||
_logger.Debug("Cleaning up old update file at {FilePath}", file);
|
||||
File.Delete(file);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
_logger.Warning(e, "Failed to clean up old update file at {FilePath}", file);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void ShowUpdateNotification(IGetNextRelease_NextPublishedRelease release)
|
||||
@ -120,6 +140,10 @@ public class UpdateService : IUpdateService
|
||||
}
|
||||
}
|
||||
|
||||
public string Channel { get; }
|
||||
public string? PreviousVersion { get; set; }
|
||||
public IGetNextRelease_NextPublishedRelease? CachedLatestRelease { get; private set; }
|
||||
|
||||
/// <inheritdoc />
|
||||
public async Task CacheLatestRelease()
|
||||
{
|
||||
@ -159,11 +183,11 @@ public class UpdateService : IUpdateService
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
public void QueueUpdate(string version)
|
||||
public void QueueUpdate(string version, string releaseId)
|
||||
{
|
||||
_releaseRepository.QueueInstallation(version);
|
||||
_releaseRepository.QueueInstallation(version, releaseId);
|
||||
}
|
||||
|
||||
|
||||
/// <inheritdoc />
|
||||
public ReleaseInstaller GetReleaseInstaller(string releaseId)
|
||||
{
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user