SeriesXmlSaver.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. using MediaBrowser.Controller.Configuration;
  2. using MediaBrowser.Controller.Entities;
  3. using MediaBrowser.Controller.Entities.TV;
  4. using MediaBrowser.Controller.Library;
  5. using MediaBrowser.Model.Entities;
  6. using System.Collections.Generic;
  7. using System.Globalization;
  8. using System.IO;
  9. using System.Security;
  10. using System.Text;
  11. using System.Threading;
  12. using CommonIO;
  13. using MediaBrowser.Common.IO;
  14. namespace MediaBrowser.LocalMetadata.Savers
  15. {
  16. public class SeriesXmlProvider : IMetadataFileSaver, IConfigurableProvider
  17. {
  18. private readonly IServerConfigurationManager _config;
  19. private readonly ILibraryManager _libraryManager;
  20. private IFileSystem _fileSystem;
  21. public SeriesXmlProvider(IServerConfigurationManager config, ILibraryManager libraryManager, IFileSystem fileSystem)
  22. {
  23. _config = config;
  24. _libraryManager = libraryManager;
  25. _fileSystem = fileSystem;
  26. }
  27. public string Name
  28. {
  29. get
  30. {
  31. return XmlProviderUtils.Name;
  32. }
  33. }
  34. /// <summary>
  35. /// Determines whether [is enabled for] [the specified item].
  36. /// </summary>
  37. /// <param name="item">The item.</param>
  38. /// <param name="updateType">Type of the update.</param>
  39. /// <returns><c>true</c> if [is enabled for] [the specified item]; otherwise, <c>false</c>.</returns>
  40. public bool IsEnabledFor(IHasMetadata item, ItemUpdateType updateType)
  41. {
  42. if (!item.SupportsLocalMetadata)
  43. {
  44. return false;
  45. }
  46. return item is Series && updateType >= ItemUpdateType.MetadataDownload;
  47. }
  48. public bool IsEnabled
  49. {
  50. get { return !_config.Configuration.DisableXmlSavers; }
  51. }
  52. private static readonly CultureInfo UsCulture = new CultureInfo("en-US");
  53. /// <summary>
  54. /// Saves the specified item.
  55. /// </summary>
  56. /// <param name="item">The item.</param>
  57. /// <param name="cancellationToken">The cancellation token.</param>
  58. /// <returns>Task.</returns>
  59. public void Save(IHasMetadata item, CancellationToken cancellationToken)
  60. {
  61. var series = (Series)item;
  62. var builder = new StringBuilder();
  63. builder.Append("<Series>");
  64. var tvdb = item.GetProviderId(MetadataProviders.Tvdb);
  65. if (!string.IsNullOrEmpty(tvdb))
  66. {
  67. builder.Append("<id>" + SecurityElement.Escape(tvdb) + "</id>");
  68. }
  69. if (series.Status.HasValue)
  70. {
  71. builder.Append("<Status>" + SecurityElement.Escape(series.Status.Value.ToString()) + "</Status>");
  72. }
  73. if (series.Studios.Count > 0)
  74. {
  75. builder.Append("<Network>" + SecurityElement.Escape(series.Studios[0]) + "</Network>");
  76. }
  77. if (!string.IsNullOrEmpty(series.AirTime))
  78. {
  79. builder.Append("<Airs_Time>" + SecurityElement.Escape(series.AirTime) + "</Airs_Time>");
  80. }
  81. if (series.AirDays != null)
  82. {
  83. if (series.AirDays.Count == 7)
  84. {
  85. builder.Append("<Airs_DayOfWeek>" + SecurityElement.Escape("Daily") + "</Airs_DayOfWeek>");
  86. }
  87. else if (series.AirDays.Count > 0)
  88. {
  89. builder.Append("<Airs_DayOfWeek>" + SecurityElement.Escape(series.AirDays[0].ToString()) + "</Airs_DayOfWeek>");
  90. }
  91. }
  92. if (series.PremiereDate.HasValue)
  93. {
  94. builder.Append("<FirstAired>" + SecurityElement.Escape(series.PremiereDate.Value.ToLocalTime().ToString("yyyy-MM-dd")) + "</FirstAired>");
  95. }
  96. if (series.AnimeSeriesIndex.HasValue)
  97. {
  98. builder.Append("<AnimeSeriesIndex>" + SecurityElement.Escape(series.AnimeSeriesIndex.Value.ToString(UsCulture)) + "</AnimeSeriesIndex>");
  99. }
  100. XmlSaverHelpers.AddCommonNodes(series, _libraryManager, builder);
  101. builder.Append("</Series>");
  102. var xmlFilePath = GetSavePath(item);
  103. XmlSaverHelpers.Save(builder, xmlFilePath, new List<string>
  104. {
  105. "id",
  106. "Status",
  107. "Network",
  108. "Airs_Time",
  109. "Airs_DayOfWeek",
  110. "FirstAired",
  111. // Don't preserve old series node
  112. "Series",
  113. "SeriesName",
  114. // Deprecated. No longer saving in this field.
  115. "AnimeSeriesIndex"
  116. }, _config, _fileSystem);
  117. }
  118. /// <summary>
  119. /// Gets the save path.
  120. /// </summary>
  121. /// <param name="item">The item.</param>
  122. /// <returns>System.String.</returns>
  123. public string GetSavePath(IHasMetadata item)
  124. {
  125. return Path.Combine(item.Path, "series.xml");
  126. }
  127. }
  128. }