From 24fba7a36dc0ff5300a02522f3d0b61bb35aca7f Mon Sep 17 00:00:00 2001 From: morpheus133 Date: Mon, 25 Feb 2019 11:22:26 +0100 Subject: [PATCH] New: Use IMDB ID when searching supported indexers --- .../NewznabRequestGeneratorFixture.cs | 15 ++++++++++++- .../Newznab/NewznabRequestGenerator.cs | 22 +++++++++++++++++++ 2 files changed, 36 insertions(+), 1 deletion(-) diff --git a/src/NzbDrone.Core.Test/IndexerTests/NewznabTests/NewznabRequestGeneratorFixture.cs b/src/NzbDrone.Core.Test/IndexerTests/NewznabTests/NewznabRequestGeneratorFixture.cs index c32c888e1..cc6100599 100644 --- a/src/NzbDrone.Core.Test/IndexerTests/NewznabTests/NewznabRequestGeneratorFixture.cs +++ b/src/NzbDrone.Core.Test/IndexerTests/NewznabTests/NewznabRequestGeneratorFixture.cs @@ -28,7 +28,7 @@ public void SetUp() _singleEpisodeSearchCriteria = new SingleEpisodeSearchCriteria { - Series = new Tv.Series { TvRageId = 10, TvdbId = 20, TvMazeId = 30 }, + Series = new Tv.Series { TvRageId = 10, TvdbId = 20, TvMazeId = 30, ImdbId ="t40" }, SceneTitles = new List { "Monkey Island" }, SeasonNumber = 1, EpisodeNumber = 2 @@ -189,6 +189,19 @@ public void should_search_by_tvmaze_if_supported() page.Url.Query.Should().Contain("tvmazeid=30"); } + [Test] + public void should_search_by_imdbid_if_supported() + { + _capabilities.SupportedTvSearchParameters = new[] { "q", "imdbid", "season", "ep" }; + + var results = Subject.GetSearchRequests(_singleEpisodeSearchCriteria); + results.GetTier(0).Should().HaveCount(1); + + var page = results.GetAllTiers().First().First(); + + page.Url.Query.Should().Contain("imdbid=t40"); + } + [Test] public void should_prefer_search_by_tvdbid_if_rid_supported() { diff --git a/src/NzbDrone.Core/Indexers/Newznab/NewznabRequestGenerator.cs b/src/NzbDrone.Core/Indexers/Newznab/NewznabRequestGenerator.cs index c01852e10..57b055bda 100644 --- a/src/NzbDrone.Core/Indexers/Newznab/NewznabRequestGenerator.cs +++ b/src/NzbDrone.Core/Indexers/Newznab/NewznabRequestGenerator.cs @@ -57,6 +57,18 @@ private bool SupportsTvdbSearch capabilities.SupportedTvSearchParameters.Contains("ep"); } } + private bool SupportsImdbSearch + { + get + { + var capabilities = _capabilitiesProvider.GetCapabilities(Settings); + + return capabilities.SupportedTvSearchParameters != null && + capabilities.SupportedTvSearchParameters.Contains("imdbid") && + capabilities.SupportedTvSearchParameters.Contains("season") && + capabilities.SupportedTvSearchParameters.Contains("ep"); + } + } private bool SupportsTvRageSearch { @@ -198,6 +210,7 @@ public virtual IndexerPageableRequestChain GetSearchRequests(SpecialEpisodeSearc private void AddTvIdPageableRequests(IndexerPageableRequestChain chain, int maxPages, IEnumerable categories, SearchCriteriaBase searchCriteria, string parameters) { var includeTvdbSearch = SupportsTvdbSearch && searchCriteria.Series.TvdbId > 0; + var includeImdbSearch = SupportsImdbSearch && searchCriteria.Series.ImdbId.IsNotNullOrWhiteSpace(); var includeTvRageSearch = SupportsTvRageSearch && searchCriteria.Series.TvRageId > 0; var includeTvMazeSearch = SupportsTvMazeSearch && searchCriteria.Series.TvMazeId > 0; @@ -209,6 +222,10 @@ private void AddTvIdPageableRequests(IndexerPageableRequestChain chain, int maxP { ids += "&tvdbid=" + searchCriteria.Series.TvdbId; } + if (includeImdbSearch) + { + ids += "&imdbid=" + searchCriteria.Series.ImdbId; + } if (includeTvRageSearch) { @@ -229,6 +246,11 @@ private void AddTvIdPageableRequests(IndexerPageableRequestChain chain, int maxP chain.Add(GetPagedRequests(maxPages, categories, "tvsearch", string.Format("&tvdbid={0}{1}", searchCriteria.Series.TvdbId, parameters))); } + else if (includeImdbSearch) + { + chain.Add(GetPagedRequests(maxPages, categories, "tvsearch", + string.Format("&imdbid={0}{1}", searchCriteria.Series.ImdbId, parameters))); + } else if (includeTvRageSearch) { chain.Add(GetPagedRequests(maxPages, categories, "tvsearch",