FanArtSeasonProvider.cs 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. using MediaBrowser.Common.Extensions;
  2. using MediaBrowser.Controller.Configuration;
  3. using MediaBrowser.Controller.Entities;
  4. using MediaBrowser.Controller.Entities.TV;
  5. using MediaBrowser.Controller.Providers;
  6. using MediaBrowser.Model.Entities;
  7. using MediaBrowser.Model.Logging;
  8. using System;
  9. using System.IO;
  10. using System.Threading;
  11. using System.Threading.Tasks;
  12. using System.Xml;
  13. namespace MediaBrowser.Providers.TV
  14. {
  15. /// <summary>
  16. /// Class FanArtSeasonProvider
  17. /// </summary>
  18. class FanArtSeasonProvider : FanartBaseProvider
  19. {
  20. /// <summary>
  21. /// The _provider manager
  22. /// </summary>
  23. private readonly IProviderManager _providerManager;
  24. /// <summary>
  25. /// Initializes a new instance of the <see cref="FanArtSeasonProvider"/> class.
  26. /// </summary>
  27. /// <param name="logManager">The log manager.</param>
  28. /// <param name="configurationManager">The configuration manager.</param>
  29. /// <param name="providerManager">The provider manager.</param>
  30. public FanArtSeasonProvider(ILogManager logManager, IServerConfigurationManager configurationManager, IProviderManager providerManager)
  31. : base(logManager, configurationManager)
  32. {
  33. _providerManager = providerManager;
  34. }
  35. /// <summary>
  36. /// Supportses the specified item.
  37. /// </summary>
  38. /// <param name="item">The item.</param>
  39. /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
  40. public override bool Supports(BaseItem item)
  41. {
  42. return item is Season;
  43. }
  44. /// <summary>
  45. /// Needses the refresh internal.
  46. /// </summary>
  47. /// <param name="item">The item.</param>
  48. /// <param name="providerInfo">The provider info.</param>
  49. /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
  50. protected override bool NeedsRefreshInternal(BaseItem item, BaseProviderInfo providerInfo)
  51. {
  52. if (GetComparisonData(item) != providerInfo.Data)
  53. {
  54. return true;
  55. }
  56. return base.NeedsRefreshInternal(item, providerInfo);
  57. }
  58. /// <summary>
  59. /// Gets the comparison data.
  60. /// </summary>
  61. /// <param name="item">The item.</param>
  62. /// <returns>Guid.</returns>
  63. private Guid GetComparisonData(BaseItem item)
  64. {
  65. var season = (Season)item;
  66. var seriesId = season.Series != null ? season.Series.GetProviderId(MetadataProviders.Tvdb) : null;
  67. if (!string.IsNullOrEmpty(seriesId))
  68. {
  69. // Process images
  70. var imagesXmlPath = Path.Combine(FanArtTvProvider.GetSeriesDataPath(ConfigurationManager.ApplicationPaths, seriesId), "fanart.xml");
  71. var imagesFileInfo = new FileInfo(imagesXmlPath);
  72. return GetComparisonData(imagesFileInfo);
  73. }
  74. return Guid.Empty;
  75. }
  76. /// <summary>
  77. /// Gets the comparison data.
  78. /// </summary>
  79. /// <param name="imagesFileInfo">The images file info.</param>
  80. /// <returns>Guid.</returns>
  81. private Guid GetComparisonData(FileInfo imagesFileInfo)
  82. {
  83. var date = imagesFileInfo.Exists ? imagesFileInfo.LastWriteTimeUtc : DateTime.MinValue;
  84. var key = date.Ticks + imagesFileInfo.FullName;
  85. return key.GetMD5();
  86. }
  87. /// <summary>
  88. /// Fetches metadata and returns true or false indicating if any work that requires persistence was done
  89. /// </summary>
  90. /// <param name="item">The item.</param>
  91. /// <param name="force">if set to <c>true</c> [force].</param>
  92. /// <param name="cancellationToken">The cancellation token.</param>
  93. /// <returns>Task{System.Boolean}.</returns>
  94. public override async Task<bool> FetchAsync(BaseItem item, bool force, CancellationToken cancellationToken)
  95. {
  96. cancellationToken.ThrowIfCancellationRequested();
  97. var season = (Season)item;
  98. var seriesId = season.Series != null ? season.Series.GetProviderId(MetadataProviders.Tvdb) : null;
  99. if (!string.IsNullOrEmpty(seriesId))
  100. {
  101. // Process images
  102. var imagesXmlPath = Path.Combine(FanArtTvProvider.GetSeriesDataPath(ConfigurationManager.ApplicationPaths, seriesId), "fanart.xml");
  103. var imagesFileInfo = new FileInfo(imagesXmlPath);
  104. if (imagesFileInfo.Exists)
  105. {
  106. if (!season.HasImage(ImageType.Thumb))
  107. {
  108. var xmlDoc = new XmlDocument();
  109. xmlDoc.Load(imagesXmlPath);
  110. await FetchImages(season, xmlDoc, cancellationToken).ConfigureAwait(false);
  111. }
  112. }
  113. BaseProviderInfo data;
  114. if (!item.ProviderData.TryGetValue(Id, out data))
  115. {
  116. data = new BaseProviderInfo();
  117. item.ProviderData[Id] = data;
  118. }
  119. data.Data = GetComparisonData(imagesFileInfo);
  120. SetLastRefreshed(item, DateTime.UtcNow);
  121. return true;
  122. }
  123. return false;
  124. }
  125. /// <summary>
  126. /// Fetches the images.
  127. /// </summary>
  128. /// <param name="season">The season.</param>
  129. /// <param name="doc">The doc.</param>
  130. /// <param name="cancellationToken">The cancellation token.</param>
  131. /// <returns>Task.</returns>
  132. private async Task FetchImages(Season season, XmlDocument doc, CancellationToken cancellationToken)
  133. {
  134. var seasonNumber = season.IndexNumber ?? -1;
  135. if (seasonNumber == -1)
  136. {
  137. return;
  138. }
  139. var language = ConfigurationManager.Configuration.PreferredMetadataLanguage.ToLower();
  140. if (ConfigurationManager.Configuration.DownloadSeasonImages.Thumb && !season.HasImage(ImageType.Thumb))
  141. {
  142. var node = doc.SelectSingleNode("//fanart/series/seasonthumbs/seasonthumb[@lang = \"" + language + "\"][@season = \"" + seasonNumber + "\"]/@url") ??
  143. doc.SelectSingleNode("//fanart/series/seasonthumbs/seasonthumb[@season = \"" + seasonNumber + "\"]/@url");
  144. var path = node != null ? node.Value : null;
  145. if (!string.IsNullOrEmpty(path))
  146. {
  147. season.SetImage(ImageType.Thumb, await _providerManager.DownloadAndSaveImage(season, path, ThumbFile, ConfigurationManager.Configuration.SaveLocalMeta, FanArtResourcePool, cancellationToken).ConfigureAwait(false));
  148. }
  149. }
  150. }
  151. /// <summary>
  152. /// Gets a value indicating whether [requires internet].
  153. /// </summary>
  154. /// <value><c>true</c> if [requires internet]; otherwise, <c>false</c>.</value>
  155. public override bool RequiresInternet
  156. {
  157. get
  158. {
  159. return true;
  160. }
  161. }
  162. /// <summary>
  163. /// Gets a value indicating whether [refresh on version change].
  164. /// </summary>
  165. /// <value><c>true</c> if [refresh on version change]; otherwise, <c>false</c>.</value>
  166. protected override bool RefreshOnVersionChange
  167. {
  168. get
  169. {
  170. return true;
  171. }
  172. }
  173. /// <summary>
  174. /// Gets the provider version.
  175. /// </summary>
  176. /// <value>The provider version.</value>
  177. protected override string ProviderVersion
  178. {
  179. get
  180. {
  181. return "3";
  182. }
  183. }
  184. }
  185. }