Map properties returned from TMDB lists to avoid needing server re-mapping

pull/4454/head
Qstick 5 years ago
parent 2bdd806565
commit 50f84101e0

@ -456,18 +456,6 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
return newAlternativeTitle; return newAlternativeTitle;
} }
private static MovieCollection MapCollection(CollectionResource arg)
{
var newCollection = new MovieCollection
{
Name = arg.Name,
TmdbId = arg.TmdbId,
Images = arg.Images.Select(MapImage).ToList()
};
return newCollection;
}
private static Ratings MapRatings(RatingResource rating) private static Ratings MapRatings(RatingResource rating)
{ {
if (rating == null) if (rating == null)

@ -1,4 +1,4 @@
using NLog; using NLog;
using NzbDrone.Common.Cloud; using NzbDrone.Common.Cloud;
using NzbDrone.Common.Http; using NzbDrone.Common.Http;
using NzbDrone.Core.Configuration; using NzbDrone.Core.Configuration;
@ -25,7 +25,7 @@ namespace NzbDrone.Core.NetImport.TMDb.Collection
public override IParseNetImportResponse GetParser() public override IParseNetImportResponse GetParser()
{ {
return new TMDbCollectionParser(_skyhookProxy); return new TMDbCollectionParser();
} }
public override INetImportRequestGenerator GetRequestGenerator() public override INetImportRequestGenerator GetRequestGenerator()

@ -8,14 +8,6 @@ namespace NzbDrone.Core.NetImport.TMDb.Collection
{ {
public class TMDbCollectionParser : TMDbParser public class TMDbCollectionParser : TMDbParser
{ {
private readonly ISearchForNewMovie _skyhookProxy;
public TMDbCollectionParser(ISearchForNewMovie skyhookProxy)
: base(skyhookProxy)
{
_skyhookProxy = skyhookProxy;
}
public override IList<Movie> ParseResponse(NetImportResponse importResponse) public override IList<Movie> ParseResponse(NetImportResponse importResponse)
{ {
var movies = new List<Movie>(); var movies = new List<Movie>();
@ -41,7 +33,7 @@ namespace NzbDrone.Core.NetImport.TMDb.Collection
continue; continue;
} }
movies.AddIfNotNull(new Movie { TmdbId = movie.id }); movies.AddIfNotNull(MapListMovie(movie));
} }
return movies; return movies;

@ -1,4 +1,4 @@
using NLog; using NLog;
using NzbDrone.Common.Cloud; using NzbDrone.Common.Cloud;
using NzbDrone.Common.Http; using NzbDrone.Common.Http;
using NzbDrone.Core.Configuration; using NzbDrone.Core.Configuration;
@ -25,7 +25,7 @@ namespace NzbDrone.Core.NetImport.TMDb.List
public override IParseNetImportResponse GetParser() public override IParseNetImportResponse GetParser()
{ {
return new TMDbListParser(_skyhookProxy); return new TMDbListParser();
} }
public override INetImportRequestGenerator GetRequestGenerator() public override INetImportRequestGenerator GetRequestGenerator()

@ -8,14 +8,6 @@ namespace NzbDrone.Core.NetImport.TMDb.List
{ {
public class TMDbListParser : TMDbParser public class TMDbListParser : TMDbParser
{ {
private readonly ISearchForNewMovie _skyhookProxy;
public TMDbListParser(ISearchForNewMovie skyhookProxy)
: base(skyhookProxy)
{
_skyhookProxy = skyhookProxy;
}
public override IList<Movie> ParseResponse(NetImportResponse importResponse) public override IList<Movie> ParseResponse(NetImportResponse importResponse)
{ {
var movies = new List<Movie>(); var movies = new List<Movie>();
@ -41,7 +33,7 @@ namespace NzbDrone.Core.NetImport.TMDb.List
continue; continue;
} }
movies.AddIfNotNull(new Movie { TmdbId = movie.id }); movies.AddIfNotNull(MapListMovie(movie));
} }
return movies; return movies;

@ -1,4 +1,4 @@
using NLog; using NLog;
using NzbDrone.Common.Cloud; using NzbDrone.Common.Cloud;
using NzbDrone.Common.Http; using NzbDrone.Common.Http;
using NzbDrone.Core.Configuration; using NzbDrone.Core.Configuration;
@ -25,7 +25,7 @@ namespace NzbDrone.Core.NetImport.TMDb.Person
public override IParseNetImportResponse GetParser() public override IParseNetImportResponse GetParser()
{ {
return new TMDbPersonParser(Settings, _skyhookProxy); return new TMDbPersonParser(Settings);
} }
public override INetImportRequestGenerator GetRequestGenerator() public override INetImportRequestGenerator GetRequestGenerator()

@ -9,13 +9,10 @@ namespace NzbDrone.Core.NetImport.TMDb.Person
public class TMDbPersonParser : TMDbParser public class TMDbPersonParser : TMDbParser
{ {
private readonly TMDbPersonSettings _settings; private readonly TMDbPersonSettings _settings;
private readonly ISearchForNewMovie _skyhookProxy;
public TMDbPersonParser(TMDbPersonSettings settings, ISearchForNewMovie skyhookProxy) public TMDbPersonParser(TMDbPersonSettings settings)
: base(skyhookProxy)
{ {
_settings = settings; _settings = settings;
_skyhookProxy = skyhookProxy;
} }
public override IList<Movie> ParseResponse(NetImportResponse importResponse) public override IList<Movie> ParseResponse(NetImportResponse importResponse)

@ -1,4 +1,4 @@
using NLog; using NLog;
using NzbDrone.Common.Cloud; using NzbDrone.Common.Cloud;
using NzbDrone.Common.Http; using NzbDrone.Common.Http;
using NzbDrone.Core.Configuration; using NzbDrone.Core.Configuration;
@ -25,7 +25,7 @@ namespace NzbDrone.Core.NetImport.TMDb.Popular
public override IParseNetImportResponse GetParser() public override IParseNetImportResponse GetParser()
{ {
return new TMDbParser(_skyhookProxy); return new TMDbParser();
} }
public override INetImportRequestGenerator GetRequestGenerator() public override INetImportRequestGenerator GetRequestGenerator()

@ -1,7 +1,10 @@
using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Globalization;
using System.Net; using System.Net;
using Newtonsoft.Json; using Newtonsoft.Json;
using NzbDrone.Common.Extensions; using NzbDrone.Common.Extensions;
using NzbDrone.Core.MediaCover;
using NzbDrone.Core.MetadataSource; using NzbDrone.Core.MetadataSource;
using NzbDrone.Core.Movies; using NzbDrone.Core.Movies;
using NzbDrone.Core.NetImport.Exceptions; using NzbDrone.Core.NetImport.Exceptions;
@ -10,13 +13,6 @@ namespace NzbDrone.Core.NetImport.TMDb
{ {
public class TMDbParser : IParseNetImportResponse public class TMDbParser : IParseNetImportResponse
{ {
private readonly ISearchForNewMovie _skyhookProxy;
public TMDbParser(ISearchForNewMovie skyhookProxy)
{
_skyhookProxy = skyhookProxy;
}
public virtual IList<Movie> ParseResponse(NetImportResponse importResponse) public virtual IList<Movie> ParseResponse(NetImportResponse importResponse)
{ {
var movies = new List<Movie>(); var movies = new List<Movie>();
@ -34,7 +30,39 @@ namespace NzbDrone.Core.NetImport.TMDb
return movies; return movies;
} }
return jsonResponse.Results.SelectList(m => new Movie { TmdbId = m.id }); return jsonResponse.Results.SelectList(MapListMovie);
}
protected Movie MapListMovie(MovieResult movieResult)
{
var movie = new Movie
{
TmdbId = movieResult.id,
Overview = movieResult.overview,
Title = movieResult.original_title,
SortTitle = Parser.Parser.NormalizeTitle(movieResult.original_title),
Images = new List<MediaCover.MediaCover>()
};
if (movieResult.release_date.IsNotNullOrWhiteSpace())
{
DateTime.TryParse(movieResult.release_date, out var releaseDate);
movie.Year = releaseDate.Year;
}
movie.Images.AddIfNotNull(MapPosterImage(movieResult.poster_path));
return movie;
}
private MediaCover.MediaCover MapPosterImage(string path)
{
if (path.IsNotNullOrWhiteSpace())
{
return new MediaCover.MediaCover(MediaCoverTypes.Poster, $"https://image.tmdb.org/t/p/original{path}");
}
return null;
} }
protected virtual bool PreProcess(NetImportResponse listResponse) protected virtual bool PreProcess(NetImportResponse listResponse)

@ -1,4 +1,4 @@
using System.Collections.Generic; using System.Collections.Generic;
using NLog; using NLog;
using NzbDrone.Common.Cloud; using NzbDrone.Common.Cloud;
using NzbDrone.Common.Http; using NzbDrone.Common.Http;
@ -27,7 +27,7 @@ namespace NzbDrone.Core.NetImport.TMDb.User
public override IParseNetImportResponse GetParser() public override IParseNetImportResponse GetParser()
{ {
return new TMDbParser(_skyhookProxy); return new TMDbParser();
} }
public override INetImportRequestGenerator GetRequestGenerator() public override INetImportRequestGenerator GetRequestGenerator()

Loading…
Cancel
Save