Fixed: Lidarr Lists use correct metadata server (#800)

pull/6/head
Qstick 6 years ago committed by GitHub
parent 35c19dac5f
commit add32ff9f3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -0,0 +1,51 @@
using FluentAssertions;
using NUnit.Framework;
using NzbDrone.Core.MetadataSource;
using NzbDrone.Core.Test.Framework;
using NzbDrone.Core.Configuration;
using NzbDrone.Common.Cloud;
using NzbDrone.Common.Http;
namespace NzbDrone.Core.Test.MetadataSource
{
[TestFixture]
public class MetadataRequestBuilderFixture : CoreTest<MetadataRequestBuilder>
{
[SetUp]
public void Setup()
{
Mocker.GetMock<IConfigService>()
.Setup(s => s.MetadataSource)
.Returns("");
Mocker.GetMock<ILidarrCloudRequestBuilder>()
.Setup(s => s.Search)
.Returns(new HttpRequestBuilder("https://api.lidarr.audio/api/v0.4/{route}").CreateFactory());
}
private void WithCustomProvider()
{
Mocker.GetMock<IConfigService>()
.Setup(s => s.MetadataSource)
.Returns("http://api.lidarr.audio/api/testing/");
}
[TestCase]
public void should_use_user_definied_if_not_blank()
{
WithCustomProvider();
var details = Subject.GetRequestBuilder().Create();
details.BaseUrl.ToString().Should().Contain("testing");
}
[TestCase]
public void should_use_default_if_config_blank()
{
var details = Subject.GetRequestBuilder().Create();
details.BaseUrl.ToString().Should().Contain("v0.4");
}
}
}

@ -311,6 +311,7 @@
<Compile Include="MediaFiles\ImportApprovedTracksFixture.cs" /> <Compile Include="MediaFiles\ImportApprovedTracksFixture.cs" />
<Compile Include="MediaFiles\MediaFileRepositoryFixture.cs" /> <Compile Include="MediaFiles\MediaFileRepositoryFixture.cs" />
<Compile Include="Messaging\Commands\CommandQueueManagerFixture.cs" /> <Compile Include="Messaging\Commands\CommandQueueManagerFixture.cs" />
<Compile Include="MetadataSource\MetadataRequestBuilderFixture.cs" />
<Compile Include="MetadataSource\SkyHook\SkyHookProxySearchFixture.cs" /> <Compile Include="MetadataSource\SkyHook\SkyHookProxySearchFixture.cs" />
<Compile Include="MetadataSource\SearchArtistComparerFixture.cs" /> <Compile Include="MetadataSource\SearchArtistComparerFixture.cs" />
<Compile Include="MetadataSource\SkyHook\SkyHookProxyFixture.cs" /> <Compile Include="MetadataSource\SkyHook\SkyHookProxyFixture.cs" />
@ -634,4 +635,4 @@
</ItemGroup> </ItemGroup>
<Copy SourceFiles="@(IdentificationTestCases)" DestinationFolder="$(OutputPath)\Files\Identification\" SkipUnchangedFiles="true" /> <Copy SourceFiles="@(IdentificationTestCases)" DestinationFolder="$(OutputPath)\Files\Identification\" SkipUnchangedFiles="true" />
</Target> </Target>
</Project> </Project>

@ -4,6 +4,7 @@ using NzbDrone.Common.Http;
using NzbDrone.Core.Configuration; using NzbDrone.Core.Configuration;
using NzbDrone.Core.Parser; using NzbDrone.Core.Parser;
using NzbDrone.Core.ThingiProvider; using NzbDrone.Core.ThingiProvider;
using NzbDrone.Core.MetadataSource;
namespace NzbDrone.Core.ImportLists.LidarrLists namespace NzbDrone.Core.ImportLists.LidarrLists
{ {
@ -13,10 +14,12 @@ namespace NzbDrone.Core.ImportLists.LidarrLists
public override int PageSize => 10; public override int PageSize => 10;
public LidarrLists(IHttpClient httpClient, IImportListStatusService importListStatusService, IConfigService configService, IParsingService parsingService, Logger logger) private readonly IMetadataRequestBuilder _requestBuilder;
public LidarrLists(IHttpClient httpClient, IImportListStatusService importListStatusService, IConfigService configService, IParsingService parsingService, IMetadataRequestBuilder requestBuilder, Logger logger)
: base(httpClient, importListStatusService, configService, parsingService, logger) : base(httpClient, importListStatusService, configService, parsingService, logger)
{ {
_requestBuilder = requestBuilder;
} }
public override IEnumerable<ProviderDefinition> DefaultDefinitions public override IEnumerable<ProviderDefinition> DefaultDefinitions
@ -29,7 +32,6 @@ namespace NzbDrone.Core.ImportLists.LidarrLists
yield return GetDefinition("Apple Music New Albums", GetSettings("apple-music/album/new")); yield return GetDefinition("Apple Music New Albums", GetSettings("apple-music/album/new"));
yield return GetDefinition("Billboard Top Albums", GetSettings("billboard/album/top")); yield return GetDefinition("Billboard Top Albums", GetSettings("billboard/album/top"));
yield return GetDefinition("Billboard Top Artists", GetSettings("billboard/artist/top")); yield return GetDefinition("Billboard Top Artists", GetSettings("billboard/artist/top"));
yield return GetDefinition("Last.fm Top Albums", GetSettings("lastfm/album/top"));
yield return GetDefinition("Last.fm Top Artists", GetSettings("lastfm/artist/top")); yield return GetDefinition("Last.fm Top Artists", GetSettings("lastfm/artist/top"));
} }
} }
@ -54,7 +56,7 @@ namespace NzbDrone.Core.ImportLists.LidarrLists
public override IImportListRequestGenerator GetRequestGenerator() public override IImportListRequestGenerator GetRequestGenerator()
{ {
return new LidarrListsRequestGenerator { Settings = Settings, PageSize = PageSize }; return new LidarrListsRequestGenerator(_requestBuilder) { Settings = Settings };
} }
public override IParseImportListResponse GetParser() public override IParseImportListResponse GetParser()

