BaseXmlProvider.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. using System.IO;
  2. using System.Threading;
  3. using System.Threading.Tasks;
  4. using MediaBrowser.Controller.Entities;
  5. using MediaBrowser.Controller.Providers;
  6. using MediaBrowser.Model.IO;
  7. namespace MediaBrowser.LocalMetadata
  8. {
  9. /// <summary>
  10. /// The BaseXmlProvider.
  11. /// </summary>
  12. /// <typeparam name="T">Type of provider.</typeparam>
  13. public abstract class BaseXmlProvider<T> : ILocalMetadataProvider<T>, IHasItemChangeMonitor, IHasOrder
  14. where T : BaseItem, new()
  15. {
  16. /// <summary>
  17. /// Initializes a new instance of the <see cref="BaseXmlProvider{T}"/> class.
  18. /// </summary>
  19. /// <param name="fileSystem">Instance of the <see cref="IFileSystem"/> interface.</param>
  20. protected BaseXmlProvider(IFileSystem fileSystem)
  21. {
  22. this.FileSystem = fileSystem;
  23. }
  24. /// <inheritdoc />
  25. public string Name => XmlProviderUtils.Name;
  26. /// After Nfo
  27. /// <inheritdoc />
  28. public virtual int Order => 1;
  29. /// <summary>
  30. /// Gets the IFileSystem.
  31. /// </summary>
  32. protected IFileSystem FileSystem { get; }
  33. /// <summary>
  34. /// Gets metadata for item.
  35. /// </summary>
  36. /// <param name="info">The item info.</param>
  37. /// <param name="directoryService">Instance of the <see cref="IDirectoryService"/> interface.</param>
  38. /// <param name="cancellationToken">The cancellation token.</param>
  39. /// <returns>The metadata for item.</returns>
  40. public Task<MetadataResult<T>> GetMetadata(
  41. ItemInfo info,
  42. IDirectoryService directoryService,
  43. CancellationToken cancellationToken)
  44. {
  45. var result = new MetadataResult<T>();
  46. var file = GetXmlFile(info, directoryService);
  47. if (file is null)
  48. {
  49. return Task.FromResult(result);
  50. }
  51. var path = file.FullName;
  52. try
  53. {
  54. result.Item = new T();
  55. Fetch(result, path, cancellationToken);
  56. result.HasMetadata = true;
  57. }
  58. catch (FileNotFoundException)
  59. {
  60. result.HasMetadata = false;
  61. }
  62. catch (IOException)
  63. {
  64. result.HasMetadata = false;
  65. }
  66. return Task.FromResult(result);
  67. }
  68. /// <summary>
  69. /// Get metadata from path.
  70. /// </summary>
  71. /// <param name="result">Resulting metadata.</param>
  72. /// <param name="path">The path.</param>
  73. /// <param name="cancellationToken">The cancellation token.</param>
  74. protected abstract void Fetch(MetadataResult<T> result, string path, CancellationToken cancellationToken);
  75. /// <summary>
  76. /// Get metadata from xml file.
  77. /// </summary>
  78. /// <param name="info">Item inf.</param>
  79. /// <param name="directoryService">Instance of the <see cref="IDirectoryService"/> interface.</param>
  80. /// <returns>The file system metadata.</returns>
  81. protected abstract FileSystemMetadata? GetXmlFile(ItemInfo info, IDirectoryService directoryService);
  82. /// <inheritdoc />
  83. public bool HasChanged(BaseItem item, IDirectoryService directoryService)
  84. {
  85. var file = GetXmlFile(new ItemInfo(item), directoryService);
  86. if (file is null)
  87. {
  88. return false;
  89. }
  90. return file.Exists && FileSystem.GetLastWriteTimeUtc(file) > item.DateLastSaved;
  91. }
  92. }
  93. }