using MediaBrowser.Controller.Configuration; using MediaBrowser.Controller.Entities; using MediaBrowser.Controller.Entities.TV; using MediaBrowser.Controller.Library; using MediaBrowser.Model.Entities; using MediaBrowser.Providers.TV; using System; using System.IO; using System.Security; using System.Text; using System.Threading; namespace MediaBrowser.Providers.Savers { public class SeriesXmlSaver : IMetadataSaver { private readonly IServerConfigurationManager _config; public SeriesXmlSaver(IServerConfigurationManager config) { _config = config; } /// /// Determines whether [is enabled for] [the specified item]. /// /// The item. /// Type of the update. /// true if [is enabled for] [the specified item]; otherwise, false. public bool IsEnabledFor(BaseItem item, ItemUpdateType updateType) { var wasMetadataEdited = (updateType & ItemUpdateType.MetadataEdit) == ItemUpdateType.MetadataEdit; var wasMetadataDownloaded = (updateType & ItemUpdateType.MetadataDownload) == ItemUpdateType.MetadataDownload; // If new metadata has been downloaded and save local is on, OR metadata was manually edited, proceed if ((_config.Configuration.SaveLocalMeta && (wasMetadataEdited || wasMetadataDownloaded)) || wasMetadataEdited) { return item is Series; } return false; } /// /// Saves the specified item. /// /// The item. /// The cancellation token. /// Task. public void Save(BaseItem item, CancellationToken cancellationToken) { var series = (Series)item; var builder = new StringBuilder(); builder.Append(""); var tvdb = item.GetProviderId(MetadataProviders.Tvdb); if (!string.IsNullOrEmpty(tvdb)) { builder.Append("" + SecurityElement.Escape(tvdb) + ""); } if (!string.IsNullOrEmpty(item.Name)) { builder.Append("" + SecurityElement.Escape(item.Name) + ""); } if (series.Status.HasValue) { builder.Append("" + SecurityElement.Escape(series.Status.Value.ToString()) + ""); } if (series.Studios.Count > 0) { builder.Append("" + SecurityElement.Escape(item.Studios[0]) + ""); } if (!string.IsNullOrEmpty(series.AirTime)) { builder.Append("" + SecurityElement.Escape(series.AirTime) + ""); } if (series.AirDays.Count == 7) { builder.Append("" + SecurityElement.Escape("Daily") + ""); } else if (series.AirDays.Count > 0) { builder.Append("" + SecurityElement.Escape(series.AirDays[0].ToString()) + ""); } XmlSaverHelpers.AddCommonNodes(item, builder); builder.Append(""); var xmlFilePath = GetSavePath(item); XmlSaverHelpers.Save(builder, xmlFilePath, new[] { "id", "SeriesName", "Status", "Network", "Airs_Time", "Airs_DayOfWeek" }); // Set last refreshed so that the provider doesn't trigger after the file save SeriesProviderFromXml.Current.SetLastRefreshed(item, DateTime.UtcNow); } /// /// Gets the save path. /// /// The item. /// System.String. public string GetSavePath(BaseItem item) { return Path.Combine(item.Path, "series.xml"); } } }