@ -1,5 +1,5 @@
using System.Collections.Generic; using System.Collections.Generic;
using NzbDrone.Common.Http; using NzbDrone.Core.MetadataSource;
namespace NzbDrone.Core.ImportLists.LidarrLists namespace NzbDrone.Core.ImportLists.LidarrLists
{ {
@ -7,13 +7,11 @@ namespace NzbDrone.Core.ImportLists.LidarrLists
{ {
public LidarrListsSettings Settings { get; set; } public LidarrListsSettings Settings { get; set; }
public int MaxPages { get; set; } private readonly IMetadataRequestBuilder _requestBulder;
public int PageSize { get; set; }
public LidarrListsRequestGenerator() public LidarrListsRequestGenerator(IMetadataRequestBuilder requestBuilder)
{ {
MaxPages = 1; _requestBulder = requestBuilder;
PageSize = 10;
} }
public virtual ImportListPageableRequestChain GetListItems() public virtual ImportListPageableRequestChain GetListItems()
@ -27,8 +25,12 @@ namespace NzbDrone.Core.ImportLists.LidarrLists
private IEnumerable<ImportListRequest> GetPagedRequests() private IEnumerable<ImportListRequest> GetPagedRequests()
{ {
yield return new ImportListRequest(string.Format("{0}{1}", Settings.BaseUrl, Settings.ListId), HttpAccept.Json); var request = _requestBulder.GetRequestBuilder()
} .Create()
.SetSegment("route", "chart/" + Settings.ListId)
.Build();
yield return new ImportListRequest(request);
}
} }
} }

@ -8,7 +8,6 @@ namespace NzbDrone.Core.ImportLists.LidarrLists
{ {
public LidarrListsSettingsValidator() public LidarrListsSettingsValidator()
{ {
RuleFor(c => c.BaseUrl).ValidRootUrl();
} }
} }
@ -18,7 +17,7 @@ namespace NzbDrone.Core.ImportLists.LidarrLists
public LidarrListsSettings() public LidarrListsSettings()
{ {
BaseUrl = "https://api.lidarr.audio/api/v0.3/chart/"; BaseUrl = "";
} }
public string BaseUrl { get; set; } public string BaseUrl { get; set; }

