InternalMetadataFolderImageProvider.cs 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. using System.Collections.Generic;
  2. using System.IO;
  3. using System.Linq;
  4. using MediaBrowser.Controller.Entities;
  5. using MediaBrowser.Controller.Entities.Audio;
  6. using MediaBrowser.Controller.Providers;
  7. using MediaBrowser.Model.IO;
  8. using Microsoft.Extensions.Logging;
  9. namespace MediaBrowser.LocalMetadata.Images
  10. {
  11. /// <summary>
  12. /// Internal metadata folder image provider.
  13. /// </summary>
  14. public class InternalMetadataFolderImageProvider : ILocalImageProvider, IHasOrder
  15. {
  16. private readonly IFileSystem _fileSystem;
  17. private readonly ILogger<InternalMetadataFolderImageProvider> _logger;
  18. /// <summary>
  19. /// Initializes a new instance of the <see cref="InternalMetadataFolderImageProvider"/> class.
  20. /// </summary>
  21. /// <param name="fileSystem">Instance of the <see cref="IFileSystem"/> interface.</param>
  22. /// <param name="logger">Instance of the <see cref="ILogger{InternalMetadataFolderImageProvider}"/> interface.</param>
  23. public InternalMetadataFolderImageProvider(
  24. IFileSystem fileSystem,
  25. ILogger<InternalMetadataFolderImageProvider> logger)
  26. {
  27. _fileSystem = fileSystem;
  28. _logger = logger;
  29. }
  30. /// Make sure this is last so that all other locations are scanned first
  31. /// <inheritdoc />
  32. public int Order => 1000;
  33. /// <inheritdoc />
  34. public string Name => "Internal Images";
  35. /// <inheritdoc />
  36. public bool Supports(BaseItem item)
  37. {
  38. if (item is Photo)
  39. {
  40. return false;
  41. }
  42. if (!item.IsSaveLocalMetadataEnabled())
  43. {
  44. return true;
  45. }
  46. // Extracted images will be saved in here
  47. if (item is Audio)
  48. {
  49. return true;
  50. }
  51. if (item.SupportsLocalMetadata && !item.AlwaysScanInternalMetadataPath)
  52. {
  53. return false;
  54. }
  55. return true;
  56. }
  57. /// <inheritdoc />
  58. public IEnumerable<LocalImageInfo> GetImages(BaseItem item, IDirectoryService directoryService)
  59. {
  60. var path = item.GetInternalMetadataPath();
  61. if (!Directory.Exists(path))
  62. {
  63. return Enumerable.Empty<LocalImageInfo>();
  64. }
  65. try
  66. {
  67. return new LocalImageProvider(_fileSystem).GetImages(item, path, directoryService);
  68. }
  69. catch (IOException ex)
  70. {
  71. _logger.LogError(ex, "Error while getting images for {Library}", item.Name);
  72. return Enumerable.Empty<LocalImageInfo>();
  73. }
  74. }
  75. }
  76. }