FolderXmlSaver.cs 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. using System.Collections.Generic;
  2. using System.IO;
  3. using System.Text;
  4. using System.Threading;
  5. using MediaBrowser.Controller.Entities;
  6. using MediaBrowser.Controller.Entities.Audio;
  7. using MediaBrowser.Controller.Entities.Movies;
  8. using MediaBrowser.Controller.Entities.TV;
  9. using MediaBrowser.Controller.Library;
  10. namespace MediaBrowser.LocalMetadata.Savers
  11. {
  12. public class FolderXmlSaver : IMetadataFileSaver
  13. {
  14. public string Name
  15. {
  16. get
  17. {
  18. return "Media Browser Xml";
  19. }
  20. }
  21. /// <summary>
  22. /// Determines whether [is enabled for] [the specified item].
  23. /// </summary>
  24. /// <param name="item">The item.</param>
  25. /// <param name="updateType">Type of the update.</param>
  26. /// <returns><c>true</c> if [is enabled for] [the specified item]; otherwise, <c>false</c>.</returns>
  27. public bool IsEnabledFor(IHasMetadata item, ItemUpdateType updateType)
  28. {
  29. if (!item.SupportsLocalMetadata)
  30. {
  31. return false;
  32. }
  33. if (item is Folder)
  34. {
  35. if (!(item is Series) && !(item is BoxSet) && !(item is MusicArtist) && !(item is MusicAlbum) &&
  36. !(item is Season) &&
  37. !(item is GameSystem))
  38. {
  39. return updateType >= ItemUpdateType.MetadataDownload;
  40. }
  41. }
  42. return false;
  43. }
  44. /// <summary>
  45. /// Saves the specified item.
  46. /// </summary>
  47. /// <param name="item">The item.</param>
  48. /// <param name="cancellationToken">The cancellation token.</param>
  49. /// <returns>Task.</returns>
  50. public void Save(IHasMetadata item, CancellationToken cancellationToken)
  51. {
  52. var builder = new StringBuilder();
  53. builder.Append("<Item>");
  54. XmlSaverHelpers.AddCommonNodes((Folder)item, builder);
  55. builder.Append("</Item>");
  56. var xmlFilePath = GetSavePath(item);
  57. XmlSaverHelpers.Save(builder, xmlFilePath, new List<string> { });
  58. }
  59. /// <summary>
  60. /// Gets the save path.
  61. /// </summary>
  62. /// <param name="item">The item.</param>
  63. /// <returns>System.String.</returns>
  64. public string GetSavePath(IHasMetadata item)
  65. {
  66. return Path.Combine(item.Path, "folder.xml");
  67. }
  68. }
  69. }