SeriesXmlSaver.cs 4.6 KB

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