TvdbSeriesImageProvider.cs 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. using MediaBrowser.Common.IO;
  2. using MediaBrowser.Common.Net;
  3. using MediaBrowser.Controller.Configuration;
  4. using MediaBrowser.Controller.Entities;
  5. using MediaBrowser.Controller.Entities.TV;
  6. using MediaBrowser.Controller.Library;
  7. using MediaBrowser.Controller.Providers;
  8. using MediaBrowser.Model.Entities;
  9. using MediaBrowser.Model.Logging;
  10. using MediaBrowser.Model.Providers;
  11. using System;
  12. using System.Collections.Generic;
  13. using System.IO;
  14. using System.Linq;
  15. using System.Threading;
  16. using System.Threading.Tasks;
  17. namespace MediaBrowser.Providers.TV
  18. {
  19. public class TvdbSeriesImageProvider : BaseMetadataProvider
  20. {
  21. /// <summary>
  22. /// Gets the HTTP client.
  23. /// </summary>
  24. /// <value>The HTTP client.</value>
  25. protected IHttpClient HttpClient { get; private set; }
  26. /// <summary>
  27. /// The _provider manager
  28. /// </summary>
  29. private readonly IProviderManager _providerManager;
  30. private readonly IFileSystem _fileSystem;
  31. /// <summary>
  32. /// Initializes a new instance of the <see cref="TvdbSeriesImageProvider"/> class.
  33. /// </summary>
  34. /// <param name="httpClient">The HTTP client.</param>
  35. /// <param name="logManager">The log manager.</param>
  36. /// <param name="configurationManager">The configuration manager.</param>
  37. /// <param name="providerManager">The provider manager.</param>
  38. /// <exception cref="System.ArgumentNullException">httpClient</exception>
  39. public TvdbSeriesImageProvider(IHttpClient httpClient, ILogManager logManager, IServerConfigurationManager configurationManager, IProviderManager providerManager, IFileSystem fileSystem)
  40. : base(logManager, configurationManager)
  41. {
  42. if (httpClient == null)
  43. {
  44. throw new ArgumentNullException("httpClient");
  45. }
  46. HttpClient = httpClient;
  47. _providerManager = providerManager;
  48. _fileSystem = fileSystem;
  49. }
  50. /// <summary>
  51. /// Supportses the specified item.
  52. /// </summary>
  53. /// <param name="item">The item.</param>
  54. /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
  55. public override bool Supports(BaseItem item)
  56. {
  57. return item is Series;
  58. }
  59. /// <summary>
  60. /// Gets the priority.
  61. /// </summary>
  62. /// <value>The priority.</value>
  63. public override MetadataProviderPriority Priority
  64. {
  65. // Run after fanart
  66. get { return MetadataProviderPriority.Fourth; }
  67. }
  68. /// <summary>
  69. /// Gets a value indicating whether [requires internet].
  70. /// </summary>
  71. /// <value><c>true</c> if [requires internet]; otherwise, <c>false</c>.</value>
  72. public override bool RequiresInternet
  73. {
  74. get
  75. {
  76. return true;
  77. }
  78. }
  79. public override ItemUpdateType ItemUpdateType
  80. {
  81. get
  82. {
  83. return ItemUpdateType.ImageUpdate;
  84. }
  85. }
  86. /// <summary>
  87. /// Gets a value indicating whether [refresh on version change].
  88. /// </summary>
  89. /// <value><c>true</c> if [refresh on version change]; otherwise, <c>false</c>.</value>
  90. protected override bool RefreshOnVersionChange
  91. {
  92. get
  93. {
  94. return true;
  95. }
  96. }
  97. /// <summary>
  98. /// Gets the provider version.
  99. /// </summary>
  100. /// <value>The provider version.</value>
  101. protected override string ProviderVersion
  102. {
  103. get
  104. {
  105. return "1";
  106. }
  107. }
  108. protected override DateTime CompareDate(BaseItem item)
  109. {
  110. var seriesId = item.GetProviderId(MetadataProviders.Tvdb);
  111. if (!string.IsNullOrEmpty(seriesId))
  112. {
  113. // Process images
  114. var imagesXmlPath = Path.Combine(TvdbSeriesProvider.GetSeriesDataPath(ConfigurationManager.ApplicationPaths, seriesId), "banners.xml");
  115. var imagesFileInfo = new FileInfo(imagesXmlPath);
  116. if (imagesFileInfo.Exists)
  117. {
  118. return _fileSystem.GetLastWriteTimeUtc(imagesFileInfo);
  119. }
  120. }
  121. return base.CompareDate(item);
  122. }
  123. protected override bool NeedsRefreshInternal(BaseItem item, BaseProviderInfo providerInfo)
  124. {
  125. if (item.HasImage(ImageType.Primary) && item.HasImage(ImageType.Banner) && item.BackdropImagePaths.Count >= ConfigurationManager.Configuration.MaxBackdrops)
  126. {
  127. return false;
  128. }
  129. return base.NeedsRefreshInternal(item, providerInfo);
  130. }
  131. /// <summary>
  132. /// Fetches metadata and returns true or false indicating if any work that requires persistence was done
  133. /// </summary>
  134. /// <param name="item">The item.</param>
  135. /// <param name="force">if set to <c>true</c> [force].</param>
  136. /// <param name="cancellationToken">The cancellation token.</param>
  137. /// <returns>Task{System.Boolean}.</returns>
  138. public override async Task<bool> FetchAsync(BaseItem item, bool force, BaseProviderInfo providerInfo, CancellationToken cancellationToken)
  139. {
  140. cancellationToken.ThrowIfCancellationRequested();
  141. var images = await _providerManager.GetAvailableRemoteImages(item, cancellationToken, ManualTvdbSeriesImageProvider.ProviderName).ConfigureAwait(false);
  142. const int backdropLimit = 1;
  143. await DownloadImages(item, images.ToList(), backdropLimit, cancellationToken).ConfigureAwait(false);
  144. SetLastRefreshed(item, DateTime.UtcNow, providerInfo);
  145. return true;
  146. }
  147. private async Task DownloadImages(BaseItem item, List<RemoteImageInfo> images, int backdropLimit, CancellationToken cancellationToken)
  148. {
  149. if (!item.LockedFields.Contains(MetadataFields.Images))
  150. {
  151. if (!item.HasImage(ImageType.Primary))
  152. {
  153. var image = images.FirstOrDefault(i => i.Type == ImageType.Primary);
  154. if (image != null)
  155. {
  156. await _providerManager.SaveImage(item, image.Url, TvdbSeriesProvider.Current.TvDbResourcePool, ImageType.Primary, null, cancellationToken)
  157. .ConfigureAwait(false);
  158. }
  159. }
  160. if (ConfigurationManager.Configuration.DownloadSeriesImages.Banner && !item.HasImage(ImageType.Banner))
  161. {
  162. var image = images.FirstOrDefault(i => i.Type == ImageType.Banner);
  163. if (image != null)
  164. {
  165. await _providerManager.SaveImage(item, image.Url, TvdbSeriesProvider.Current.TvDbResourcePool, ImageType.Banner, null, cancellationToken)
  166. .ConfigureAwait(false);
  167. }
  168. }
  169. }
  170. if (ConfigurationManager.Configuration.DownloadSeriesImages.Backdrops && item.BackdropImagePaths.Count < backdropLimit && !item.LockedFields.Contains(MetadataFields.Backdrops))
  171. {
  172. foreach (var backdrop in images.Where(i => i.Type == ImageType.Backdrop &&
  173. (!i.Width.HasValue ||
  174. i.Width.Value >= ConfigurationManager.Configuration.MinSeriesBackdropDownloadWidth)))
  175. {
  176. var url = backdrop.Url;
  177. if (item.ContainsImageWithSourceUrl(url))
  178. {
  179. continue;
  180. }
  181. await _providerManager.SaveImage(item, url, TvdbSeriesProvider.Current.TvDbResourcePool, ImageType.Backdrop, null, cancellationToken).ConfigureAwait(false);
  182. if (item.BackdropImagePaths.Count >= backdropLimit) break;
  183. }
  184. }
  185. }
  186. }
  187. }