@ -0,0 +1,37 @@
using NzbDrone.Common.Cloud;
using NzbDrone.Common.Extensions;
using NzbDrone.Common.Http;
using NzbDrone.Core.Configuration;
namespace NzbDrone.Core.MetadataSource
{
public interface IMetadataRequestBuilder
{
IHttpRequestBuilderFactory GetRequestBuilder();
}
public class MetadataRequestBuilder : IMetadataRequestBuilder
{
private readonly IConfigService _configService;
private readonly ILidarrCloudRequestBuilder _defaultRequestFactory;
public MetadataRequestBuilder(IConfigService configService, ILidarrCloudRequestBuilder defaultRequestBuilder)
{
_configService = configService;
_defaultRequestFactory = defaultRequestBuilder;
}
public IHttpRequestBuilderFactory GetRequestBuilder()
{
if (_configService.MetadataSource.IsNotNullOrWhiteSpace())
{
return new HttpRequestBuilder(_configService.MetadataSource.TrimEnd("/") + "/{route}").CreateFactory();
}
else
{
return _defaultRequestFactory.Search;
}
}
}
}

@ -21,17 +21,15 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
private readonly Logger _logger; private readonly Logger _logger;
private readonly IArtistService _artistService; private readonly IArtistService _artistService;
private readonly IAlbumService _albumService; private readonly IAlbumService _albumService;
private readonly IHttpRequestBuilderFactory _requestBuilder; private readonly IMetadataRequestBuilder _requestBuilder;
private readonly IConfigService _configService; private readonly IConfigService _configService;
private readonly IMetadataProfileService _metadataProfileService; private readonly IMetadataProfileService _metadataProfileService;
private static readonly List<string> nonAudioMedia = new List<string> { "DVD", "DVD-Video", "Blu-ray", "HD-DVD", "VCD", "SVCD", "UMD", "VHS" }; private static readonly List<string> nonAudioMedia = new List<string> { "DVD", "DVD-Video", "Blu-ray", "HD-DVD", "VCD", "SVCD", "UMD", "VHS" };
private static readonly List<string> skippedTracks = new List<string> { "[data track]" }; private static readonly List<string> skippedTracks = new List<string> { "[data track]" };
private IHttpRequestBuilderFactory _customerRequestBuilder;
public SkyHookProxy(IHttpClient httpClient, public SkyHookProxy(IHttpClient httpClient,
ILidarrCloudRequestBuilder requestBuilder, IMetadataRequestBuilder requestBuilder,
IArtistService artistService, IArtistService artistService,
IAlbumService albumService, IAlbumService albumService,
Logger logger, Logger logger,
@ -41,7 +39,7 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
_httpClient = httpClient; _httpClient = httpClient;
_configService = configService; _configService = configService;
_metadataProfileService = metadataProfileService; _metadataProfileService = metadataProfileService;
_requestBuilder = requestBuilder.Search; _requestBuilder = requestBuilder;
_artistService = artistService; _artistService = artistService;
_albumService = albumService; _albumService = albumService;
_logger = logger; _logger = logger;
@ -52,15 +50,13 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
_logger.Debug("Getting Artist with LidarrAPI.MetadataID of {0}", foreignArtistId); _logger.Debug("Getting Artist with LidarrAPI.MetadataID of {0}", foreignArtistId);
SetCustomProvider();
var metadataProfile = _metadataProfileService.Exists(metadataProfileId) ? _metadataProfileService.Get(metadataProfileId) : _metadataProfileService.All().First(); var metadataProfile = _metadataProfileService.Exists(metadataProfileId) ? _metadataProfileService.Get(metadataProfileId) : _metadataProfileService.All().First();
var primaryTypes = metadataProfile.PrimaryAlbumTypes.Where(s => s.Allowed).Select(s => s.PrimaryAlbumType.Name); var primaryTypes = metadataProfile.PrimaryAlbumTypes.Where(s => s.Allowed).Select(s => s.PrimaryAlbumType.Name);
var secondaryTypes = metadataProfile.SecondaryAlbumTypes.Where(s => s.Allowed).Select(s => s.SecondaryAlbumType.Name); var secondaryTypes = metadataProfile.SecondaryAlbumTypes.Where(s => s.Allowed).Select(s => s.SecondaryAlbumType.Name);
var releaseStatuses = metadataProfile.ReleaseStatuses.Where(s => s.Allowed).Select(s => s.ReleaseStatus.Name); var releaseStatuses = metadataProfile.ReleaseStatuses.Where(s => s.Allowed).Select(s => s.ReleaseStatus.Name);
var httpRequest = _customerRequestBuilder.Create() var httpRequest = _requestBuilder.GetRequestBuilder().Create()
.SetSegment("route", "artist/" + foreignArtistId) .SetSegment("route", "artist/" + foreignArtistId)
.AddQueryParam("primTypes", string.Join("|", primaryTypes)) .AddQueryParam("primTypes", string.Join("|", primaryTypes))
.AddQueryParam("secTypes", string.Join("|", secondaryTypes)) .AddQueryParam("secTypes", string.Join("|", secondaryTypes))
@ -101,10 +97,8 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
public Tuple<string, Album, List<ArtistMetadata>> GetAlbumInfo(string foreignAlbumId) public Tuple<string, Album, List<ArtistMetadata>> GetAlbumInfo(string foreignAlbumId)
{ {
_logger.Debug("Getting Album with LidarrAPI.MetadataID of {0}", foreignAlbumId); _logger.Debug("Getting Album with LidarrAPI.MetadataID of {0}", foreignAlbumId);
SetCustomProvider(); var httpRequest = _requestBuilder.GetRequestBuilder().Create()
var httpRequest = _customerRequestBuilder.Create()
.SetSegment("route", "album/" + foreignAlbumId) .SetSegment("route", "album/" + foreignAlbumId)
.Build(); .Build();
@ -173,9 +167,7 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
} }
} }
SetCustomProvider(); var httpRequest = _requestBuilder.GetRequestBuilder().Create()
var httpRequest = _customerRequestBuilder.Create()
.SetSegment("route", "search") .SetSegment("route", "search")
.AddQueryParam("type", "artist") .AddQueryParam("type", "artist")
.AddQueryParam("query", title.ToLower().Trim()) .AddQueryParam("query", title.ToLower().Trim())
@ -244,9 +236,7 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
} }
} }
SetCustomProvider(); var httpRequest = _requestBuilder.GetRequestBuilder().Create()
var httpRequest = _customerRequestBuilder.Create()
.SetSegment("route", "search") .SetSegment("route", "search")
.AddQueryParam("type", "album") .AddQueryParam("type", "album")
.AddQueryParam("query", title.ToLower().Trim()) .AddQueryParam("query", title.ToLower().Trim())
@ -508,17 +498,5 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
return SecondaryAlbumType.Studio; return SecondaryAlbumType.Studio;
} }
} }
private void SetCustomProvider()
{
if (_configService.MetadataSource.IsNotNullOrWhiteSpace())
{
_customerRequestBuilder = new HttpRequestBuilder(_configService.MetadataSource.TrimEnd("/") + "/{route}").CreateFactory();
}
else
{
_customerRequestBuilder = _requestBuilder;
}
}
} }
} }

@ -716,6 +716,7 @@
<Compile Include="Languages\Language.cs" /> <Compile Include="Languages\Language.cs" />
<Compile Include="Languages\LanguageComparer.cs" /> <Compile Include="Languages\LanguageComparer.cs" />
<Compile Include="Languages\LanguagesBelowCutoff.cs" /> <Compile Include="Languages\LanguagesBelowCutoff.cs" />
<Compile Include="MetadataSource\IMetadataRequestBuilder.cs" />
<Compile Include="Notifications\Discord\Discord.cs" /> <Compile Include="Notifications\Discord\Discord.cs" />
<Compile Include="Notifications\Discord\DiscordColors.cs" /> <Compile Include="Notifications\Discord\DiscordColors.cs" />
<Compile Include="Notifications\Discord\DiscordException.cs" /> <Compile Include="Notifications\Discord\DiscordException.cs" />

Loading…
Cancel
Save