InternalMetadataFolderImageProvider.cs 2.9 KB

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