using Jellyfin.Plugin.MetaShark.Api; using Jellyfin.Plugin.MetaShark.Core; using Jellyfin.Plugin.MetaShark.Model; using MediaBrowser.Controller.Entities; using MediaBrowser.Controller.Entities.Movies; using MediaBrowser.Controller.Entities.TV; using MediaBrowser.Controller.Library; using MediaBrowser.Controller.Providers; using MediaBrowser.Model.Dto; using MediaBrowser.Model.Entities; using MediaBrowser.Model.Extensions; using MediaBrowser.Model.Providers; using Microsoft.Extensions.Logging; using System; using System.Collections.Generic; using System.Linq; using System.Net.Http; using System.Text; using System.Threading; using System.Threading.Tasks; using TMDbLib.Objects.Languages; namespace Jellyfin.Plugin.MetaShark.Providers { public class MovieImageProvider : BaseProvider, IRemoteImageProvider { /// /// Initializes a new instance of the class. /// /// Instance of the interface. /// Instance of the interface. /// Instance of . public MovieImageProvider(IHttpClientFactory httpClientFactory, ILoggerFactory loggerFactory, ILibraryManager libraryManager, DoubanApi doubanApi, TmdbApi tmdbApi, OmdbApi omdbApi) : base(httpClientFactory, loggerFactory.CreateLogger(), libraryManager, doubanApi, tmdbApi, omdbApi) { } /// public string Name => Plugin.PluginName; /// public bool Supports(BaseItem item) => item is Movie; /// public IEnumerable GetSupportedImages(BaseItem item) => new List { ImageType.Primary, ImageType.Backdrop }; /// public async Task> GetImages(BaseItem item, CancellationToken cancellationToken) { var sid = item.GetProviderId(DoubanProviderId); var metaSource = item.GetProviderId(Plugin.ProviderId); this.Log($"GetImages for item: {item.Name} [metaSource]: {metaSource}"); if (!string.IsNullOrEmpty(sid) && metaSource == MetaSource.Douban) { var primary = await this._doubanApi.GetMovieAsync(sid, cancellationToken); var dropback = await GetBackdrop(sid, cancellationToken); var res = new List { new RemoteImageInfo { ProviderName = primary.Name, Url = primary.ImgMiddle, Type = ImageType.Primary } }; res.AddRange(dropback); return res; } var tmdbId = item.GetProviderId(MetadataProvider.Tmdb).ToInt(); if (tmdbId > 0) { var language = item.GetPreferredMetadataLanguage(); var movie = await _tmdbApi .GetMovieAsync(tmdbId, language, language, cancellationToken) .ConfigureAwait(false); if (movie?.Images == null) { return Enumerable.Empty(); } var remoteImages = new List(); for (var i = 0; i < movie.Images.Posters.Count; i++) { var poster = movie.Images.Posters[i]; remoteImages.Add(new RemoteImageInfo { Url = _tmdbApi.GetPosterUrl(poster.FilePath), CommunityRating = poster.VoteAverage, VoteCount = poster.VoteCount, Width = poster.Width, Height = poster.Height, ProviderName = Name, Type = ImageType.Primary, }); } for (var i = 0; i < movie.Images.Backdrops.Count; i++) { var backdrop = movie.Images.Backdrops[i]; remoteImages.Add(new RemoteImageInfo { Url = _tmdbApi.GetPosterUrl(backdrop.FilePath), CommunityRating = backdrop.VoteAverage, VoteCount = backdrop.VoteCount, Width = backdrop.Width, Height = backdrop.Height, ProviderName = Name, Type = ImageType.Backdrop, RatingType = RatingType.Score }); } return remoteImages.OrderByLanguageDescending(language); } this.Log($"Got images failed because the sid of \"{item.Name}\" is empty!"); return new List(); } /// public async Task GetImageResponse(string url, CancellationToken cancellationToken) { this.Log("GetImageResponse url: {0}", url); return await this._httpClientFactory.CreateClient().GetAsync(new Uri(url), cancellationToken).ConfigureAwait(false); } /// /// Query for a background photo /// /// a subject/movie id /// Instance of the interface. private async Task> GetBackdrop(string sid, CancellationToken cancellationToken) { this.Log("GetBackdrop of sid: {0}", sid); var photo = await this._doubanApi.GetWallpaperBySidAsync(sid, cancellationToken); var list = new List(); if (photo == null) { return list; } return photo.Where(x => x.Width > x.Height * 1.3).Select(x => { return new RemoteImageInfo { ProviderName = Name, Url = x.Large, Type = ImageType.Backdrop, }; }); } } }