From 3fcc39596438beaf5e38de3fde4a83397940f80e Mon Sep 17 00:00:00 2001 From: bakerboy448 <55419169+bakerboy448@users.noreply.github.com> Date: Tue, 7 Dec 2021 19:46:44 -0600 Subject: [PATCH] Fixed: Escape Characters as needed for *znab queries Fixes #6799 [common] --- .../NewznabRequestGeneratorFixture.cs | 43 +++++++++++++++++++ .../Newznab/NewznabRequestGenerator.cs | 3 +- 2 files changed, 45 insertions(+), 1 deletion(-) diff --git a/src/NzbDrone.Core.Test/IndexerTests/NewznabTests/NewznabRequestGeneratorFixture.cs b/src/NzbDrone.Core.Test/IndexerTests/NewznabTests/NewznabRequestGeneratorFixture.cs index 1cb57a2fa..ad7e03270 100644 --- a/src/NzbDrone.Core.Test/IndexerTests/NewznabTests/NewznabRequestGeneratorFixture.cs +++ b/src/NzbDrone.Core.Test/IndexerTests/NewznabTests/NewznabRequestGeneratorFixture.cs @@ -204,5 +204,48 @@ namespace NzbDrone.Core.Test.IndexerTests.NewznabTests pageTier2.Url.Query.Should().NotContain("imdbid=0076759"); pageTier2.Url.Query.Should().Contain("q="); } + + [Test] + public void should_encode_raw_title() + { + _capabilities.SupportedMovieSearchParameters = new[] { "q" }; + _capabilities.TextSearchEngine = "raw"; + + MovieSearchCriteria movieRawSearchCriteria = new MovieSearchCriteria + { + Movie = new Movies.Movie { Title = "Some Movie & Title: Words", Year = 2021, TmdbId = 123 }, + SceneTitles = new List { "Some Movie & Title: Words" } + }; + + var results = Subject.GetSearchRequests(movieRawSearchCriteria); + + var page = results.GetTier(0).First().First(); + + page.Url.Query.Should().Contain("q=Some%20Movie%20%26%20Title%3A%20Words"); + page.Url.Query.Should().NotContain(" & "); + page.Url.Query.Should().Contain("%26"); + } + + [Test] + public void should_use_clean_title_and_encode() + { + _capabilities.SupportedMovieSearchParameters = new[] { "q" }; + _capabilities.TextSearchEngine = "sphinx"; + + MovieSearchCriteria movieRawSearchCriteria = new MovieSearchCriteria + { + Movie = new Movies.Movie { Title = "Some Movie & Title: Words", Year = 2021, TmdbId = 123 }, + SceneTitles = new List { "Some Movie & Title: Words" } + }; + + var results = Subject.GetSearchRequests(movieRawSearchCriteria); + + var page = results.GetTier(0).First().First(); + + page.Url.Query.Should().Contain("q=Some%20Movie%20and%20Title%20Words%202021"); + page.Url.Query.Should().Contain("and"); + page.Url.Query.Should().NotContain(" & "); + page.Url.Query.Should().NotContain("%26"); + } } } diff --git a/src/NzbDrone.Core/Indexers/Newznab/NewznabRequestGenerator.cs b/src/NzbDrone.Core/Indexers/Newznab/NewznabRequestGenerator.cs index 9486b019a..a20f0dbab 100644 --- a/src/NzbDrone.Core/Indexers/Newznab/NewznabRequestGenerator.cs +++ b/src/NzbDrone.Core/Indexers/Newznab/NewznabRequestGenerator.cs @@ -204,7 +204,8 @@ namespace NzbDrone.Core.Indexers.Newznab private static string NewsnabifyTitle(string title) { - return title.Replace("+", "%20"); + var newtitle = title.Replace("+", " "); + return Uri.EscapeDataString(newtitle); } public Func> GetCookies { get; set; }