FolderXmlSaver.cs 3.0 KB

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