BaseFFMpegProvider.cs 2.4 KB

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