|
|
@ -23,6 +23,7 @@ namespace NzbDrone.Core.ImportLists
|
|
|
|
private readonly IImportListStatusService _importListStatusService;
|
|
|
|
private readonly IImportListStatusService _importListStatusService;
|
|
|
|
private readonly IImportListMovieService _listMovieService;
|
|
|
|
private readonly IImportListMovieService _listMovieService;
|
|
|
|
private readonly ISearchForNewMovie _movieSearch;
|
|
|
|
private readonly ISearchForNewMovie _movieSearch;
|
|
|
|
|
|
|
|
private readonly IProvideMovieInfo _movieInfoService;
|
|
|
|
private readonly IMovieMetadataService _movieMetadataService;
|
|
|
|
private readonly IMovieMetadataService _movieMetadataService;
|
|
|
|
private readonly Logger _logger;
|
|
|
|
private readonly Logger _logger;
|
|
|
|
|
|
|
|
|
|
|
@ -30,6 +31,7 @@ namespace NzbDrone.Core.ImportLists
|
|
|
|
IImportListStatusService importListStatusService,
|
|
|
|
IImportListStatusService importListStatusService,
|
|
|
|
IImportListMovieService listMovieService,
|
|
|
|
IImportListMovieService listMovieService,
|
|
|
|
ISearchForNewMovie movieSearch,
|
|
|
|
ISearchForNewMovie movieSearch,
|
|
|
|
|
|
|
|
IProvideMovieInfo movieInfoService,
|
|
|
|
IMovieMetadataService movieMetadataService,
|
|
|
|
IMovieMetadataService movieMetadataService,
|
|
|
|
Logger logger)
|
|
|
|
Logger logger)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -37,6 +39,7 @@ namespace NzbDrone.Core.ImportLists
|
|
|
|
_importListStatusService = importListStatusService;
|
|
|
|
_importListStatusService = importListStatusService;
|
|
|
|
_listMovieService = listMovieService;
|
|
|
|
_listMovieService = listMovieService;
|
|
|
|
_movieSearch = movieSearch;
|
|
|
|
_movieSearch = movieSearch;
|
|
|
|
|
|
|
|
_movieInfoService = movieInfoService;
|
|
|
|
_movieMetadataService = movieMetadataService;
|
|
|
|
_movieMetadataService = movieMetadataService;
|
|
|
|
_logger = logger;
|
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -84,20 +87,10 @@ namespace NzbDrone.Core.ImportLists
|
|
|
|
|
|
|
|
|
|
|
|
if (!importListReports.AnyFailure)
|
|
|
|
if (!importListReports.AnyFailure)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// TODO some opportunity to bulk map here if we had the tmdbIds
|
|
|
|
var alreadyMapped = result.Movies.Where(x => importListReports.Movies.Any(r => r.TmdbId == x.TmdbId));
|
|
|
|
var listMovies = importListReports.Movies.Select(x =>
|
|
|
|
var listMovies = MapMovieReports(importListReports.Movies.Where(x => !result.Movies.Any(r => r.TmdbId == x.TmdbId)).ToList()).Where(x => x.TmdbId > 0).ToList();
|
|
|
|
{
|
|
|
|
|
|
|
|
// Is it existing in result
|
|
|
|
|
|
|
|
var movie = result.Movies.FirstOrDefault(r => r.TmdbId == x.TmdbId);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (movie != null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
movie.ListId = importList.Definition.Id;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return movie ?? MapMovieReport(x);
|
|
|
|
|
|
|
|
}).Where(x => x.TmdbId > 0).ToList();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
listMovies.AddRange(alreadyMapped);
|
|
|
|
listMovies = listMovies.DistinctBy(x => x.TmdbId).ToList();
|
|
|
|
listMovies = listMovies.DistinctBy(x => x.TmdbId).ToList();
|
|
|
|
listMovies.ForEach(m => m.ListId = importList.Definition.Id);
|
|
|
|
listMovies.ForEach(m => m.ListId = importList.Definition.Id);
|
|
|
|
|
|
|
|
|
|
|
@ -148,11 +141,7 @@ namespace NzbDrone.Core.ImportLists
|
|
|
|
|
|
|
|
|
|
|
|
if (!importListReports.AnyFailure)
|
|
|
|
if (!importListReports.AnyFailure)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// TODO some opportunity to bulk map here if we had the tmdbIds
|
|
|
|
var listMovies = MapMovieReports(importListReports.Movies).Where(x => x.TmdbId > 0).ToList();
|
|
|
|
var listMovies = importListReports.Movies.Select(x =>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return MapMovieReport(x);
|
|
|
|
|
|
|
|
}).Where(x => x.TmdbId > 0).ToList();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
listMovies = listMovies.DistinctBy(x => x.TmdbId).ToList();
|
|
|
|
listMovies = listMovies.DistinctBy(x => x.TmdbId).ToList();
|
|
|
|
|
|
|
|
|
|
|
@ -173,21 +162,32 @@ namespace NzbDrone.Core.ImportLists
|
|
|
|
return result;
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private ImportListMovie MapMovieReport(ImportListMovie report)
|
|
|
|
private List<ImportListMovie> MapMovieReports(List<ImportListMovie> reports)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var mappedMovie = _movieSearch.MapMovieToTmdbMovie(new MovieMetadata { Title = report.Title, TmdbId = report.TmdbId, ImdbId = report.ImdbId, Year = report.Year });
|
|
|
|
var mappedMovies = reports.Select(m => _movieSearch.MapMovieToTmdbMovie(new MovieMetadata { Title = m.Title, TmdbId = m.TmdbId, ImdbId = m.ImdbId, Year = m.Year }))
|
|
|
|
|
|
|
|
.Where(x => x != null)
|
|
|
|
|
|
|
|
.ToList();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_movieMetadataService.UpsertMany(mappedMovies);
|
|
|
|
|
|
|
|
|
|
|
|
var mappedListMovie = new ImportListMovie { ListId = report.ListId };
|
|
|
|
var mappedListMovies = new List<ImportListMovie>();
|
|
|
|
|
|
|
|
|
|
|
|
if (mappedMovie != null)
|
|
|
|
foreach (var report in reports)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_movieMetadataService.Upsert(mappedMovie);
|
|
|
|
var mappedListMovie = new ImportListMovie { ListId = report.ListId };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var movieMeta = mappedMovies.FirstOrDefault(bulkMapMovies => bulkMapMovies.TmdbId == report.TmdbId);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (movieMeta != null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
mappedListMovie.MovieMetadata = movieMeta;
|
|
|
|
|
|
|
|
mappedListMovie.MovieMetadataId = movieMeta.Id;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
mappedListMovie.MovieMetadata = mappedMovie;
|
|
|
|
mappedListMovies.Add(mappedListMovie);
|
|
|
|
mappedListMovie.MovieMetadataId = mappedMovie.Id;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return mappedListMovie;
|
|
|
|
return mappedListMovies;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|