FolderXmlSaver.cs 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. using MediaBrowser.Controller.Entities;
  2. using MediaBrowser.Controller.Entities.Movies;
  3. using MediaBrowser.Controller.Entities.TV;
  4. using MediaBrowser.Controller.Library;
  5. using MediaBrowser.Model.Entities;
  6. using System.IO;
  7. using System.Text;
  8. using System.Threading;
  9. namespace MediaBrowser.Providers.Savers
  10. {
  11. public class FolderXmlSaver : IMetadataSaver
  12. {
  13. /// <summary>
  14. /// Supportses the specified item.
  15. /// </summary>
  16. /// <param name="item">The item.</param>
  17. /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
  18. public bool Supports(BaseItem item)
  19. {
  20. if (item.LocationType != LocationType.FileSystem)
  21. {
  22. return false;
  23. }
  24. return item is Folder && !(item is Series) && !(item is BoxSet);
  25. }
  26. /// <summary>
  27. /// Saves the specified item.
  28. /// </summary>
  29. /// <param name="item">The item.</param>
  30. /// <param name="cancellationToken">The cancellation token.</param>
  31. /// <returns>Task.</returns>
  32. public void Save(BaseItem item, CancellationToken cancellationToken)
  33. {
  34. var builder = new StringBuilder();
  35. builder.Append("<Item>");
  36. XmlHelpers.AddCommonNodes(item, builder);
  37. builder.Append("</Item>");
  38. var xmlFilePath = GetSavePath(item);
  39. XmlHelpers.Save(builder, xmlFilePath);
  40. }
  41. /// <summary>
  42. /// Gets the save path.
  43. /// </summary>
  44. /// <param name="item">The item.</param>
  45. /// <returns>System.String.</returns>
  46. public string GetSavePath(BaseItem item)
  47. {
  48. return Path.Combine(item.Path, "folder.xml");
  49. }
  50. }
  51. }