2019-01-13 19:24:58 +00:00
|
|
|
|
using System;
|
2014-05-07 02:28:19 +00:00
|
|
|
|
using System.Collections.Generic;
|
2013-05-02 15:12:27 +00:00
|
|
|
|
using System.IO;
|
2013-05-30 22:22:15 +00:00
|
|
|
|
using System.Linq;
|
2016-11-10 21:06:00 +00:00
|
|
|
|
using System.Threading.Tasks;
|
2019-01-13 19:24:58 +00:00
|
|
|
|
using MediaBrowser.Common.Extensions;
|
|
|
|
|
using MediaBrowser.Controller;
|
|
|
|
|
using MediaBrowser.Controller.Entities;
|
|
|
|
|
using MediaBrowser.Controller.Net;
|
|
|
|
|
using MediaBrowser.Model.Dto;
|
2016-10-25 19:02:04 +00:00
|
|
|
|
using MediaBrowser.Model.IO;
|
|
|
|
|
using MediaBrowser.Model.Services;
|
2013-05-02 15:12:27 +00:00
|
|
|
|
|
|
|
|
|
namespace MediaBrowser.Api.Images
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Class GetGeneralImage
|
|
|
|
|
/// </summary>
|
2014-11-15 02:31:03 +00:00
|
|
|
|
[Route("/Images/General/{Name}/{Type}", "GET", Summary = "Gets a general image by name")]
|
2013-05-03 18:33:47 +00:00
|
|
|
|
public class GetGeneralImage
|
2013-05-02 15:12:27 +00:00
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the name.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <value>The name.</value>
|
|
|
|
|
[ApiMember(Name = "Name", Description = "The name of the image", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")]
|
|
|
|
|
public string Name { get; set; }
|
2013-05-03 18:33:47 +00:00
|
|
|
|
|
|
|
|
|
[ApiMember(Name = "Type", Description = "Image Type (primary, backdrop, logo, etc).", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")]
|
|
|
|
|
public string Type { get; set; }
|
2013-05-02 15:12:27 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Class GetRatingImage
|
|
|
|
|
/// </summary>
|
2014-11-15 02:31:03 +00:00
|
|
|
|
[Route("/Images/Ratings/{Theme}/{Name}", "GET", Summary = "Gets a rating image by name")]
|
2013-05-03 18:33:47 +00:00
|
|
|
|
public class GetRatingImage
|
2013-05-02 15:12:27 +00:00
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the name.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <value>The name.</value>
|
|
|
|
|
[ApiMember(Name = "Name", Description = "The name of the image", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")]
|
|
|
|
|
public string Name { get; set; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the theme.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <value>The theme.</value>
|
|
|
|
|
[ApiMember(Name = "Theme", Description = "The theme to get the image from", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")]
|
|
|
|
|
public string Theme { get; set; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Class GetMediaInfoImage
|
|
|
|
|
/// </summary>
|
2014-11-15 02:31:03 +00:00
|
|
|
|
[Route("/Images/MediaInfo/{Theme}/{Name}", "GET", Summary = "Gets a media info image by name")]
|
2013-05-03 18:33:47 +00:00
|
|
|
|
public class GetMediaInfoImage
|
2013-05-02 15:12:27 +00:00
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the name.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <value>The name.</value>
|
|
|
|
|
[ApiMember(Name = "Name", Description = "The name of the image", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")]
|
|
|
|
|
public string Name { get; set; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets or sets the theme.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <value>The theme.</value>
|
|
|
|
|
[ApiMember(Name = "Theme", Description = "The theme to get the image from", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")]
|
|
|
|
|
public string Theme { get; set; }
|
|
|
|
|
}
|
|
|
|
|
|
2014-11-15 02:31:03 +00:00
|
|
|
|
[Route("/Images/MediaInfo", "GET", Summary = "Gets all media info image by name")]
|
|
|
|
|
[Authenticated]
|
2014-05-07 02:28:19 +00:00
|
|
|
|
public class GetMediaInfoImages : IReturn<List<ImageByNameInfo>>
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2014-11-15 02:31:03 +00:00
|
|
|
|
[Route("/Images/Ratings", "GET", Summary = "Gets all rating images by name")]
|
|
|
|
|
[Authenticated]
|
2014-05-07 02:28:19 +00:00
|
|
|
|
public class GetRatingImages : IReturn<List<ImageByNameInfo>>
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2014-11-15 02:31:03 +00:00
|
|
|
|
[Route("/Images/General", "GET", Summary = "Gets all general images by name")]
|
|
|
|
|
[Authenticated]
|
2014-05-07 02:28:19 +00:00
|
|
|
|
public class GetGeneralImages : IReturn<List<ImageByNameInfo>>
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2013-05-02 15:12:27 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Class ImageByNameService
|
|
|
|
|
/// </summary>
|
|
|
|
|
public class ImageByNameService : BaseApiService
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// The _app paths
|
|
|
|
|
/// </summary>
|
|
|
|
|
private readonly IServerApplicationPaths _appPaths;
|
|
|
|
|
|
2014-07-26 17:30:15 +00:00
|
|
|
|
private readonly IFileSystem _fileSystem;
|
2016-11-10 14:41:24 +00:00
|
|
|
|
private readonly IHttpResultFactory _resultFactory;
|
2014-07-26 17:30:15 +00:00
|
|
|
|
|
2013-05-02 15:12:27 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Initializes a new instance of the <see cref="ImageByNameService" /> class.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="appPaths">The app paths.</param>
|
2016-11-10 14:41:24 +00:00
|
|
|
|
public ImageByNameService(IServerApplicationPaths appPaths, IFileSystem fileSystem, IHttpResultFactory resultFactory)
|
2013-05-02 15:12:27 +00:00
|
|
|
|
{
|
|
|
|
|
_appPaths = appPaths;
|
2014-07-26 17:30:15 +00:00
|
|
|
|
_fileSystem = fileSystem;
|
2016-11-10 14:41:24 +00:00
|
|
|
|
_resultFactory = resultFactory;
|
2013-05-02 15:12:27 +00:00
|
|
|
|
}
|
|
|
|
|
|
2014-05-07 02:28:19 +00:00
|
|
|
|
public object Get(GetMediaInfoImages request)
|
|
|
|
|
{
|
2014-05-23 23:58:28 +00:00
|
|
|
|
return ToOptimizedResult(GetImageList(_appPaths.MediaInfoImagesPath, true));
|
2014-05-07 02:28:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public object Get(GetRatingImages request)
|
|
|
|
|
{
|
2014-05-23 23:58:28 +00:00
|
|
|
|
return ToOptimizedResult(GetImageList(_appPaths.RatingsPath, true));
|
2014-05-07 02:28:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public object Get(GetGeneralImages request)
|
|
|
|
|
{
|
2014-05-23 23:58:28 +00:00
|
|
|
|
return ToOptimizedResult(GetImageList(_appPaths.GeneralPath, false));
|
2014-05-07 02:28:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2014-05-23 23:58:28 +00:00
|
|
|
|
private List<ImageByNameInfo> GetImageList(string path, bool supportsThemes)
|
2014-05-07 02:28:19 +00:00
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
2019-01-07 23:24:34 +00:00
|
|
|
|
return _fileSystem.GetFiles(path, BaseItem.SupportedImageExtensions, false, true)
|
2014-05-07 02:28:19 +00:00
|
|
|
|
.Select(i => new ImageByNameInfo
|
|
|
|
|
{
|
2014-07-26 17:30:15 +00:00
|
|
|
|
Name = _fileSystem.GetFileNameWithoutExtension(i),
|
2014-05-07 02:28:19 +00:00
|
|
|
|
FileLength = i.Length,
|
2014-06-01 04:11:04 +00:00
|
|
|
|
|
|
|
|
|
// 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
|
2014-05-23 23:58:28 +00:00
|
|
|
|
Theme = supportsThemes ? GetThemeName(i.FullName, path) : null,
|
2014-06-01 04:11:04 +00:00
|
|
|
|
Context = supportsThemes ? null : GetThemeName(i.FullName, path),
|
|
|
|
|
|
2014-05-07 02:28:19 +00:00
|
|
|
|
Format = i.Extension.ToLower().TrimStart('.')
|
|
|
|
|
})
|
|
|
|
|
.OrderBy(i => i.Name)
|
|
|
|
|
.ToList();
|
|
|
|
|
}
|
2016-11-01 03:07:45 +00:00
|
|
|
|
catch (IOException)
|
2014-05-07 02:28:19 +00:00
|
|
|
|
{
|
|
|
|
|
return new List<ImageByNameInfo>();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private string GetThemeName(string path, string rootImagePath)
|
|
|
|
|
{
|
2017-05-04 18:14:45 +00:00
|
|
|
|
var parentName = _fileSystem.GetDirectoryName(path);
|
2014-05-07 02:28:19 +00:00
|
|
|
|
|
|
|
|
|
if (string.Equals(parentName, rootImagePath, StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
{
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
parentName = Path.GetFileName(parentName);
|
|
|
|
|
|
|
|
|
|
return string.Equals(parentName, "all", StringComparison.OrdinalIgnoreCase) ?
|
|
|
|
|
null :
|
|
|
|
|
parentName;
|
|
|
|
|
}
|
|
|
|
|
|
2013-05-02 15:12:27 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets the specified request.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="request">The request.</param>
|
|
|
|
|
/// <returns>System.Object.</returns>
|
2016-11-10 21:06:00 +00:00
|
|
|
|
public Task<object> Get(GetGeneralImage request)
|
2013-05-02 15:12:27 +00:00
|
|
|
|
{
|
2013-05-03 19:34:25 +00:00
|
|
|
|
var filename = string.Equals(request.Type, "primary", StringComparison.OrdinalIgnoreCase)
|
2013-05-03 18:33:47 +00:00
|
|
|
|
? "folder"
|
|
|
|
|
: request.Type;
|
|
|
|
|
|
2013-05-30 22:22:15 +00:00
|
|
|
|
var paths = BaseItem.SupportedImageExtensions.Select(i => Path.Combine(_appPaths.GeneralPath, request.Name, filename + i)).ToList();
|
2013-05-02 15:12:27 +00:00
|
|
|
|
|
2019-01-07 23:24:34 +00:00
|
|
|
|
var path = paths.FirstOrDefault(_fileSystem.FileExists) ?? paths.FirstOrDefault();
|
2013-05-30 22:22:15 +00:00
|
|
|
|
|
2016-11-10 14:41:24 +00:00
|
|
|
|
return _resultFactory.GetStaticFileResult(Request, path);
|
2013-05-02 15:12:27 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets the specified request.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="request">The request.</param>
|
|
|
|
|
/// <returns>System.Object.</returns>
|
|
|
|
|
public object Get(GetRatingImage request)
|
|
|
|
|
{
|
2013-05-02 15:31:39 +00:00
|
|
|
|
var themeFolder = Path.Combine(_appPaths.RatingsPath, request.Theme);
|
|
|
|
|
|
2019-01-07 23:24:34 +00:00
|
|
|
|
if (_fileSystem.DirectoryExists(themeFolder))
|
2013-05-02 15:31:39 +00:00
|
|
|
|
{
|
2014-05-07 02:28:19 +00:00
|
|
|
|
var path = BaseItem.SupportedImageExtensions
|
|
|
|
|
.Select(i => Path.Combine(themeFolder, request.Name + i))
|
2019-01-07 23:24:34 +00:00
|
|
|
|
.FirstOrDefault(_fileSystem.FileExists);
|
2013-05-02 15:31:39 +00:00
|
|
|
|
|
2013-05-30 22:22:15 +00:00
|
|
|
|
if (!string.IsNullOrEmpty(path))
|
2013-05-02 15:31:39 +00:00
|
|
|
|
{
|
2016-11-10 14:41:24 +00:00
|
|
|
|
return _resultFactory.GetStaticFileResult(Request, path);
|
2013-05-02 15:31:39 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var allFolder = Path.Combine(_appPaths.RatingsPath, "all");
|
|
|
|
|
|
2019-01-07 23:24:34 +00:00
|
|
|
|
if (_fileSystem.DirectoryExists(allFolder))
|
2013-05-02 15:31:39 +00:00
|
|
|
|
{
|
2013-05-30 22:22:15 +00:00
|
|
|
|
// Avoid implicitly captured closure
|
|
|
|
|
var currentRequest = request;
|
2013-05-02 15:31:39 +00:00
|
|
|
|
|
2014-05-07 02:28:19 +00:00
|
|
|
|
var path = BaseItem.SupportedImageExtensions
|
|
|
|
|
.Select(i => Path.Combine(allFolder, currentRequest.Name + i))
|
2019-01-07 23:24:34 +00:00
|
|
|
|
.FirstOrDefault(_fileSystem.FileExists);
|
2013-05-02 15:31:39 +00:00
|
|
|
|
|
2013-05-30 22:22:15 +00:00
|
|
|
|
if (!string.IsNullOrEmpty(path))
|
2013-05-02 15:31:39 +00:00
|
|
|
|
{
|
2016-11-10 14:41:24 +00:00
|
|
|
|
return _resultFactory.GetStaticFileResult(Request, path);
|
2013-05-02 15:31:39 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
throw new ResourceNotFoundException("MediaInfo image not found: " + request.Name);
|
2013-05-02 15:12:27 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Gets the specified request.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="request">The request.</param>
|
|
|
|
|
/// <returns>System.Object.</returns>
|
2016-11-10 21:06:00 +00:00
|
|
|
|
public Task<object> Get(GetMediaInfoImage request)
|
2013-05-02 15:12:27 +00:00
|
|
|
|
{
|
2013-05-02 15:31:39 +00:00
|
|
|
|
var themeFolder = Path.Combine(_appPaths.MediaInfoImagesPath, request.Theme);
|
2013-05-02 15:12:27 +00:00
|
|
|
|
|
2019-01-07 23:24:34 +00:00
|
|
|
|
if (_fileSystem.DirectoryExists(themeFolder))
|
2013-05-02 15:31:39 +00:00
|
|
|
|
{
|
2013-05-30 22:22:15 +00:00
|
|
|
|
var path = BaseItem.SupportedImageExtensions.Select(i => Path.Combine(themeFolder, request.Name + i))
|
2019-01-07 23:24:34 +00:00
|
|
|
|
.FirstOrDefault(_fileSystem.FileExists);
|
2013-05-02 15:12:27 +00:00
|
|
|
|
|
2013-05-30 22:22:15 +00:00
|
|
|
|
if (!string.IsNullOrEmpty(path))
|
2013-05-02 15:31:39 +00:00
|
|
|
|
{
|
2016-11-10 14:41:24 +00:00
|
|
|
|
return _resultFactory.GetStaticFileResult(Request, path);
|
2013-05-02 15:31:39 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2013-05-03 18:33:47 +00:00
|
|
|
|
|
2013-05-02 15:31:39 +00:00
|
|
|
|
var allFolder = Path.Combine(_appPaths.MediaInfoImagesPath, "all");
|
|
|
|
|
|
2019-01-07 23:24:34 +00:00
|
|
|
|
if (_fileSystem.DirectoryExists(allFolder))
|
2013-05-02 15:31:39 +00:00
|
|
|
|
{
|
2013-05-30 22:22:15 +00:00
|
|
|
|
// Avoid implicitly captured closure
|
|
|
|
|
var currentRequest = request;
|
2013-05-02 15:31:39 +00:00
|
|
|
|
|
2013-05-30 22:22:15 +00:00
|
|
|
|
var path = BaseItem.SupportedImageExtensions.Select(i => Path.Combine(allFolder, currentRequest.Name + i))
|
2019-01-07 23:24:34 +00:00
|
|
|
|
.FirstOrDefault(_fileSystem.FileExists);
|
2014-05-07 02:28:19 +00:00
|
|
|
|
|
2013-05-30 22:22:15 +00:00
|
|
|
|
if (!string.IsNullOrEmpty(path))
|
2013-05-02 15:31:39 +00:00
|
|
|
|
{
|
2016-11-10 14:41:24 +00:00
|
|
|
|
return _resultFactory.GetStaticFileResult(Request, path);
|
2013-05-02 15:31:39 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
throw new ResourceNotFoundException("MediaInfo image not found: " + request.Name);
|
2013-05-02 15:12:27 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|