|
|
@ -16,6 +16,7 @@ using System.Threading;
|
|
|
|
using NzbDrone.Core.Parser;
|
|
|
|
using NzbDrone.Core.Parser;
|
|
|
|
using NzbDrone.Core.Profiles;
|
|
|
|
using NzbDrone.Core.Profiles;
|
|
|
|
using NzbDrone.Common.Serializer;
|
|
|
|
using NzbDrone.Common.Serializer;
|
|
|
|
|
|
|
|
using NzbDrone.Core.NetImport.ImportExclusions;
|
|
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.MetadataSource.SkyHook
|
|
|
|
namespace NzbDrone.Core.MetadataSource.SkyHook
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -29,8 +30,10 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
|
|
|
|
private readonly ITmdbConfigService _configService;
|
|
|
|
private readonly ITmdbConfigService _configService;
|
|
|
|
private readonly IMovieService _movieService;
|
|
|
|
private readonly IMovieService _movieService;
|
|
|
|
private readonly IPreDBService _predbService;
|
|
|
|
private readonly IPreDBService _predbService;
|
|
|
|
|
|
|
|
private readonly IImportExclusionsService _exclusionService;
|
|
|
|
|
|
|
|
|
|
|
|
public SkyHookProxy(IHttpClient httpClient, ISonarrCloudRequestBuilder requestBuilder, ITmdbConfigService configService, IMovieService movieService, IPreDBService predbService, Logger logger)
|
|
|
|
public SkyHookProxy(IHttpClient httpClient, ISonarrCloudRequestBuilder requestBuilder, ITmdbConfigService configService, IMovieService movieService,
|
|
|
|
|
|
|
|
IPreDBService predbService, IImportExclusionsService exclusionService, Logger logger)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_httpClient = httpClient;
|
|
|
|
_httpClient = httpClient;
|
|
|
|
_requestBuilder = requestBuilder.SkyHookTvdb;
|
|
|
|
_requestBuilder = requestBuilder.SkyHookTvdb;
|
|
|
@ -38,6 +41,7 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
|
|
|
|
_configService = configService;
|
|
|
|
_configService = configService;
|
|
|
|
_movieService = movieService;
|
|
|
|
_movieService = movieService;
|
|
|
|
_predbService = predbService;
|
|
|
|
_predbService = predbService;
|
|
|
|
|
|
|
|
_exclusionService = exclusionService;
|
|
|
|
_logger = logger;
|
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -351,7 +355,10 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
|
|
|
|
|
|
|
|
|
|
|
|
public List<Movie> DiscoverNewMovies(string action)
|
|
|
|
public List<Movie> DiscoverNewMovies(string action)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
string allIds = string.Join(",", _movieService.GetAllMovies().Select(m => m.TmdbId));
|
|
|
|
var allMovies = _movieService.GetAllMovies();
|
|
|
|
|
|
|
|
var allExclusions = _exclusionService.GetAllExclusions();
|
|
|
|
|
|
|
|
string allIds = string.Join(",", allMovies.Select(m => m.TmdbId));
|
|
|
|
|
|
|
|
string ignoredIds = string.Join(",", allExclusions.Select(ex => ex.TmdbId));
|
|
|
|
|
|
|
|
|
|
|
|
HttpRequest request;
|
|
|
|
HttpRequest request;
|
|
|
|
List<MovieResult> results;
|
|
|
|
List<MovieResult> results;
|
|
|
@ -387,7 +394,7 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
|
|
|
|
request.AllowAutoRedirect = true;
|
|
|
|
request.AllowAutoRedirect = true;
|
|
|
|
request.Method = HttpMethod.POST;
|
|
|
|
request.Method = HttpMethod.POST;
|
|
|
|
request.Headers.ContentType = "application/x-www-form-urlencoded";
|
|
|
|
request.Headers.ContentType = "application/x-www-form-urlencoded";
|
|
|
|
request.SetContent($"tmdbids={allIds}");
|
|
|
|
request.SetContent($"tmdbids={allIds}&ignoredIds={ignoredIds}");
|
|
|
|
|
|
|
|
|
|
|
|
var response = _httpClient.Post<List<MovieResult>>(request);
|
|
|
|
var response = _httpClient.Post<List<MovieResult>>(request);
|
|
|
|
|
|
|
|
|
|
|
@ -399,6 +406,8 @@ namespace NzbDrone.Core.MetadataSource.SkyHook
|
|
|
|
results = response.Resource;
|
|
|
|
results = response.Resource;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
results = results.Where(m => allMovies.None(mo => mo.TmdbId == m.id) && allExclusions.None(ex => ex.TmdbId == m.id)).ToList();
|
|
|
|
|
|
|
|
|
|
|
|
return results.SelectList(MapMovie);
|
|
|
|
return results.SelectList(MapMovie);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|