FanArtSeasonProvider.cs 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. using MediaBrowser.Common.IO;
  2. using MediaBrowser.Controller.Configuration;
  3. using MediaBrowser.Controller.Entities;
  4. using MediaBrowser.Controller.Entities.TV;
  5. using MediaBrowser.Controller.Library;
  6. using MediaBrowser.Controller.Providers;
  7. using MediaBrowser.Model.Entities;
  8. using MediaBrowser.Model.Logging;
  9. using MediaBrowser.Model.Providers;
  10. using System;
  11. using System.Collections.Generic;
  12. using System.IO;
  13. using System.Linq;
  14. using System.Threading;
  15. using System.Threading.Tasks;
  16. using MediaBrowser.Model.Net;
  17. using System.Net;
  18. namespace MediaBrowser.Providers.TV
  19. {
  20. /// <summary>
  21. /// Class FanArtSeasonProvider
  22. /// </summary>
  23. class FanArtSeasonProvider : FanartBaseProvider
  24. {
  25. /// <summary>
  26. /// The _provider manager
  27. /// </summary>
  28. private readonly IProviderManager _providerManager;
  29. private readonly IFileSystem _fileSystem;
  30. /// <summary>
  31. /// Initializes a new instance of the <see cref="FanArtSeasonProvider"/> class.
  32. /// </summary>
  33. /// <param name="logManager">The log manager.</param>
  34. /// <param name="configurationManager">The configuration manager.</param>
  35. /// <param name="providerManager">The provider manager.</param>
  36. public FanArtSeasonProvider(ILogManager logManager, IServerConfigurationManager configurationManager, IProviderManager providerManager, IFileSystem fileSystem)
  37. : base(logManager, configurationManager)
  38. {
  39. _providerManager = providerManager;
  40. _fileSystem = fileSystem;
  41. }
  42. public override ItemUpdateType ItemUpdateType
  43. {
  44. get
  45. {
  46. return ItemUpdateType.ImageUpdate;
  47. }
  48. }
  49. /// <summary>
  50. /// Supportses the specified item.
  51. /// </summary>
  52. /// <param name="item">The item.</param>
  53. /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
  54. public override bool Supports(BaseItem item)
  55. {
  56. return item is Season;
  57. }
  58. /// <summary>
  59. /// Gets the priority.
  60. /// </summary>
  61. /// <value>The priority.</value>
  62. public override MetadataProviderPriority Priority
  63. {
  64. get { return MetadataProviderPriority.Third; }
  65. }
  66. protected override DateTime CompareDate(BaseItem item)
  67. {
  68. var season = (Season)item;
  69. var seriesId = season.Series != null ? season.Series.GetProviderId(MetadataProviders.Tvdb) : null;
  70. if (!string.IsNullOrEmpty(seriesId))
  71. {
  72. // Process images
  73. var imagesXmlPath = FanArtTvProvider.Current.GetFanartXmlPath(seriesId);
  74. var imagesFileInfo = new FileInfo(imagesXmlPath);
  75. if (imagesFileInfo.Exists)
  76. {
  77. return _fileSystem.GetLastWriteTimeUtc(imagesFileInfo);
  78. }
  79. }
  80. return base.CompareDate(item);
  81. }
  82. /// <summary>
  83. /// Fetches metadata and returns true or false indicating if any work that requires persistence was done
  84. /// </summary>
  85. /// <param name="item">The item.</param>
  86. /// <param name="force">if set to <c>true</c> [force].</param>
  87. /// <param name="cancellationToken">The cancellation token.</param>
  88. /// <returns>Task{System.Boolean}.</returns>
  89. public override async Task<bool> FetchAsync(BaseItem item, bool force, BaseProviderInfo providerInfo, CancellationToken cancellationToken)
  90. {
  91. cancellationToken.ThrowIfCancellationRequested();
  92. var season = (Season) item;
  93. // Process images
  94. var images = await _providerManager.GetAvailableRemoteImages(item, cancellationToken, ManualFanartSeasonImageProvider.ProviderName).ConfigureAwait(false);
  95. await FetchImages(season, images.ToList(), cancellationToken).ConfigureAwait(false);
  96. SetLastRefreshed(item, DateTime.UtcNow, providerInfo);
  97. return true;
  98. }
  99. /// <summary>
  100. /// Fetches the images.
  101. /// </summary>
  102. /// <param name="season">The season.</param>
  103. /// <param name="images">The images.</param>
  104. /// <param name="cancellationToken">The cancellation token.</param>
  105. /// <returns>Task.</returns>
  106. private async Task FetchImages(Season season, List<RemoteImageInfo> images, CancellationToken cancellationToken)
  107. {
  108. if (ConfigurationManager.Configuration.DownloadSeasonImages.Thumb && !season.HasImage(ImageType.Thumb) && !season.LockedFields.Contains(MetadataFields.Images))
  109. {
  110. await SaveImage(season, images, ImageType.Thumb, cancellationToken).ConfigureAwait(false);
  111. }
  112. }
  113. private async Task SaveImage(BaseItem item, List<RemoteImageInfo> images, ImageType type, CancellationToken cancellationToken)
  114. {
  115. foreach (var image in images.Where(i => i.Type == type))
  116. {
  117. try
  118. {
  119. await _providerManager.SaveImage(item, image.Url, FanArtResourcePool, type, null, cancellationToken).ConfigureAwait(false);
  120. break;
  121. }
  122. catch (HttpException ex)
  123. {
  124. // Sometimes fanart has bad url's in their xml
  125. if (ex.StatusCode.HasValue && ex.StatusCode.Value == HttpStatusCode.NotFound)
  126. {
  127. continue;
  128. }
  129. break;
  130. }
  131. }
  132. }
  133. /// <summary>
  134. /// Gets a value indicating whether [requires internet].
  135. /// </summary>
  136. /// <value><c>true</c> if [requires internet]; otherwise, <c>false</c>.</value>
  137. public override bool RequiresInternet
  138. {
  139. get
  140. {
  141. return true;
  142. }
  143. }
  144. /// <summary>
  145. /// Gets a value indicating whether [refresh on version change].
  146. /// </summary>
  147. /// <value><c>true</c> if [refresh on version change]; otherwise, <c>false</c>.</value>
  148. protected override bool RefreshOnVersionChange
  149. {
  150. get
  151. {
  152. return true;
  153. }
  154. }
  155. /// <summary>
  156. /// Gets the provider version.
  157. /// </summary>
  158. /// <value>The provider version.</value>
  159. protected override string ProviderVersion
  160. {
  161. get
  162. {
  163. return "3";
  164. }
  165. }
  166. }
  167. }