|
|
@ -262,100 +262,122 @@ namespace Ombi.Schedule.Jobs.Plex
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (content.viewGroup.Equals(PlexMediaType.Movie.ToString(), StringComparison.InvariantCultureIgnoreCase))
|
|
|
|
if (content.viewGroup.Equals(PlexMediaType.Movie.ToString(), StringComparison.InvariantCultureIgnoreCase))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Logger.LogDebug("Processing Movies");
|
|
|
|
await MovieLoop(servers, content, contentToAdd, contentProcessed);
|
|
|
|
foreach (var movie in content?.Metadata ?? new Metadata[] { })
|
|
|
|
}
|
|
|
|
|
|
|
|
if (contentToAdd.Count > 500)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
await Repo.AddRange(contentToAdd);
|
|
|
|
|
|
|
|
foreach (var c in contentToAdd)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Let's check if we have this movie
|
|
|
|
contentProcessed.Add(c.Id, c.Key);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
contentToAdd.Clear();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
if (contentToAdd.Any())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var existing = await Repo.GetFirstContentByCustom(x => x.Title == movie.title
|
|
|
|
await Repo.AddRange(contentToAdd);
|
|
|
|
&& x.ReleaseYear == movie.year.ToString()
|
|
|
|
foreach (var c in contentToAdd)
|
|
|
|
&& x.Type == PlexMediaTypeEntity.Movie);
|
|
|
|
{
|
|
|
|
// The rating key keeps changing
|
|
|
|
contentProcessed.Add(c.Id, c.Key);
|
|
|
|
//var existing = await Repo.GetByKey(movie.ratingKey);
|
|
|
|
}
|
|
|
|
if (existing != null)
|
|
|
|
}
|
|
|
|
{
|
|
|
|
|
|
|
|
Logger.LogDebug("We already have movie {0}", movie.title);
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var hasSameKey = await Repo.GetByKey(movie.ratingKey);
|
|
|
|
retVal.Content = contentProcessed.Values;
|
|
|
|
if (hasSameKey != null)
|
|
|
|
retVal.Episodes = episodesProcessed;
|
|
|
|
{
|
|
|
|
return retVal;
|
|
|
|
await Repo.Delete(hasSameKey);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Logger.LogDebug("Adding movie {0}", movie.title);
|
|
|
|
public async Task MovieLoop(PlexServers servers, Mediacontainer content, HashSet<PlexServerContent> contentToAdd,
|
|
|
|
var guids = new List<string>();
|
|
|
|
Dictionary<int, int> contentProcessed)
|
|
|
|
if (!movie.Guid.Any())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Logger.LogDebug("Processing Movies");
|
|
|
|
var metaData = await PlexApi.GetMetadata(servers.PlexAuthToken, servers.FullUri,
|
|
|
|
foreach (var movie in content?.Metadata ?? new Metadata[] { })
|
|
|
|
movie.ratingKey);
|
|
|
|
{
|
|
|
|
|
|
|
|
// Let's check if we have this movie
|
|
|
|
|
|
|
|
|
|
|
|
var meta = metaData.MediaContainer.Metadata.FirstOrDefault();
|
|
|
|
try
|
|
|
|
guids.Add(meta.guid);
|
|
|
|
{
|
|
|
|
if (meta.Guid != null)
|
|
|
|
var existing = await Repo.GetFirstContentByCustom(x => x.Title == movie.title
|
|
|
|
{
|
|
|
|
&& x.ReleaseYear == movie.year.ToString()
|
|
|
|
foreach (var g in meta.Guid)
|
|
|
|
&& x.Type == PlexMediaTypeEntity.Movie);
|
|
|
|
{
|
|
|
|
// The rating key keeps changing
|
|
|
|
guids.Add(g.Id);
|
|
|
|
//var existing = await Repo.GetByKey(movie.ratingKey);
|
|
|
|
}
|
|
|
|
if (existing != null)
|
|
|
|
}
|
|
|
|
{
|
|
|
|
}
|
|
|
|
Logger.LogDebug("We already have movie {0}", movie.title);
|
|
|
|
else
|
|
|
|
continue;
|
|
|
|
{
|
|
|
|
}
|
|
|
|
// Currently a Plex Pass feature only
|
|
|
|
|
|
|
|
foreach (var g in movie.Guid)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
guids.Add(g.Id);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var providerIds = PlexHelper.GetProviderIdsFromMetadata(guids.ToArray());
|
|
|
|
var hasSameKey = await Repo.GetByKey(movie.ratingKey);
|
|
|
|
|
|
|
|
if (hasSameKey != null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
await Repo.Delete(hasSameKey);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var item = new PlexServerContent
|
|
|
|
Logger.LogDebug("Adding movie {0}", movie.title);
|
|
|
|
{
|
|
|
|
var guids = new List<string>();
|
|
|
|
AddedAt = DateTime.Now,
|
|
|
|
if (!movie.Guid.Any())
|
|
|
|
Key = movie.ratingKey,
|
|
|
|
{
|
|
|
|
ReleaseYear = movie.year.ToString(),
|
|
|
|
var metaData = await PlexApi.GetMetadata(servers.PlexAuthToken, servers.FullUri,
|
|
|
|
Type = PlexMediaTypeEntity.Movie,
|
|
|
|
movie.ratingKey);
|
|
|
|
Title = movie.title,
|
|
|
|
|
|
|
|
Url = PlexHelper.GetPlexMediaUrl(servers.MachineIdentifier, movie.ratingKey),
|
|
|
|
var meta = metaData.MediaContainer.Metadata.FirstOrDefault();
|
|
|
|
Seasons = new List<PlexSeasonsContent>(),
|
|
|
|
guids.Add(meta.guid);
|
|
|
|
Quality = movie.Media?.FirstOrDefault()?.videoResolution ?? string.Empty
|
|
|
|
if (meta.Guid != null)
|
|
|
|
};
|
|
|
|
{
|
|
|
|
if (providerIds.ImdbId.HasValue())
|
|
|
|
foreach (var g in meta.Guid)
|
|
|
|
{
|
|
|
|
|
|
|
|
item.ImdbId = providerIds.ImdbId;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (providerIds.TheMovieDb.HasValue())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
item.TheMovieDbId = providerIds.TheMovieDb;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (providerIds.TheTvDb.HasValue())
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
item.TvDbId = providerIds.TheTvDb;
|
|
|
|
guids.Add(g.Id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
contentToAdd.Add(item);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// Currently a Plex Pass feature only
|
|
|
|
|
|
|
|
foreach (var g in movie.Guid)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Logger.LogError(LoggingEvents.PlexContentCacher, e, "Exception when adding new Movie {0}",
|
|
|
|
guids.Add(g.Id);
|
|
|
|
movie.title);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (contentToAdd.Count > 500)
|
|
|
|
var providerIds = PlexHelper.GetProviderIdsFromMetadata(guids.ToArray());
|
|
|
|
{
|
|
|
|
|
|
|
|
await Repo.AddRange(contentToAdd);
|
|
|
|
var item = new PlexServerContent
|
|
|
|
foreach (var c in contentToAdd)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
AddedAt = DateTime.Now,
|
|
|
|
contentProcessed.Add(c.Id, c.Key);
|
|
|
|
Key = movie.ratingKey,
|
|
|
|
}
|
|
|
|
ReleaseYear = movie.year.ToString(),
|
|
|
|
contentToAdd.Clear();
|
|
|
|
Type = PlexMediaTypeEntity.Movie,
|
|
|
|
}
|
|
|
|
Title = movie.title,
|
|
|
|
|
|
|
|
Url = PlexHelper.GetPlexMediaUrl(servers.MachineIdentifier, movie.ratingKey),
|
|
|
|
|
|
|
|
Seasons = new List<PlexSeasonsContent>(),
|
|
|
|
|
|
|
|
Quality = movie.Media?.FirstOrDefault()?.videoResolution ?? string.Empty
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
if (providerIds.ImdbId.HasValue())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
item.ImdbId = providerIds.ImdbId;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (providerIds.TheMovieDb.HasValue())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
item.TheMovieDbId = providerIds.TheMovieDb;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (providerIds.TheTvDb.HasValue())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
item.TvDbId = providerIds.TheTvDb;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
contentToAdd.Add(item);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Logger.LogError(LoggingEvents.PlexContentCacher, e, "Exception when adding new Movie {0}",
|
|
|
|
|
|
|
|
movie.title);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (contentToAdd.Count > 500)
|
|
|
|
if (contentToAdd.Count > 500)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
await Repo.AddRange(contentToAdd);
|
|
|
|
await Repo.AddRange(contentToAdd);
|
|
|
@ -363,22 +385,10 @@ namespace Ombi.Schedule.Jobs.Plex
|
|
|
|
{
|
|
|
|
{
|
|
|
|
contentProcessed.Add(c.Id, c.Key);
|
|
|
|
contentProcessed.Add(c.Id, c.Key);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
contentToAdd.Clear();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (contentToAdd.Any())
|
|
|
|
contentToAdd.Clear();
|
|
|
|
{
|
|
|
|
|
|
|
|
await Repo.AddRange(contentToAdd);
|
|
|
|
|
|
|
|
foreach (var c in contentToAdd)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
contentProcessed.Add(c.Id, c.Key);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
retVal.Content = contentProcessed.Values;
|
|
|
|
|
|
|
|
retVal.Episodes = episodesProcessed;
|
|
|
|
|
|
|
|
return retVal;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private async Task ProcessTvShow(PlexServers servers, Metadata show, HashSet<PlexServerContent> contentToAdd, Dictionary<int, int> contentProcessed)
|
|
|
|
private async Task ProcessTvShow(PlexServers servers, Metadata show, HashSet<PlexServerContent> contentToAdd, Dictionary<int, int> contentProcessed)
|
|
|
|