From 9ec1235b629c534781cc9cb0d8899926845d3ccb Mon Sep 17 00:00:00 2001 From: Mark McDowall Date: Sun, 2 Apr 2023 13:26:49 -0700 Subject: [PATCH] New: Add release info to webhook/custom script import events Closes #8293 --- .../MatchesGrabSpecificationFixture.cs | 26 +++------- .../Aggregators/AggregateReleaseInfo.cs | 52 +++++++++++++++++++ .../MatchesGrabSpecification.cs | 21 ++------ .../CustomScript/CustomScript.cs | 3 ++ .../Notifications/DownloadMessage.cs | 1 + .../Notifications/NotificationService.cs | 3 +- .../Notifications/Webhook/WebhookBase.cs | 1 + .../Webhook/WebhookGrabbedRelease.cs | 27 ++++++++++ .../Webhook/WebhookImportPayload.cs | 1 + .../Parser/Model/GrabbedReleaseInfo.cs | 13 +++++ src/NzbDrone.Core/Parser/Model/LocalMovie.cs | 1 + 11 files changed, 113 insertions(+), 36 deletions(-) create mode 100644 src/NzbDrone.Core/MediaFiles/MovieImport/Aggregation/Aggregators/AggregateReleaseInfo.cs create mode 100644 src/NzbDrone.Core/Notifications/Webhook/WebhookGrabbedRelease.cs create mode 100644 src/NzbDrone.Core/Parser/Model/GrabbedReleaseInfo.cs diff --git a/src/NzbDrone.Core.Test/MediaFiles/MovieImport/Specifications/MatchesGrabSpecificationFixture.cs b/src/NzbDrone.Core.Test/MediaFiles/MovieImport/Specifications/MatchesGrabSpecificationFixture.cs index ad0c40332..5821dad59 100644 --- a/src/NzbDrone.Core.Test/MediaFiles/MovieImport/Specifications/MatchesGrabSpecificationFixture.cs +++ b/src/NzbDrone.Core.Test/MediaFiles/MovieImport/Specifications/MatchesGrabSpecificationFixture.cs @@ -1,10 +1,8 @@ -using System.Collections.Generic; +using System.Linq; using FizzWare.NBuilder; using FluentAssertions; -using Moq; using NUnit.Framework; using NzbDrone.Core.Download; -using NzbDrone.Core.History; using NzbDrone.Core.MediaFiles.MovieImport.Specifications; using NzbDrone.Core.Movies; using NzbDrone.Core.Parser.Model; @@ -40,6 +38,7 @@ namespace NzbDrone.Core.Test.MediaFiles.MovieImport.Specifications _localMovie = Builder.CreateNew() .With(l => l.Path = @"C:\Test\Unsorted\Series.Title.S01E01.720p.HDTV-Sonarr\S01E05.mkv".AsOsAgnostic()) .With(l => l.Movie = _movie1) + .With(l => l.Release = null) .Build(); _downloadClientItem = Builder.CreateNew().Build(); @@ -47,19 +46,8 @@ namespace NzbDrone.Core.Test.MediaFiles.MovieImport.Specifications private void GivenHistoryForMovies(params Movie[] movies) { - var history = new List(); - - foreach (var movie in movies) - { - history.Add(Builder.CreateNew() - .With(h => h.EventType = MovieHistoryEventType.Grabbed) - .With(h => h.MovieId = movie.Id) - .Build()); - } - - Mocker.GetMock() - .Setup(s => s.FindByDownloadId(It.IsAny())) - .Returns(history); + _localMovie.Release = new GrabbedReleaseInfo(); + _localMovie.Release.MovieIds = movies.Select(e => e.Id).ToList(); } [Test] @@ -77,7 +65,7 @@ namespace NzbDrone.Core.Test.MediaFiles.MovieImport.Specifications } [Test] - public void should_be_accepted_if_no_grab_history() + public void should_be_accepted_if_no_grab_release_info() { GivenHistoryForMovies(); @@ -85,7 +73,7 @@ namespace NzbDrone.Core.Test.MediaFiles.MovieImport.Specifications } [Test] - public void should_be_accepted_if_file_episode_matches_single_grab_history() + public void should_be_accepted_if_file_episode_matches_single_grab_release_info() { GivenHistoryForMovies(_movie1); @@ -93,7 +81,7 @@ namespace NzbDrone.Core.Test.MediaFiles.MovieImport.Specifications } [Test] - public void should_be_rejected_if_file_episode_does_not_match_single_grab_history() + public void should_be_rejected_if_file_episode_does_not_match_single_grab_release_info() { GivenHistoryForMovies(_movie2); diff --git a/src/NzbDrone.Core/MediaFiles/MovieImport/Aggregation/Aggregators/AggregateReleaseInfo.cs b/src/NzbDrone.Core/MediaFiles/MovieImport/Aggregation/Aggregators/AggregateReleaseInfo.cs new file mode 100644 index 000000000..1b6dc92cf --- /dev/null +++ b/src/NzbDrone.Core/MediaFiles/MovieImport/Aggregation/Aggregators/AggregateReleaseInfo.cs @@ -0,0 +1,52 @@ +using System.Linq; +using NzbDrone.Common.Extensions; +using NzbDrone.Core.Download; +using NzbDrone.Core.History; +using NzbDrone.Core.Parser.Model; + +namespace NzbDrone.Core.MediaFiles.MovieImport.Aggregation.Aggregators +{ + public class AggregateReleaseInfo : IAggregateLocalMovie + { + private readonly IHistoryService _historyService; + + public AggregateReleaseInfo(IHistoryService historyService) + { + _historyService = historyService; + } + + public LocalMovie Aggregate(LocalMovie localMovie, DownloadClientItem downloadClientItem) + { + if (downloadClientItem == null) + { + return localMovie; + } + + var grabbedHistories = _historyService.FindByDownloadId(downloadClientItem.DownloadId) + .Where(h => h.EventType == MovieHistoryEventType.Grabbed) + .ToList(); + + if (grabbedHistories.Empty()) + { + return localMovie; + } + + var movieIds = grabbedHistories.Select(h => h.MovieId).Distinct().ToList(); + var grabbedHistory = grabbedHistories.First(); + var releaseInfo = new GrabbedReleaseInfo(); + + grabbedHistory.Data.TryGetValue("indexer", out var indexer); + grabbedHistory.Data.TryGetValue("size", out var sizeString); + long.TryParse(sizeString, out var size); + + releaseInfo.Title = grabbedHistory.SourceTitle; + releaseInfo.Indexer = indexer; + releaseInfo.Size = size; + releaseInfo.MovieIds = movieIds; + + localMovie.Release = releaseInfo; + + return localMovie; + } + } +} diff --git a/src/NzbDrone.Core/MediaFiles/MovieImport/Specifications/MatchesGrabSpecification.cs b/src/NzbDrone.Core/MediaFiles/MovieImport/Specifications/MatchesGrabSpecification.cs index 1b689c035..658c2b735 100644 --- a/src/NzbDrone.Core/MediaFiles/MovieImport/Specifications/MatchesGrabSpecification.cs +++ b/src/NzbDrone.Core/MediaFiles/MovieImport/Specifications/MatchesGrabSpecification.cs @@ -12,14 +12,10 @@ namespace NzbDrone.Core.MediaFiles.MovieImport.Specifications public class MatchesGrabSpecification : IImportDecisionEngineSpecification { private readonly Logger _logger; - private readonly IParsingService _parsingService; - private readonly IHistoryService _historyService; - public MatchesGrabSpecification(IParsingService parsingService, IHistoryService historyService, Logger logger) + public MatchesGrabSpecification(Logger logger) { _logger = logger; - _parsingService = parsingService; - _historyService = historyService; } public Decision IsSatisfiedBy(LocalMovie localMovie, DownloadClientItem downloadClientItem) @@ -29,25 +25,18 @@ namespace NzbDrone.Core.MediaFiles.MovieImport.Specifications return Decision.Accept(); } - if (downloadClientItem == null) - { - return Decision.Accept(); - } - - var grabbedHistory = _historyService.FindByDownloadId(downloadClientItem.DownloadId) - .Where(h => h.EventType == MovieHistoryEventType.Grabbed) - .ToList(); + var releaseInfo = localMovie.Release; - if (grabbedHistory.Empty()) + if (releaseInfo == null || releaseInfo.MovieIds.Empty()) { return Decision.Accept(); } - if (grabbedHistory.All(o => o.MovieId != localMovie.Movie.Id)) + if (releaseInfo.MovieIds.All(o => o != localMovie.Movie.Id)) { _logger.Debug("Unexpected movie(s) in file: {0}", localMovie.Movie.ToString()); - return Decision.Reject("Movie {0} was not found in the grabbed release: {1}", localMovie.Movie.ToString(), grabbedHistory.First().SourceTitle); + return Decision.Reject("Movie {0} was not found in the grabbed release: {1}", localMovie.Movie.ToString(), releaseInfo.Title); } return Decision.Accept(); diff --git a/src/NzbDrone.Core/Notifications/CustomScript/CustomScript.cs b/src/NzbDrone.Core/Notifications/CustomScript/CustomScript.cs index cb6179a21..4955a32cf 100755 --- a/src/NzbDrone.Core/Notifications/CustomScript/CustomScript.cs +++ b/src/NzbDrone.Core/Notifications/CustomScript/CustomScript.cs @@ -122,6 +122,9 @@ namespace NzbDrone.Core.Notifications.CustomScript environmentVariables.Add("Radarr_MovieFile_MediaInfo_VideoDynamicRangeType", MediaInfoFormatter.FormatVideoDynamicRangeType(movieFile.MediaInfo)); environmentVariables.Add("Radarr_MovieFile_CustomFormat", string.Join("|", message.MovieInfo.CustomFormats)); environmentVariables.Add("Radarr_MovieFile_CustomFormatScore", message.MovieInfo.CustomFormatScore.ToString()); + environmentVariables.Add("Radarr_Release_Indexer", message.Release?.Indexer); + environmentVariables.Add("Radarr_Release_Size", message.Release?.Size.ToString()); + environmentVariables.Add("Radarr_Release_Title", message.Release?.Title); if (message.OldMovieFiles.Any()) { diff --git a/src/NzbDrone.Core/Notifications/DownloadMessage.cs b/src/NzbDrone.Core/Notifications/DownloadMessage.cs index 64da38bdb..01f988616 100644 --- a/src/NzbDrone.Core/Notifications/DownloadMessage.cs +++ b/src/NzbDrone.Core/Notifications/DownloadMessage.cs @@ -16,6 +16,7 @@ namespace NzbDrone.Core.Notifications public string SourcePath { get; set; } public DownloadClientItemClientInfo DownloadClientInfo { get; set; } public string DownloadId { get; set; } + public GrabbedReleaseInfo Release { get; set; } public override string ToString() { diff --git a/src/NzbDrone.Core/Notifications/NotificationService.cs b/src/NzbDrone.Core/Notifications/NotificationService.cs index 141bbc848..2bc875c51 100644 --- a/src/NzbDrone.Core/Notifications/NotificationService.cs +++ b/src/NzbDrone.Core/Notifications/NotificationService.cs @@ -136,7 +136,8 @@ namespace NzbDrone.Core.Notifications OldMovieFiles = message.OldFiles, SourcePath = message.MovieInfo.Path, DownloadClientInfo = message.DownloadClientInfo, - DownloadId = message.DownloadId + DownloadId = message.DownloadId, + Release = message.MovieInfo.Release }; foreach (var notification in _notificationFactory.OnDownloadEnabled()) diff --git a/src/NzbDrone.Core/Notifications/Webhook/WebhookBase.cs b/src/NzbDrone.Core/Notifications/Webhook/WebhookBase.cs index 50a792765..693891644 100644 --- a/src/NzbDrone.Core/Notifications/Webhook/WebhookBase.cs +++ b/src/NzbDrone.Core/Notifications/Webhook/WebhookBase.cs @@ -53,6 +53,7 @@ namespace NzbDrone.Core.Notifications.Webhook Movie = new WebhookMovie(message.Movie), RemoteMovie = new WebhookRemoteMovie(message.Movie), MovieFile = new WebhookMovieFile(movieFile), + Release = new WebhookGrabbedRelease(message.Release), IsUpgrade = message.OldMovieFiles.Any(), DownloadClient = message.DownloadClientInfo?.Name, DownloadClientType = message.DownloadClientInfo?.Type, diff --git a/src/NzbDrone.Core/Notifications/Webhook/WebhookGrabbedRelease.cs b/src/NzbDrone.Core/Notifications/Webhook/WebhookGrabbedRelease.cs new file mode 100644 index 000000000..bcce1af60 --- /dev/null +++ b/src/NzbDrone.Core/Notifications/Webhook/WebhookGrabbedRelease.cs @@ -0,0 +1,27 @@ +using NzbDrone.Core.Parser.Model; + +namespace NzbDrone.Core.Notifications.Webhook +{ + public class WebhookGrabbedRelease + { + public WebhookGrabbedRelease() + { + } + + public WebhookGrabbedRelease(GrabbedReleaseInfo release) + { + if (release == null) + { + return; + } + + ReleaseTitle = release.Title; + Indexer = release.Indexer; + Size = release.Size; + } + + public string ReleaseTitle { get; set; } + public string Indexer { get; set; } + public long Size { get; set; } + } +} diff --git a/src/NzbDrone.Core/Notifications/Webhook/WebhookImportPayload.cs b/src/NzbDrone.Core/Notifications/Webhook/WebhookImportPayload.cs index c28ba25f8..1d3de1415 100755 --- a/src/NzbDrone.Core/Notifications/Webhook/WebhookImportPayload.cs +++ b/src/NzbDrone.Core/Notifications/Webhook/WebhookImportPayload.cs @@ -13,5 +13,6 @@ namespace NzbDrone.Core.Notifications.Webhook public string DownloadId { get; set; } public List DeletedFiles { get; set; } public WebhookCustomFormatInfo CustomFormatInfo { get; set; } + public WebhookGrabbedRelease Release { get; set; } } } diff --git a/src/NzbDrone.Core/Parser/Model/GrabbedReleaseInfo.cs b/src/NzbDrone.Core/Parser/Model/GrabbedReleaseInfo.cs new file mode 100644 index 000000000..58c9e62c3 --- /dev/null +++ b/src/NzbDrone.Core/Parser/Model/GrabbedReleaseInfo.cs @@ -0,0 +1,13 @@ +using System.Collections.Generic; + +namespace NzbDrone.Core.Parser.Model +{ + public class GrabbedReleaseInfo + { + public string Title { get; set; } + public string Indexer { get; set; } + public long Size { get; set; } + + public List MovieIds { get; set; } + } +} diff --git a/src/NzbDrone.Core/Parser/Model/LocalMovie.cs b/src/NzbDrone.Core/Parser/Model/LocalMovie.cs index 2128cac4f..8932bf0ce 100644 --- a/src/NzbDrone.Core/Parser/Model/LocalMovie.cs +++ b/src/NzbDrone.Core/Parser/Model/LocalMovie.cs @@ -31,6 +31,7 @@ namespace NzbDrone.Core.Parser.Model public bool OtherVideoFiles { get; set; } public List CustomFormats { get; set; } public int CustomFormatScore { get; set; } + public GrabbedReleaseInfo Release { get; set; } public override string ToString() {