InternalMetadataFolderImageProvider.cs 3.0 KB

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