1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2025-01-17 10:45:49 +02:00

Fixed: Previously imported downloads reappear in queue

Fixes #3496
This commit is contained in:
Mark McDowall 2020-01-07 16:55:13 -08:00
parent 29117fc222
commit fa4060b7fe

View File

@ -110,19 +110,27 @@ public TrackedDownload TrackDownload(DownloadClientDefinition downloadClient, Do
var firstHistoryItem = historyItems.First(); var firstHistoryItem = historyItems.First();
var state = GetStateFromHistory(firstHistoryItem.EventType); var state = GetStateFromHistory(firstHistoryItem.EventType);
trackedDownload.State = state;
// TODO: Restore check to confirm all files were imported
// This will treat partially imported downloads as imported (as it was before), which means a partially imported download after a
// restart will get marked as imported without importing the restart of the files.
// One potential issue here is if the latest is imported, but other episodes are ignored or never imported. // One potential issue here is if the latest is imported, but other episodes are ignored or never imported.
// It's unlikely that will happen, but could happen if additional episodes are added to season after it's already imported. // It's unlikely that will happen, but could happen if additional episodes are added to season after it's already imported.
if (state == TrackedDownloadState.Imported) // if (state == TrackedDownloadState.Imported)
{ // {
var allImported = _trackedDownloadAlreadyImported.IsImported(trackedDownload, historyItems); // trackedDownload.State = TrackedDownloadState.Imported;
//
trackedDownload.State = allImported ? TrackedDownloadState.Imported : TrackedDownloadState.Downloading; // var allImported = _trackedDownloadAlreadyImported.IsImported(trackedDownload, historyItems);
} //
else // trackedDownload.State = allImported ? TrackedDownloadState.Imported : TrackedDownloadState.Downloading;
{ // }
trackedDownload.State = state; // else
} // {
// trackedDownload.State = state;
// }
var grabbedEvent = historyItems.FirstOrDefault(v => v.EventType == HistoryEventType.Grabbed); var grabbedEvent = historyItems.FirstOrDefault(v => v.EventType == HistoryEventType.Grabbed);
trackedDownload.Indexer = grabbedEvent?.Data["indexer"]; trackedDownload.Indexer = grabbedEvent?.Data["indexer"];