mirror of https://github.com/lidarr/Lidarr
59 lines
2.0 KiB
C#
59 lines
2.0 KiB
C#
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using NLog;
|
|
using NzbDrone.Common.Extensions;
|
|
using NzbDrone.Core.History;
|
|
|
|
namespace NzbDrone.Core.Download.TrackedDownloads
|
|
{
|
|
public interface ITrackedDownloadAlreadyImported
|
|
{
|
|
bool IsImported(TrackedDownload trackedDownload, List<EntityHistory> historyItems);
|
|
}
|
|
|
|
public class TrackedDownloadAlreadyImported : ITrackedDownloadAlreadyImported
|
|
{
|
|
private readonly Logger _logger;
|
|
|
|
public TrackedDownloadAlreadyImported(Logger logger)
|
|
{
|
|
_logger = logger;
|
|
}
|
|
|
|
public bool IsImported(TrackedDownload trackedDownload, List<EntityHistory> historyItems)
|
|
{
|
|
_logger.Trace("Checking if all items for '{0}' have been imported", trackedDownload.DownloadItem.Title);
|
|
|
|
if (historyItems.Empty())
|
|
{
|
|
_logger.Trace("No history for {0}", trackedDownload.DownloadItem.Title);
|
|
return false;
|
|
}
|
|
|
|
if (trackedDownload.RemoteAlbum == null || trackedDownload.RemoteAlbum.Albums == null)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
var allAlbumsImportedInHistory = trackedDownload.RemoteAlbum.Albums.All(album =>
|
|
{
|
|
var lastHistoryItem = historyItems.FirstOrDefault(h => h.AlbumId == album.Id);
|
|
|
|
if (lastHistoryItem == null)
|
|
{
|
|
_logger.Trace($"No history for album: {album}");
|
|
return false;
|
|
}
|
|
|
|
_logger.Trace($"Last event for album: {album} is: {lastHistoryItem.EventType}");
|
|
|
|
return new[] { EntityHistoryEventType.DownloadImported, EntityHistoryEventType.TrackFileImported }.Contains(lastHistoryItem.EventType);
|
|
});
|
|
|
|
_logger.Trace("All albums for '{0}' have been imported: {1}", trackedDownload.DownloadItem.Title, allAlbumsImportedInHistory);
|
|
|
|
return allAlbumsImportedInHistory;
|
|
}
|
|
}
|
|
}
|