using MediaBrowser.Common.Extensions; using MediaBrowser.Controller; using MediaBrowser.Controller.Entities; using MediaBrowser.Controller.Net; using MediaBrowser.Model.Dto; using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Threading.Tasks; using MediaBrowser.Common.IO; using MediaBrowser.Controller.IO; using MediaBrowser.Model.IO; using MediaBrowser.Model.Services; namespace MediaBrowser.Api.Images { /// /// Class GetGeneralImage /// [Route("/Images/General/{Name}/{Type}", "GET", Summary = "Gets a general image by name")] public class GetGeneralImage { /// /// Gets or sets the name. /// /// The name. [ApiMember(Name = "Name", Description = "The name of the image", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")] public string Name { get; set; } [ApiMember(Name = "Type", Description = "Image Type (primary, backdrop, logo, etc).", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")] public string Type { get; set; } } /// /// Class GetRatingImage /// [Route("/Images/Ratings/{Theme}/{Name}", "GET", Summary = "Gets a rating image by name")] public class GetRatingImage { /// /// Gets or sets the name. /// /// The name. [ApiMember(Name = "Name", Description = "The name of the image", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")] public string Name { get; set; } /// /// Gets or sets the theme. /// /// The theme. [ApiMember(Name = "Theme", Description = "The theme to get the image from", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")] public string Theme { get; set; } } /// /// Class GetMediaInfoImage /// [Route("/Images/MediaInfo/{Theme}/{Name}", "GET", Summary = "Gets a media info image by name")] public class GetMediaInfoImage { /// /// Gets or sets the name. /// /// The name. [ApiMember(Name = "Name", Description = "The name of the image", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")] public string Name { get; set; } /// /// Gets or sets the theme. /// /// The theme. [ApiMember(Name = "Theme", Description = "The theme to get the image from", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")] public string Theme { get; set; } } [Route("/Images/MediaInfo", "GET", Summary = "Gets all media info image by name")] [Authenticated] public class GetMediaInfoImages : IReturn> { } [Route("/Images/Ratings", "GET", Summary = "Gets all rating images by name")] [Authenticated] public class GetRatingImages : IReturn> { } [Route("/Images/General", "GET", Summary = "Gets all general images by name")] [Authenticated] public class GetGeneralImages : IReturn> { } /// /// Class ImageByNameService /// public class ImageByNameService : BaseApiService { /// /// The _app paths /// private readonly IServerApplicationPaths _appPaths; private readonly IFileSystem _fileSystem; private readonly IHttpResultFactory _resultFactory; /// /// Initializes a new instance of the class. /// /// The app paths. public ImageByNameService(IServerApplicationPaths appPaths, IFileSystem fileSystem, IHttpResultFactory resultFactory) { _appPaths = appPaths; _fileSystem = fileSystem; _resultFactory = resultFactory; } public object Get(GetMediaInfoImages request) { return ToOptimizedResult(GetImageList(_appPaths.MediaInfoImagesPath, true)); } public object Get(GetRatingImages request) { return ToOptimizedResult(GetImageList(_appPaths.RatingsPath, true)); } public object Get(GetGeneralImages request) { return ToOptimizedResult(GetImageList(_appPaths.GeneralPath, false)); } private List GetImageList(string path, bool supportsThemes) { try { return _fileSystem.GetFiles(path, BaseItem.SupportedImageExtensions, false, true) .Select(i => new ImageByNameInfo { Name = _fileSystem.GetFileNameWithoutExtension(i), FileLength = i.Length, // For themeable images, use the Theme property // For general images, the same object structure is fine, // but it's not owned by a theme, so call it Context Theme = supportsThemes ? GetThemeName(i.FullName, path) : null, Context = supportsThemes ? null : GetThemeName(i.FullName, path), Format = i.Extension.ToLower().TrimStart('.') }) .OrderBy(i => i.Name) .ToList(); } catch (IOException) { return new List(); } } private string GetThemeName(string path, string rootImagePath) { var parentName = _fileSystem.GetDirectoryName(path); if (string.Equals(parentName, rootImagePath, StringComparison.OrdinalIgnoreCase)) { return null; } parentName = Path.GetFileName(parentName); return string.Equals(parentName, "all", StringComparison.OrdinalIgnoreCase) ? null : parentName; } /// /// Gets the specified request. /// /// The request. /// System.Object. public Task Get(GetGeneralImage request) { var filename = string.Equals(request.Type, "primary", StringComparison.OrdinalIgnoreCase) ? "folder" : request.Type; var paths = BaseItem.SupportedImageExtensions.Select(i => Path.Combine(_appPaths.GeneralPath, request.Name, filename + i)).ToList(); var path = paths.FirstOrDefault(_fileSystem.FileExists) ?? paths.FirstOrDefault(); return _resultFactory.GetStaticFileResult(Request, path); } /// /// Gets the specified request. /// /// The request. /// System.Object. public object Get(GetRatingImage request) { var themeFolder = Path.Combine(_appPaths.RatingsPath, request.Theme); if (_fileSystem.DirectoryExists(themeFolder)) { var path = BaseItem.SupportedImageExtensions .Select(i => Path.Combine(themeFolder, request.Name + i)) .FirstOrDefault(_fileSystem.FileExists); if (!string.IsNullOrEmpty(path)) { return _resultFactory.GetStaticFileResult(Request, path); } } var allFolder = Path.Combine(_appPaths.RatingsPath, "all"); if (_fileSystem.DirectoryExists(allFolder)) { // Avoid implicitly captured closure var currentRequest = request; var path = BaseItem.SupportedImageExtensions .Select(i => Path.Combine(allFolder, currentRequest.Name + i)) .FirstOrDefault(_fileSystem.FileExists); if (!string.IsNullOrEmpty(path)) { return _resultFactory.GetStaticFileResult(Request, path); } } throw new ResourceNotFoundException("MediaInfo image not found: " + request.Name); } /// /// Gets the specified request. /// /// The request. /// System.Object. public Task Get(GetMediaInfoImage request) { var themeFolder = Path.Combine(_appPaths.MediaInfoImagesPath, request.Theme); if (_fileSystem.DirectoryExists(themeFolder)) { var path = BaseItem.SupportedImageExtensions.Select(i => Path.Combine(themeFolder, request.Name + i)) .FirstOrDefault(_fileSystem.FileExists); if (!string.IsNullOrEmpty(path)) { return _resultFactory.GetStaticFileResult(Request, path); } } var allFolder = Path.Combine(_appPaths.MediaInfoImagesPath, "all"); if (_fileSystem.DirectoryExists(allFolder)) { // Avoid implicitly captured closure var currentRequest = request; var path = BaseItem.SupportedImageExtensions.Select(i => Path.Combine(allFolder, currentRequest.Name + i)) .FirstOrDefault(_fileSystem.FileExists); if (!string.IsNullOrEmpty(path)) { return _resultFactory.GetStaticFileResult(Request, path); } } throw new ResourceNotFoundException("MediaInfo image not found: " + request.Name); } } }