|
|
|
@ -1,32 +1,140 @@
|
|
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
|
using Ombi.Api.Emby;
|
|
|
|
|
using Ombi.Api.Emby.Models.Movie;
|
|
|
|
|
using Ombi.Core.Settings;
|
|
|
|
|
using Ombi.Core.Settings.Models.External;
|
|
|
|
|
using Ombi.Helpers;
|
|
|
|
|
using Ombi.Store.Entities;
|
|
|
|
|
using Ombi.Store.Repository;
|
|
|
|
|
using Serilog;
|
|
|
|
|
using EmbyMediaType = Ombi.Store.Entities.EmbyMediaType;
|
|
|
|
|
|
|
|
|
|
namespace Ombi.Schedule.Jobs.Emby
|
|
|
|
|
{
|
|
|
|
|
public class EmbyContentCacher
|
|
|
|
|
public class EmbyContentCacher : IEmbyContentCacher
|
|
|
|
|
{
|
|
|
|
|
public EmbyContentCacher(ISettingsService<EmbySettings> settings, IEmbyApi api, ILogger<EmbyContentCacher> logger)
|
|
|
|
|
public EmbyContentCacher(ISettingsService<EmbySettings> settings, IEmbyApi api, ILogger<EmbyContentCacher> logger,
|
|
|
|
|
IEmbyContentRepository repo)
|
|
|
|
|
{
|
|
|
|
|
_logger = logger;
|
|
|
|
|
_settings = settings;
|
|
|
|
|
_api = api;
|
|
|
|
|
_repo = repo;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private readonly ILogger<EmbyContentCacher> _logger;
|
|
|
|
|
private readonly ISettingsService<EmbySettings> _settings;
|
|
|
|
|
private readonly IEmbyApi _api;
|
|
|
|
|
private readonly IEmbyContentRepository _repo;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public async Task Start()
|
|
|
|
|
{
|
|
|
|
|
var embySettings = await _settings.GetSettingsAsync();
|
|
|
|
|
if (!embySettings.Enable)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
foreach (var server in embySettings.Servers)
|
|
|
|
|
await StartServerCache(server);
|
|
|
|
|
|
|
|
|
|
// Episodes
|
|
|
|
|
//BackgroundJob.Enqueue(() => );
|
|
|
|
|
}
|
|
|
|
|
private bool ValidateSettings(EmbySettings emby)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private async Task StartServerCache(EmbyServers server)
|
|
|
|
|
{
|
|
|
|
|
if (emby.Enable)
|
|
|
|
|
if (!ValidateSettings(server))
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
var movies = await _api.GetAllMovies(server.ApiKey, server.AdministratorId, server.FullUri);
|
|
|
|
|
var mediaToAdd = new List<EmbyContent>();
|
|
|
|
|
foreach (var movie in movies.Items)
|
|
|
|
|
{
|
|
|
|
|
foreach (var server in emby.Servers)
|
|
|
|
|
if (movie.Type.Equals("boxset", StringComparison.CurrentCultureIgnoreCase))
|
|
|
|
|
{
|
|
|
|
|
if (server?.Ip == null || string.IsNullOrEmpty(server?.ApiKey))
|
|
|
|
|
var movieInfo =
|
|
|
|
|
await _api.GetCollection(movie.Id, server.ApiKey, server.AdministratorId, server.FullUri);
|
|
|
|
|
foreach (var item in movieInfo.Items)
|
|
|
|
|
{
|
|
|
|
|
//Log.Warn("A setting is null, Ensure Emby is configured correctly, and we have a Emby Auth token.");
|
|
|
|
|
return false;
|
|
|
|
|
var info = await _api.GetMovieInformation(item.Id, server.ApiKey,
|
|
|
|
|
server.AdministratorId, server.FullUri);
|
|
|
|
|
await ProcessMovies(info, mediaToAdd);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Regular movie
|
|
|
|
|
var movieInfo = await _api.GetMovieInformation(movie.Id, server.ApiKey,
|
|
|
|
|
server.AdministratorId, server.FullUri);
|
|
|
|
|
|
|
|
|
|
await ProcessMovies(movieInfo, mediaToAdd);
|
|
|
|
|
}
|
|
|
|
|
return emby.Enable;
|
|
|
|
|
}
|
|
|
|
|
// TV Time
|
|
|
|
|
var tv = await _api.GetAllShows(server.ApiKey, server.AdministratorId, server.FullUri);
|
|
|
|
|
|
|
|
|
|
foreach (var tvShow in tv.Items)
|
|
|
|
|
{
|
|
|
|
|
var tvInfo = await _api.GetSeriesInformation(tvShow.Id, server.ApiKey, server.AdministratorId,
|
|
|
|
|
server.FullUri);
|
|
|
|
|
if (string.IsNullOrEmpty(tvInfo.ProviderIds?.Tvdb))
|
|
|
|
|
{
|
|
|
|
|
Log.Error("Provider Id on tv {0} is null", tvShow.Name);
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var existingTv = await _repo.GetByEmbyId(tvShow.Id);
|
|
|
|
|
if (existingTv == null)
|
|
|
|
|
mediaToAdd.Add(new EmbyContent
|
|
|
|
|
{
|
|
|
|
|
ProviderId = tvInfo.ProviderIds.Tvdb,
|
|
|
|
|
Title = tvInfo.Name,
|
|
|
|
|
Type = EmbyMediaType.Series,
|
|
|
|
|
EmbyId = tvShow.Id,
|
|
|
|
|
AddedAt = DateTime.UtcNow
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (mediaToAdd.Any())
|
|
|
|
|
await _repo.AddRange(mediaToAdd);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private async Task ProcessMovies(MovieInformation movieInfo, ICollection<EmbyContent> content)
|
|
|
|
|
{
|
|
|
|
|
if (string.IsNullOrEmpty(movieInfo.ProviderIds.Imdb))
|
|
|
|
|
{
|
|
|
|
|
Log.Error("Provider Id on movie {0} is null", movieInfo.Name);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
// Check if it exists
|
|
|
|
|
var existingMovie = await _repo.GetByEmbyId(movieInfo.Id);
|
|
|
|
|
|
|
|
|
|
if (existingMovie == null)
|
|
|
|
|
content.Add(new EmbyContent
|
|
|
|
|
{
|
|
|
|
|
ProviderId = movieInfo.ProviderIds.Imdb,
|
|
|
|
|
Title = movieInfo.Name,
|
|
|
|
|
Type = EmbyMediaType.Movie,
|
|
|
|
|
EmbyId = movieInfo.Id,
|
|
|
|
|
AddedAt = DateTime.UtcNow,
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private bool ValidateSettings(EmbyServers server)
|
|
|
|
|
{
|
|
|
|
|
if (server?.Ip == null || string.IsNullOrEmpty(server?.ApiKey))
|
|
|
|
|
{
|
|
|
|
|
_logger.LogInformation(LoggingEvents.EmbyContentCacher, $"Server {server?.Name} is not configured correctly");
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|