Fixed: Prevent duplicate searches on list add

(cherry picked from commit 735fceb0746a8bf476cac5d69bc5648c3a868219)
pull/2877/head
ta264 3 years ago
parent 70ae0c931e
commit c524886e62

@ -5,6 +5,7 @@ using NLog;
using NzbDrone.Common.Extensions; using NzbDrone.Common.Extensions;
using NzbDrone.Common.Instrumentation.Extensions; using NzbDrone.Common.Instrumentation.Extensions;
using NzbDrone.Core.ImportLists.Exclusions; using NzbDrone.Core.ImportLists.Exclusions;
using NzbDrone.Core.IndexerSearch;
using NzbDrone.Core.Messaging.Commands; using NzbDrone.Core.Messaging.Commands;
using NzbDrone.Core.Messaging.Events; using NzbDrone.Core.Messaging.Events;
using NzbDrone.Core.MetadataSource; using NzbDrone.Core.MetadataSource;
@ -189,19 +190,36 @@ namespace NzbDrone.Core.ImportLists
if (!existingAlbum.Monitored) if (!existingAlbum.Monitored)
{ {
_albumService.SetAlbumMonitored(existingAlbum.Id, true); _albumService.SetAlbumMonitored(existingAlbum.Id, true);
if (importList.ShouldMonitor == ImportListMonitorType.SpecificAlbum)
{
_commandQueueManager.Push(new AlbumSearchCommand(new List<int> { existingAlbum.Id }));
}
} }
var existingArtist = existingAlbum.Artist.Value; var existingArtist = existingAlbum.Artist.Value;
var doSearch = false;
if (importList.ShouldMonitor == ImportListMonitorType.EntireArtist) if (importList.ShouldMonitor == ImportListMonitorType.EntireArtist)
{ {
_albumService.SetMonitored(existingArtist.Albums.Value.Select(x => x.Id), true); if (existingArtist.Albums.Value.Any(x => !x.Monitored))
{
doSearch = true;
_albumService.SetMonitored(existingArtist.Albums.Value.Select(x => x.Id), true);
}
} }
if (!existingArtist.Monitored) if (!existingArtist.Monitored)
{ {
doSearch = true;
existingArtist.Monitored = true; existingArtist.Monitored = true;
_artistService.UpdateArtist(existingArtist); _artistService.UpdateArtist(existingArtist);
} }
if (doSearch)
{
_commandQueueManager.Push(new MissingAlbumSearchCommand(existingArtist.Id));
}
} }
return; return;
@ -240,7 +258,7 @@ namespace NzbDrone.Core.ImportLists
Artist = toAddArtist, Artist = toAddArtist,
AddOptions = new AddAlbumOptions AddOptions = new AddAlbumOptions
{ {
SearchForNewAlbum = importList.ShouldSearch SearchForNewAlbum = importList.ShouldSearch && toAddArtist.Id > 0
} }
}; };

Loading…
Cancel
Save