From a0b08f6c6f106d92cdb12fbb959dd2605c22fe6a Mon Sep 17 00:00:00 2001 From: Bogdan Date: Sun, 30 Apr 2023 07:09:11 +0300 Subject: [PATCH] Build download requests from indexer implementation --- .../Blackhole/TorrentBlackholeFixture.cs | 16 ++++---- .../Blackhole/UsenetBlackholeFixture.cs | 4 +- .../DelugeTests/DelugeFixture.cs | 4 +- .../DownloadClientFixtureBase.cs | 12 ++++++ .../TorrentDownloadStationFixture.cs | 8 ++-- .../UsenetDownloadStationFixture.cs | 8 ++-- .../TorrentFreeboxDownloadFixture.cs | 12 +++--- .../HadoukenTests/HadoukenFixture.cs | 6 +-- .../NzbVortexTests/NzbVortexFixture.cs | 4 +- .../NzbgetTests/NzbgetFixture.cs | 4 +- .../PneumaticProviderFixture.cs | 20 ++++++++-- .../QBittorrentTests/QBittorrentFixture.cs | 16 ++++---- .../RTorrentTests/RTorrentFixture.cs | 2 +- .../SabnzbdTests/SabnzbdFixture.cs | 6 +-- .../TransmissionTests/TransmissionFixture.cs | 12 +++--- .../UTorrentTests/UTorrentFixture.cs | 8 ++-- .../VuzeTests/VuzeFixture.cs | 12 +++--- .../Download/DownloadServiceFixture.cs | 38 +++++++++---------- .../Download/Clients/Pneumatic/Pneumatic.cs | 2 +- .../Download/DownloadClientBase.cs | 2 +- src/NzbDrone.Core/Download/DownloadService.cs | 6 ++- src/NzbDrone.Core/Download/IDownloadClient.cs | 2 +- .../Download/TorrentClientBase.cs | 14 ++++--- .../Download/UsenetClientBase.cs | 4 +- src/NzbDrone.Core/Indexers/HttpIndexerBase.cs | 6 ++- src/NzbDrone.Core/Indexers/IIndexer.cs | 2 + src/NzbDrone.Core/Indexers/IndexerBase.cs | 3 +- 27 files changed, 135 insertions(+), 98 deletions(-) diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/Blackhole/TorrentBlackholeFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/Blackhole/TorrentBlackholeFixture.cs index 5f73a28ee..15e25e2b9 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/Blackhole/TorrentBlackholeFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/Blackhole/TorrentBlackholeFixture.cs @@ -147,7 +147,7 @@ public void Download_should_download_file_if_it_doesnt_exist() { var remoteEpisode = CreateRemoteEpisode(); - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock().Verify(c => c.Get(It.Is(v => v.Url.FullUri == _downloadUrl)), Times.Once()); Mocker.GetMock().Verify(c => c.OpenWriteStream(_filePath), Times.Once()); @@ -163,7 +163,7 @@ public void Download_should_save_magnet_if_enabled() var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = null; - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock().Verify(c => c.Get(It.Is(v => v.Url.FullUri == _downloadUrl)), Times.Never()); Mocker.GetMock().Verify(c => c.OpenWriteStream(_filePath), Times.Never()); @@ -182,7 +182,7 @@ public void Download_should_save_magnet_using_specified_extension() var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = null; - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock().Verify(c => c.Get(It.Is(v => v.Url.FullUri == _downloadUrl)), Times.Never()); Mocker.GetMock().Verify(c => c.OpenWriteStream(_filePath), Times.Never()); @@ -197,7 +197,7 @@ public void Download_should_not_save_magnet_if_disabled() var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = null; - Assert.Throws(() => Subject.Download(remoteEpisode)); + Assert.Throws(() => Subject.Download(remoteEpisode, CreateIndexer())); Mocker.GetMock().Verify(c => c.Get(It.Is(v => v.Url.FullUri == _downloadUrl)), Times.Never()); Mocker.GetMock().Verify(c => c.OpenWriteStream(_filePath), Times.Never()); @@ -212,7 +212,7 @@ public void Download_should_prefer_torrent_over_magnet() var remoteEpisode = CreateRemoteEpisode(); - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock().Verify(c => c.Get(It.Is(v => v.Url.FullUri == _downloadUrl)), Times.Once()); Mocker.GetMock().Verify(c => c.OpenWriteStream(_filePath), Times.Once()); @@ -229,7 +229,7 @@ public void Download_should_replace_illegal_characters_in_title() var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.Title = illegalTitle; - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock().Verify(c => c.Get(It.Is(v => v.Url.FullUri == _downloadUrl)), Times.Once()); Mocker.GetMock().Verify(c => c.OpenWriteStream(expectedFilename), Times.Once()); @@ -242,7 +242,7 @@ public void Download_should_throw_if_magnet_and_torrent_url_does_not_exist() var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = null; - Assert.Throws(() => Subject.Download(remoteEpisode)); + Assert.Throws(() => Subject.Download(remoteEpisode, CreateIndexer())); } [Test] @@ -316,7 +316,7 @@ public void should_return_null_hash() { var remoteEpisode = CreateRemoteEpisode(); - Subject.Download(remoteEpisode).Should().BeNull(); + Subject.Download(remoteEpisode, CreateIndexer()).Should().BeNull(); } } } diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/Blackhole/UsenetBlackholeFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/Blackhole/UsenetBlackholeFixture.cs index 26bef6406..c9a3a3fb0 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/Blackhole/UsenetBlackholeFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/Blackhole/UsenetBlackholeFixture.cs @@ -119,7 +119,7 @@ public void Download_should_download_file_if_it_doesnt_exist() { var remoteEpisode = CreateRemoteEpisode(); - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock().Verify(c => c.Get(It.Is(v => v.Url.FullUri == _downloadUrl)), Times.Once()); Mocker.GetMock().Verify(c => c.OpenWriteStream(_filePath), Times.Once()); @@ -135,7 +135,7 @@ public void Download_should_replace_illegal_characters_in_title() var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.Title = illegalTitle; - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock().Verify(c => c.Get(It.Is(v => v.Url.FullUri == _downloadUrl)), Times.Once()); Mocker.GetMock().Verify(c => c.OpenWriteStream(expectedFilename), Times.Once()); diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/DelugeTests/DelugeFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/DelugeTests/DelugeFixture.cs index f94fff6ea..8998619c4 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/DelugeTests/DelugeFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/DelugeTests/DelugeFixture.cs @@ -206,7 +206,7 @@ public void Download_should_return_unique_id() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -219,7 +219,7 @@ public void Download_should_get_hash_from_magnet_url(string magnetUrl, string ex var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = magnetUrl; - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().Be(expectedHash); } diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadClientFixtureBase.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadClientFixtureBase.cs index 2ba48a0bb..64b999f30 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadClientFixtureBase.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadClientFixtureBase.cs @@ -2,16 +2,19 @@ using System.Collections.Generic; using FluentAssertions; using Moq; +using NLog; using NUnit.Framework; using NzbDrone.Common.Disk; using NzbDrone.Common.Http; using NzbDrone.Core.Configuration; using NzbDrone.Core.Download; +using NzbDrone.Core.Indexers; using NzbDrone.Core.IndexerSearch.Definitions; using NzbDrone.Core.Parser; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.RemotePathMappings; using NzbDrone.Core.Test.Framework; +using NzbDrone.Core.Test.IndexerTests; using NzbDrone.Core.Tv; namespace NzbDrone.Core.Test.Download.DownloadClientTests @@ -60,6 +63,15 @@ protected virtual RemoteEpisode CreateRemoteEpisode() return remoteEpisode; } + protected virtual IIndexer CreateIndexer() + { + return new TestIndexer(Mocker.Resolve(), + Mocker.Resolve(), + Mocker.Resolve(), + Mocker.Resolve(), + Mocker.Resolve()); + } + protected void VerifyIdentifiable(DownloadClientItem downloadClientItem) { downloadClientItem.DownloadClientInfo.Protocol.Should().Be(Subject.Protocol); diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/TorrentDownloadStationFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/TorrentDownloadStationFixture.cs index ecc1b5c8d..7928ac165 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/TorrentDownloadStationFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/TorrentDownloadStationFixture.cs @@ -381,7 +381,7 @@ public void Download_with_TvDirectory_should_force_directory() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -398,7 +398,7 @@ public void Download_with_category_should_force_directory() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -414,7 +414,7 @@ public void Download_without_TvDirectory_and_Category_should_use_default() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -493,7 +493,7 @@ public void Download_should_throw_and_not_add_task_if_cannot_get_serial_number() .Setup(s => s.GetSerialNumber(_settings)) .Throws(new ApplicationException("Some unknown exception, HttpException or DownloadClientException")); - Assert.Throws(Is.InstanceOf(), () => Subject.Download(remoteEpisode)); + Assert.Throws(Is.InstanceOf(), () => Subject.Download(remoteEpisode, CreateIndexer())); Mocker.GetMock() .Verify(v => v.AddTaskFromUrl(It.IsAny(), null, _settings), Times.Never()); diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/UsenetDownloadStationFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/UsenetDownloadStationFixture.cs index fbf06df35..240e348aa 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/UsenetDownloadStationFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/DownloadStationTests/UsenetDownloadStationFixture.cs @@ -259,7 +259,7 @@ public void Download_with_TvDirectory_should_force_directory() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -276,7 +276,7 @@ public void Download_with_category_should_force_directory() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -292,7 +292,7 @@ public void Download_without_TvDirectory_and_Category_should_use_default() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -371,7 +371,7 @@ public void Download_should_throw_and_not_add_task_if_cannot_get_serial_number() .Setup(s => s.GetSerialNumber(_settings)) .Throws(new ApplicationException("Some unknown exception, HttpException or DownloadClientException")); - Assert.Throws(Is.InstanceOf(), () => Subject.Download(remoteEpisode)); + Assert.Throws(Is.InstanceOf(), () => Subject.Download(remoteEpisode, CreateIndexer())); Mocker.GetMock() .Verify(v => v.AddTaskFromUrl(It.IsAny(), null, _settings), Times.Never()); diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/FreeboxDownloadTests/TorrentFreeboxDownloadFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/FreeboxDownloadTests/TorrentFreeboxDownloadFixture.cs index 4521b50b9..310f80f0b 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/FreeboxDownloadTests/TorrentFreeboxDownloadFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/FreeboxDownloadTests/TorrentFreeboxDownloadFixture.cs @@ -153,7 +153,7 @@ public void Download_with_DestinationDirectory_should_force_directory() var remoteEpisode = CreateRemoteEpisode(); - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock() .Verify(v => v.AddTaskFromUrl(It.IsAny(), _encodedDestinationDirectory, It.IsAny(), It.IsAny(), It.IsAny(), It.IsAny()), Times.Once()); @@ -168,7 +168,7 @@ public void Download_with_Category_should_force_directory() var remoteEpisode = CreateRemoteEpisode(); - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock() .Verify(v => v.AddTaskFromUrl(It.IsAny(), _encodedDefaultDestinationAndCategory, It.IsAny(), It.IsAny(), It.IsAny(), It.IsAny()), Times.Once()); @@ -182,7 +182,7 @@ public void Download_without_DestinationDirectory_and_Category_should_use_defaul var remoteEpisode = CreateRemoteEpisode(); - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock() .Verify(v => v.AddTaskFromUrl(It.IsAny(), _encodedDefaultDestination, It.IsAny(), It.IsAny(), It.IsAny(), It.IsAny()), Times.Once()); @@ -199,7 +199,7 @@ public void Download_should_pause_torrent_as_expected(bool addPausedSetting, boo var remoteEpisode = CreateRemoteEpisode(); - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock() .Verify(v => v.AddTaskFromUrl(It.IsAny(), It.IsAny(), toBePausedFlag, It.IsAny(), It.IsAny(), It.IsAny()), Times.Once()); @@ -230,7 +230,7 @@ public void Download_should_queue_torrent_first_as_expected(int ageDay, int olde remoteEpisode.Episodes.Add(episode); - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock() .Verify(v => v.AddTaskFromUrl(It.IsAny(), It.IsAny(), It.IsAny(), toBeQueuedFirstFlag, It.IsAny(), It.IsAny()), Times.Once()); @@ -248,7 +248,7 @@ public void Download_should_define_seed_ratio_as_expected(double? providerSeedRa remoteEpisode.SeedConfiguration = new TorrentSeedConfiguration(); remoteEpisode.SeedConfiguration.Ratio = providerSeedRatio; - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock() .Verify(v => v.AddTaskFromUrl(It.IsAny(), It.IsAny(), It.IsAny(), It.IsAny(), expectedSeedRatio, It.IsAny()), Times.Once()); diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/HadoukenTests/HadoukenFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/HadoukenTests/HadoukenFixture.cs index 1b08dfdda..dbe80b3ff 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/HadoukenTests/HadoukenFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/HadoukenTests/HadoukenFixture.cs @@ -202,7 +202,7 @@ public void Download_should_return_unique_id() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -286,7 +286,7 @@ public void Download_from_magnet_link_should_return_hash_uppercase() Mocker.GetMock() .Setup(v => v.AddTorrentUri(It.IsAny(), It.IsAny())); - var result = Subject.Download(remoteEpisode); + var result = Subject.Download(remoteEpisode, CreateIndexer()); Assert.IsFalse(result.Any(c => char.IsLower(c))); } @@ -300,7 +300,7 @@ public void Download_from_torrent_file_should_return_hash_uppercase() .Setup(v => v.AddTorrentFile(It.IsAny(), It.IsAny())) .Returns("hash"); - var result = Subject.Download(remoteEpisode); + var result = Subject.Download(remoteEpisode, CreateIndexer()); Assert.IsFalse(result.Any(c => char.IsLower(c))); } diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/NzbVortexTests/NzbVortexFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/NzbVortexTests/NzbVortexFixture.cs index f33aa5e0c..70b2cb784 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/NzbVortexTests/NzbVortexFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/NzbVortexTests/NzbVortexFixture.cs @@ -206,7 +206,7 @@ public void Download_should_return_unique_id() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -218,7 +218,7 @@ public void Download_should_throw_if_failed() var remoteEpisode = CreateRemoteEpisode(); - Assert.Throws(() => Subject.Download(remoteEpisode)); + Assert.Throws(() => Subject.Download(remoteEpisode, CreateIndexer())); } [Test] diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/NzbgetTests/NzbgetFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/NzbgetTests/NzbgetFixture.cs index 3e2ef2c54..cb086a27e 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/NzbgetTests/NzbgetFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/NzbgetTests/NzbgetFixture.cs @@ -346,7 +346,7 @@ public void Download_should_return_unique_id() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -358,7 +358,7 @@ public void Download_should_throw_if_failed() var remoteEpisode = CreateRemoteEpisode(); - Assert.Throws(() => Subject.Download(remoteEpisode)); + Assert.Throws(() => Subject.Download(remoteEpisode, CreateIndexer())); } [Test] diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/PneumaticProviderFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/PneumaticProviderFixture.cs index 00d90c438..fd5853f76 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/PneumaticProviderFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/PneumaticProviderFixture.cs @@ -3,12 +3,17 @@ using System.Net; using FizzWare.NBuilder; using Moq; +using NLog; using NUnit.Framework; using NzbDrone.Common.Http; +using NzbDrone.Core.Configuration; using NzbDrone.Core.Download; using NzbDrone.Core.Download.Clients.Pneumatic; +using NzbDrone.Core.Indexers; +using NzbDrone.Core.Parser; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.Test.Framework; +using NzbDrone.Core.Test.IndexerTests; using NzbDrone.Test.Common; namespace NzbDrone.Core.Test.Download.DownloadClientTests @@ -22,6 +27,7 @@ public class PneumaticProviderFixture : CoreTest private string _strmFolder; private string _nzbPath; private RemoteEpisode _remoteEpisode; + private IIndexer _indexer; private DownloadClientItem _downloadClientItem; [SetUp] @@ -40,6 +46,12 @@ public void Setup() _remoteEpisode.ParsedEpisodeInfo = new ParsedEpisodeInfo(); _remoteEpisode.ParsedEpisodeInfo.FullSeason = false; + _indexer = new TestIndexer(Mocker.Resolve(), + Mocker.Resolve(), + Mocker.Resolve(), + Mocker.Resolve(), + Mocker.Resolve()); + _downloadClientItem = Builder .CreateNew().With(d => d.DownloadId = "_Droned.S01E01.Pilot.1080p.WEB-DL-DRONE_0") .Build(); @@ -60,7 +72,7 @@ private void WithFailedDownload() [Test] public void should_download_file_if_it_doesnt_exist() { - Subject.Download(_remoteEpisode); + Subject.Download(_remoteEpisode, _indexer); Mocker.GetMock().Verify(c => c.DownloadFile(_nzbUrl, _nzbPath), Times.Once()); } @@ -70,7 +82,7 @@ public void should_throw_on_failed_download() { WithFailedDownload(); - Assert.Throws(() => Subject.Download(_remoteEpisode)); + Assert.Throws(() => Subject.Download(_remoteEpisode, _indexer)); } [Test] @@ -79,7 +91,7 @@ public void should_throw_if_full_season_download() _remoteEpisode.Release.Title = "30 Rock - Season 1"; _remoteEpisode.ParsedEpisodeInfo.FullSeason = true; - Assert.Throws(() => Subject.Download(_remoteEpisode)); + Assert.Throws(() => Subject.Download(_remoteEpisode, _indexer)); } [Test] @@ -95,7 +107,7 @@ public void should_replace_illegal_characters_in_title() var expectedFilename = Path.Combine(_pneumaticFolder, "Saturday Night Live - S38E08 - Jeremy Renner+Maroon 5 [SDTV].nzb"); _remoteEpisode.Release.Title = illegalTitle; - Subject.Download(_remoteEpisode); + Subject.Download(_remoteEpisode, _indexer); Mocker.GetMock().Verify(c => c.DownloadFile(It.IsAny(), expectedFilename), Times.Once()); } diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/QBittorrentTests/QBittorrentFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/QBittorrentTests/QBittorrentFixture.cs index 004dc7ff0..f63d04de6 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/QBittorrentTests/QBittorrentFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/QBittorrentTests/QBittorrentFixture.cs @@ -454,7 +454,7 @@ public void Download_should_return_unique_id() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -467,7 +467,7 @@ public void Download_should_get_hash_from_magnet_url(string magnetUrl, string ex var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = magnetUrl; - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().Be(expectedHash); } @@ -482,7 +482,7 @@ public void Download_should_refuse_magnet_if_no_trackers_provided_and_dht_is_dis var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = "magnet:?xt=urn:btih:ZPBPA2P6ROZPKRHK44D5OW6NHXU5Z6KR"; - Assert.Throws(() => Subject.Download(remoteEpisode)); + Assert.Throws(() => Subject.Download(remoteEpisode, CreateIndexer())); } [Test] @@ -495,7 +495,7 @@ public void Download_should_accept_magnet_if_trackers_provided_and_dht_is_disabl var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = "magnet:?xt=urn:btih:ZPBPA2P6ROZPKRHK44D5OW6NHXU5Z6KR&tr=udp://abc"; - Assert.DoesNotThrow(() => Subject.Download(remoteEpisode)); + Assert.DoesNotThrow(() => Subject.Download(remoteEpisode, CreateIndexer())); Mocker.GetMock() .Verify(s => s.AddTorrentFromUrl(It.IsAny(), It.IsAny(), It.IsAny()), Times.Once()); @@ -509,7 +509,7 @@ public void Download_should_set_top_priority() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock() .Verify(v => v.MoveTorrentToTopInQueue(It.IsAny(), It.IsAny()), Times.Once()); @@ -527,7 +527,7 @@ public void Download_should_not_fail_if_top_priority_not_available() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -561,7 +561,7 @@ public void Download_should_handle_http_redirect_to_magnet() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -574,7 +574,7 @@ public void Download_should_handle_http_redirect_to_torrent() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/RTorrentTests/RTorrentFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/RTorrentTests/RTorrentFixture.cs index 257d1cdca..655edd3ee 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/RTorrentTests/RTorrentFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/RTorrentTests/RTorrentFixture.cs @@ -117,7 +117,7 @@ public void Download_should_return_unique_id() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/SabnzbdTests/SabnzbdFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/SabnzbdTests/SabnzbdFixture.cs index 6597410b8..cd8836ef6 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/SabnzbdTests/SabnzbdFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/SabnzbdTests/SabnzbdFixture.cs @@ -308,7 +308,7 @@ public void Download_should_use_clean_title(string title, string filename) var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.Title = title; - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock() .Verify(v => v.DownloadNzb(It.IsAny(), filename, It.IsAny(), It.IsAny(), It.IsAny()), Times.Once()); @@ -321,7 +321,7 @@ public void Download_should_return_unique_id() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -367,7 +367,7 @@ public void Download_should_use_sabRecentTvPriority_when_recentEpisode_is_true() .Build() .ToList(); - Subject.Download(remoteEpisode); + Subject.Download(remoteEpisode, CreateIndexer()); Mocker.GetMock() .Verify(v => v.DownloadNzb(It.IsAny(), It.IsAny(), It.IsAny(), (int)SabnzbdPriority.High, It.IsAny()), Times.Once()); diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/TransmissionTests/TransmissionFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/TransmissionTests/TransmissionFixture.cs index 6778fefbb..04402fb10 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/TransmissionTests/TransmissionFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/TransmissionTests/TransmissionFixture.cs @@ -61,7 +61,7 @@ public void Download_should_return_unique_id() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -74,7 +74,7 @@ public void Download_with_TvDirectory_should_force_directory() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -90,7 +90,7 @@ public void Download_with_category_should_force_directory() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -108,7 +108,7 @@ public void Download_with_category_should_not_have_double_slashes() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -123,7 +123,7 @@ public void Download_without_TvDirectory_and_Category_should_use_default() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -139,7 +139,7 @@ public void Download_should_get_hash_from_magnet_url(string magnetUrl, string ex var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = magnetUrl; - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().Be(expectedHash); } diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/UTorrentTests/UTorrentFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/UTorrentTests/UTorrentFixture.cs index 5a7e8b432..32c2fe2e2 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/UTorrentTests/UTorrentFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/UTorrentTests/UTorrentFixture.cs @@ -234,7 +234,7 @@ public void Download_should_return_unique_id() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -259,7 +259,7 @@ public void Download_should_get_hash_from_magnet_url(string magnetUrl, string ex var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = magnetUrl; - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().Be(expectedHash); } @@ -357,7 +357,7 @@ public void Download_should_handle_http_redirect_to_magnet() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -370,7 +370,7 @@ public void Download_should_handle_http_redirect_to_torrent() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } diff --git a/src/NzbDrone.Core.Test/Download/DownloadClientTests/VuzeTests/VuzeFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadClientTests/VuzeTests/VuzeFixture.cs index 89532d84f..5d06ba0a7 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadClientTests/VuzeTests/VuzeFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadClientTests/VuzeTests/VuzeFixture.cs @@ -69,7 +69,7 @@ public void Download_should_return_unique_id() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); } @@ -82,7 +82,7 @@ public void Download_with_TvDirectory_should_force_directory() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -98,7 +98,7 @@ public void Download_with_category_should_force_directory() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -116,7 +116,7 @@ public void Download_with_category_should_not_have_double_slashes() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -131,7 +131,7 @@ public void Download_without_TvDirectory_and_Category_should_use_default() var remoteEpisode = CreateRemoteEpisode(); - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().NotBeNullOrEmpty(); @@ -147,7 +147,7 @@ public void Download_should_get_hash_from_magnet_url(string magnetUrl, string ex var remoteEpisode = CreateRemoteEpisode(); remoteEpisode.Release.DownloadUrl = magnetUrl; - var id = Subject.Download(remoteEpisode); + var id = Subject.Download(remoteEpisode, CreateIndexer()); id.Should().Be(expectedHash); } diff --git a/src/NzbDrone.Core.Test/Download/DownloadServiceFixture.cs b/src/NzbDrone.Core.Test/Download/DownloadServiceFixture.cs index b2954fcc1..bace5b65e 100644 --- a/src/NzbDrone.Core.Test/Download/DownloadServiceFixture.cs +++ b/src/NzbDrone.Core.Test/Download/DownloadServiceFixture.cs @@ -82,7 +82,7 @@ private Mock WithTorrentClient() public void Download_report_should_publish_on_grab_event() { var mock = WithUsenetClient(); - mock.Setup(s => s.Download(It.IsAny())); + mock.Setup(s => s.Download(It.IsAny(), It.IsAny())); Subject.DownloadReport(_parseResult, null); @@ -93,18 +93,18 @@ public void Download_report_should_publish_on_grab_event() public void Download_report_should_grab_using_client() { var mock = WithUsenetClient(); - mock.Setup(s => s.Download(It.IsAny())); + mock.Setup(s => s.Download(It.IsAny(), It.IsAny())); Subject.DownloadReport(_parseResult, null); - mock.Verify(s => s.Download(It.IsAny()), Times.Once()); + mock.Verify(s => s.Download(It.IsAny(), It.IsAny()), Times.Once()); } [Test] public void Download_report_should_not_publish_on_failed_grab_event() { var mock = WithUsenetClient(); - mock.Setup(s => s.Download(It.IsAny())) + mock.Setup(s => s.Download(It.IsAny(), It.IsAny())) .Throws(new WebException()); Assert.Throws(() => Subject.DownloadReport(_parseResult, null)); @@ -116,8 +116,8 @@ public void Download_report_should_not_publish_on_failed_grab_event() public void Download_report_should_trigger_indexer_backoff_on_indexer_error() { var mock = WithUsenetClient(); - mock.Setup(s => s.Download(It.IsAny())) - .Callback(v => + mock.Setup(s => s.Download(It.IsAny(), It.IsAny())) + .Callback((v, indexer) => { throw new ReleaseDownloadException(v.Release, "Error", new WebException()); }); @@ -136,8 +136,8 @@ public void Download_report_should_trigger_indexer_backoff_on_http429_with_long_ response.Headers["Retry-After"] = "300"; var mock = WithUsenetClient(); - mock.Setup(s => s.Download(It.IsAny())) - .Callback(v => + mock.Setup(s => s.Download(It.IsAny(), It.IsAny())) + .Callback((v, indexer) => { throw new ReleaseDownloadException(v.Release, "Error", new TooManyRequestsException(request, response)); }); @@ -156,8 +156,8 @@ public void Download_report_should_trigger_indexer_backoff_on_http429_based_on_d response.Headers["Retry-After"] = DateTime.UtcNow.AddSeconds(300).ToString("r"); var mock = WithUsenetClient(); - mock.Setup(s => s.Download(It.IsAny())) - .Callback(v => + mock.Setup(s => s.Download(It.IsAny(), It.IsAny())) + .Callback((v, indexer) => { throw new ReleaseDownloadException(v.Release, "Error", new TooManyRequestsException(request, response)); }); @@ -173,7 +173,7 @@ public void Download_report_should_trigger_indexer_backoff_on_http429_based_on_d public void Download_report_should_not_trigger_indexer_backoff_on_downloadclient_error() { var mock = WithUsenetClient(); - mock.Setup(s => s.Download(It.IsAny())) + mock.Setup(s => s.Download(It.IsAny(), It.IsAny())) .Throws(new DownloadClientException("Some Error")); Assert.Throws(() => Subject.DownloadReport(_parseResult, null)); @@ -186,8 +186,8 @@ public void Download_report_should_not_trigger_indexer_backoff_on_downloadclient public void Download_report_should_not_trigger_indexer_backoff_on_indexer_404_error() { var mock = WithUsenetClient(); - mock.Setup(s => s.Download(It.IsAny())) - .Callback(v => + mock.Setup(s => s.Download(It.IsAny(), It.IsAny())) + .Callback((v, indexer) => { throw new ReleaseUnavailableException(v.Release, "Error", new WebException()); }); @@ -203,7 +203,7 @@ public void should_not_attempt_download_if_client_isnt_configured() { Assert.Throws(() => Subject.DownloadReport(_parseResult, null)); - Mocker.GetMock().Verify(c => c.Download(It.IsAny()), Times.Never()); + Mocker.GetMock().Verify(c => c.Download(It.IsAny(), It.IsAny()), Times.Never()); VerifyEventNotPublished(); } @@ -226,7 +226,7 @@ public void should_attempt_download_even_if_client_is_disabled() Subject.DownloadReport(_parseResult, null); Mocker.GetMock().Verify(c => c.GetBlockedProviders(), Times.Never()); - mockUsenet.Verify(c => c.Download(It.IsAny()), Times.Once()); + mockUsenet.Verify(c => c.Download(It.IsAny(), It.IsAny()), Times.Once()); VerifyEventPublished(); } @@ -238,8 +238,8 @@ public void should_send_download_to_correct_usenet_client() Subject.DownloadReport(_parseResult, null); - mockTorrent.Verify(c => c.Download(It.IsAny()), Times.Never()); - mockUsenet.Verify(c => c.Download(It.IsAny()), Times.Once()); + mockTorrent.Verify(c => c.Download(It.IsAny(), It.IsAny()), Times.Never()); + mockUsenet.Verify(c => c.Download(It.IsAny(), It.IsAny()), Times.Once()); } [Test] @@ -252,8 +252,8 @@ public void should_send_download_to_correct_torrent_client() Subject.DownloadReport(_parseResult, null); - mockTorrent.Verify(c => c.Download(It.IsAny()), Times.Once()); - mockUsenet.Verify(c => c.Download(It.IsAny()), Times.Never()); + mockTorrent.Verify(c => c.Download(It.IsAny(), It.IsAny()), Times.Once()); + mockUsenet.Verify(c => c.Download(It.IsAny(), It.IsAny()), Times.Never()); } } } diff --git a/src/NzbDrone.Core/Download/Clients/Pneumatic/Pneumatic.cs b/src/NzbDrone.Core/Download/Clients/Pneumatic/Pneumatic.cs index b5a685866..298de88e2 100644 --- a/src/NzbDrone.Core/Download/Clients/Pneumatic/Pneumatic.cs +++ b/src/NzbDrone.Core/Download/Clients/Pneumatic/Pneumatic.cs @@ -32,7 +32,7 @@ public Pneumatic(IHttpClient httpClient, public override DownloadProtocol Protocol => DownloadProtocol.Usenet; - public override string Download(RemoteEpisode remoteEpisode) + public override string Download(RemoteEpisode remoteEpisode, IIndexer indexer) { var url = remoteEpisode.Release.DownloadUrl; var title = remoteEpisode.Release.Title; diff --git a/src/NzbDrone.Core/Download/DownloadClientBase.cs b/src/NzbDrone.Core/Download/DownloadClientBase.cs index 2abdb5207..985a918b7 100644 --- a/src/NzbDrone.Core/Download/DownloadClientBase.cs +++ b/src/NzbDrone.Core/Download/DownloadClientBase.cs @@ -58,7 +58,7 @@ public abstract DownloadProtocol Protocol get; } - public abstract string Download(RemoteEpisode remoteEpisode); + public abstract string Download(RemoteEpisode remoteEpisode, IIndexer indexer); public abstract IEnumerable GetItems(); public virtual DownloadClientItem GetImportItem(DownloadClientItem item, DownloadClientItem previousImportAttempt) diff --git a/src/NzbDrone.Core/Download/DownloadService.cs b/src/NzbDrone.Core/Download/DownloadService.cs index b70fbf3c6..96a8a8730 100644 --- a/src/NzbDrone.Core/Download/DownloadService.cs +++ b/src/NzbDrone.Core/Download/DownloadService.cs @@ -22,6 +22,7 @@ public class DownloadService : IDownloadService { private readonly IProvideDownloadClient _downloadClientProvider; private readonly IDownloadClientStatusService _downloadClientStatusService; + private readonly IIndexerFactory _indexerFactory; private readonly IIndexerStatusService _indexerStatusService; private readonly IRateLimitService _rateLimitService; private readonly IEventAggregator _eventAggregator; @@ -30,6 +31,7 @@ public class DownloadService : IDownloadService public DownloadService(IProvideDownloadClient downloadClientProvider, IDownloadClientStatusService downloadClientStatusService, + IIndexerFactory indexerFactory, IIndexerStatusService indexerStatusService, IRateLimitService rateLimitService, IEventAggregator eventAggregator, @@ -38,6 +40,7 @@ public DownloadService(IProvideDownloadClient downloadClientProvider, { _downloadClientProvider = downloadClientProvider; _downloadClientStatusService = downloadClientStatusService; + _indexerFactory = indexerFactory; _indexerStatusService = indexerStatusService; _rateLimitService = rateLimitService; _eventAggregator = eventAggregator; @@ -68,6 +71,7 @@ private void DownloadReport(RemoteEpisode remoteEpisode, IDownloadClient downloa // Get the seed configuration for this release. remoteEpisode.SeedConfiguration = _seedConfigProvider.GetSeedConfiguration(remoteEpisode); + var indexer = _indexerFactory.GetInstance(_indexerFactory.Get(remoteEpisode.Release.IndexerId)); // Limit grabs to 2 per second. if (remoteEpisode.Release.DownloadUrl.IsNotNullOrWhiteSpace() && !remoteEpisode.Release.DownloadUrl.StartsWith("magnet:")) @@ -79,7 +83,7 @@ private void DownloadReport(RemoteEpisode remoteEpisode, IDownloadClient downloa string downloadClientId; try { - downloadClientId = downloadClient.Download(remoteEpisode); + downloadClientId = downloadClient.Download(remoteEpisode, indexer); _downloadClientStatusService.RecordSuccess(downloadClient.Definition.Id); _indexerStatusService.RecordSuccess(remoteEpisode.Release.IndexerId); } diff --git a/src/NzbDrone.Core/Download/IDownloadClient.cs b/src/NzbDrone.Core/Download/IDownloadClient.cs index 612ba79c3..262591ebc 100644 --- a/src/NzbDrone.Core/Download/IDownloadClient.cs +++ b/src/NzbDrone.Core/Download/IDownloadClient.cs @@ -8,7 +8,7 @@ namespace NzbDrone.Core.Download public interface IDownloadClient : IProvider { DownloadProtocol Protocol { get; } - string Download(RemoteEpisode remoteEpisode); + string Download(RemoteEpisode remoteEpisode, IIndexer indexer); IEnumerable GetItems(); DownloadClientItem GetImportItem(DownloadClientItem item, DownloadClientItem previousImportAttempt); void RemoveItem(DownloadClientItem item, bool deleteData); diff --git a/src/NzbDrone.Core/Download/TorrentClientBase.cs b/src/NzbDrone.Core/Download/TorrentClientBase.cs index 161ee3f12..a54294ab7 100644 --- a/src/NzbDrone.Core/Download/TorrentClientBase.cs +++ b/src/NzbDrone.Core/Download/TorrentClientBase.cs @@ -41,7 +41,7 @@ protected TorrentClientBase(ITorrentFileInfoReader torrentFileInfoReader, protected abstract string AddFromMagnetLink(RemoteEpisode remoteEpisode, string hash, string magnetLink); protected abstract string AddFromTorrentFile(RemoteEpisode remoteEpisode, string hash, string filename, byte[] fileContent); - public override string Download(RemoteEpisode remoteEpisode) + public override string Download(RemoteEpisode remoteEpisode, IIndexer indexer) { var torrentInfo = remoteEpisode.Release as TorrentInfo; @@ -68,7 +68,7 @@ public override string Download(RemoteEpisode remoteEpisode) { try { - return DownloadFromWebUrl(remoteEpisode, torrentUrl); + return DownloadFromWebUrl(remoteEpisode, indexer, torrentUrl); } catch (Exception ex) { @@ -114,20 +114,20 @@ public override string Download(RemoteEpisode remoteEpisode) if (torrentUrl.IsNotNullOrWhiteSpace()) { - return DownloadFromWebUrl(remoteEpisode, torrentUrl); + return DownloadFromWebUrl(remoteEpisode, indexer, torrentUrl); } } return null; } - private string DownloadFromWebUrl(RemoteEpisode remoteEpisode, string torrentUrl) + private string DownloadFromWebUrl(RemoteEpisode remoteEpisode, IIndexer indexer, string torrentUrl) { byte[] torrentFile = null; try { - var request = new HttpRequest(torrentUrl); + var request = indexer.GetDownloadRequest(torrentUrl); request.RateLimitKey = remoteEpisode?.Release?.IndexerId.ToString(); request.Headers.Accept = "application/x-bittorrent"; request.AllowAutoRedirect = false; @@ -149,7 +149,9 @@ private string DownloadFromWebUrl(RemoteEpisode remoteEpisode, string torrentUrl return DownloadFromMagnetUrl(remoteEpisode, locationHeader); } - return DownloadFromWebUrl(remoteEpisode, locationHeader); + request.Url += new HttpUri(locationHeader); + + return DownloadFromWebUrl(remoteEpisode, indexer, request.Url.ToString()); } throw new WebException("Remote website tried to redirect without providing a location."); diff --git a/src/NzbDrone.Core/Download/UsenetClientBase.cs b/src/NzbDrone.Core/Download/UsenetClientBase.cs index 929f0a20c..5e427bcd6 100644 --- a/src/NzbDrone.Core/Download/UsenetClientBase.cs +++ b/src/NzbDrone.Core/Download/UsenetClientBase.cs @@ -34,7 +34,7 @@ protected UsenetClientBase(IHttpClient httpClient, protected abstract string AddFromNzbFile(RemoteEpisode remoteEpisode, string filename, byte[] fileContent); - public override string Download(RemoteEpisode remoteEpisode) + public override string Download(RemoteEpisode remoteEpisode, IIndexer indexer) { var url = remoteEpisode.Release.DownloadUrl; var filename = FileNameBuilder.CleanFileName(remoteEpisode.Release.Title) + ".nzb"; @@ -43,7 +43,7 @@ public override string Download(RemoteEpisode remoteEpisode) try { - var request = new HttpRequest(url); + var request = indexer.GetDownloadRequest(url); request.RateLimitKey = remoteEpisode?.Release?.IndexerId.ToString(); nzbData = _httpClient.Get(request).ResponseData; diff --git a/src/NzbDrone.Core/Indexers/HttpIndexerBase.cs b/src/NzbDrone.Core/Indexers/HttpIndexerBase.cs index a81410bce..0be68fb9a 100644 --- a/src/NzbDrone.Core/Indexers/HttpIndexerBase.cs +++ b/src/NzbDrone.Core/Indexers/HttpIndexerBase.cs @@ -12,7 +12,6 @@ using NzbDrone.Core.IndexerSearch.Definitions; using NzbDrone.Core.Parser; using NzbDrone.Core.Parser.Model; -using NzbDrone.Core.ThingiProvider; namespace NzbDrone.Core.Indexers { @@ -109,6 +108,11 @@ public override IList Fetch(SpecialEpisodeSearchCriteria searchCrit return FetchReleases(g => g.GetSearchRequests(searchCriteria)); } + public override HttpRequest GetDownloadRequest(string link) + { + return new HttpRequest(link); + } + protected virtual IList FetchReleases(Func pageableRequestChainSelector, bool isRecent = false) { var releases = new List(); diff --git a/src/NzbDrone.Core/Indexers/IIndexer.cs b/src/NzbDrone.Core/Indexers/IIndexer.cs index e306756a7..420f4d29f 100644 --- a/src/NzbDrone.Core/Indexers/IIndexer.cs +++ b/src/NzbDrone.Core/Indexers/IIndexer.cs @@ -1,4 +1,5 @@ using System.Collections.Generic; +using NzbDrone.Common.Http; using NzbDrone.Core.IndexerSearch.Definitions; using NzbDrone.Core.Parser.Model; using NzbDrone.Core.ThingiProvider; @@ -18,5 +19,6 @@ public interface IIndexer : IProvider IList Fetch(DailySeasonSearchCriteria searchCriteria); IList Fetch(AnimeEpisodeSearchCriteria searchCriteria); IList Fetch(SpecialEpisodeSearchCriteria searchCriteria); + HttpRequest GetDownloadRequest(string link); } } diff --git a/src/NzbDrone.Core/Indexers/IndexerBase.cs b/src/NzbDrone.Core/Indexers/IndexerBase.cs index 8c469645f..81d94378a 100644 --- a/src/NzbDrone.Core/Indexers/IndexerBase.cs +++ b/src/NzbDrone.Core/Indexers/IndexerBase.cs @@ -3,7 +3,7 @@ using System.Linq; using FluentValidation.Results; using NLog; -using NzbDrone.Common.Extensions; +using NzbDrone.Common.Http; using NzbDrone.Core.Configuration; using NzbDrone.Core.IndexerSearch.Definitions; using NzbDrone.Core.Parser; @@ -74,6 +74,7 @@ public virtual object RequestAction(string action, IDictionary q public abstract IList Fetch(DailySeasonSearchCriteria searchCriteria); public abstract IList Fetch(AnimeEpisodeSearchCriteria searchCriteria); public abstract IList Fetch(SpecialEpisodeSearchCriteria searchCriteria); + public abstract HttpRequest GetDownloadRequest(string link); protected virtual IList CleanupReleases(IEnumerable releases) {