BaseFFMpegProvider.cs 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. using MediaBrowser.Common.IO;
  2. using MediaBrowser.Common.MediaInfo;
  3. using MediaBrowser.Controller.Configuration;
  4. using MediaBrowser.Controller.Entities;
  5. using MediaBrowser.Model.Entities;
  6. using MediaBrowser.Model.Logging;
  7. using System;
  8. using System.Threading.Tasks;
  9. namespace MediaBrowser.Controller.Providers.MediaInfo
  10. {
  11. /// <summary>
  12. /// Class BaseFFMpegProvider
  13. /// </summary>
  14. /// <typeparam name="T"></typeparam>
  15. public abstract class BaseFFMpegProvider<T> : BaseMetadataProvider
  16. where T : BaseItem
  17. {
  18. protected readonly IMediaEncoder MediaEncoder;
  19. protected BaseFFMpegProvider(ILogManager logManager, IServerConfigurationManager configurationManager, IMediaEncoder mediaEncoder) : base(logManager, configurationManager)
  20. {
  21. MediaEncoder = mediaEncoder;
  22. }
  23. /// <summary>
  24. /// Supportses the specified item.
  25. /// </summary>
  26. /// <param name="item">The item.</param>
  27. /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
  28. public override bool Supports(BaseItem item)
  29. {
  30. return item.LocationType == LocationType.FileSystem && item is T;
  31. }
  32. /// <summary>
  33. /// Override this to return the date that should be compared to the last refresh date
  34. /// to determine if this provider should be re-fetched.
  35. /// </summary>
  36. /// <param name="item">The item.</param>
  37. /// <returns>DateTime.</returns>
  38. protected override DateTime CompareDate(BaseItem item)
  39. {
  40. return item.DateModified;
  41. }
  42. /// <summary>
  43. /// The null mount task result
  44. /// </summary>
  45. protected readonly Task<IIsoMount> NullMountTaskResult = Task.FromResult<IIsoMount>(null);
  46. /// <summary>
  47. /// Gets the provider version.
  48. /// </summary>
  49. /// <value>The provider version.</value>
  50. protected override string ProviderVersion
  51. {
  52. get
  53. {
  54. return MediaEncoder.Version;
  55. }
  56. }
  57. /// <summary>
  58. /// Needses the refresh internal.
  59. /// </summary>
  60. /// <param name="item">The item.</param>
  61. /// <param name="providerInfo">The provider info.</param>
  62. /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
  63. protected override bool NeedsRefreshInternal(BaseItem item, BaseProviderInfo providerInfo)
  64. {
  65. // If the last run wasn't successful, try again when there's a new version of ffmpeg
  66. if (providerInfo.LastRefreshStatus != ProviderRefreshStatus.Success)
  67. {
  68. if (!string.Equals(ProviderVersion, providerInfo.ProviderVersion))
  69. {
  70. return true;
  71. }
  72. }
  73. return base.NeedsRefreshInternal(item, providerInfo);
  74. }
  75. }
  76. }