EntryPoint.cs 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. #pragma warning disable CS1591
  2. using System;
  3. using System.Threading.Tasks;
  4. using MediaBrowser.Common.Configuration;
  5. using MediaBrowser.Controller.Entities;
  6. using MediaBrowser.Controller.Library;
  7. using MediaBrowser.Controller.Plugins;
  8. using MediaBrowser.Controller.Providers;
  9. using MediaBrowser.Model.Entities;
  10. using MediaBrowser.XbmcMetadata.Configuration;
  11. using MediaBrowser.XbmcMetadata.Savers;
  12. using Microsoft.Extensions.Logging;
  13. namespace MediaBrowser.XbmcMetadata
  14. {
  15. public sealed class EntryPoint : IServerEntryPoint
  16. {
  17. private readonly IUserDataManager _userDataManager;
  18. private readonly ILogger<EntryPoint> _logger;
  19. private readonly IProviderManager _providerManager;
  20. private readonly IConfigurationManager _config;
  21. public EntryPoint(
  22. IUserDataManager userDataManager,
  23. ILogger<EntryPoint> logger,
  24. IProviderManager providerManager,
  25. IConfigurationManager config)
  26. {
  27. _userDataManager = userDataManager;
  28. _logger = logger;
  29. _providerManager = providerManager;
  30. _config = config;
  31. }
  32. /// <inheritdoc />
  33. public Task RunAsync()
  34. {
  35. _userDataManager.UserDataSaved += OnUserDataSaved;
  36. return Task.CompletedTask;
  37. }
  38. private void OnUserDataSaved(object sender, UserDataSaveEventArgs e)
  39. {
  40. if (e.SaveReason == UserDataSaveReason.PlaybackFinished || e.SaveReason == UserDataSaveReason.TogglePlayed || e.SaveReason == UserDataSaveReason.UpdateUserRating)
  41. {
  42. if (!string.IsNullOrWhiteSpace(_config.GetNfoConfiguration().UserId))
  43. {
  44. SaveMetadataForItem(e.Item, ItemUpdateType.MetadataDownload);
  45. }
  46. }
  47. }
  48. /// <inheritdoc />
  49. public void Dispose()
  50. {
  51. _userDataManager.UserDataSaved -= OnUserDataSaved;
  52. }
  53. private void SaveMetadataForItem(BaseItem item, ItemUpdateType updateReason)
  54. {
  55. if (!item.IsFileProtocol)
  56. {
  57. return;
  58. }
  59. if (!item.SupportsLocalMetadata)
  60. {
  61. return;
  62. }
  63. if (!item.IsSaveLocalMetadataEnabled())
  64. {
  65. return;
  66. }
  67. try
  68. {
  69. _providerManager.SaveMetadata(item, updateReason, new[] { BaseNfoSaver.SaverName });
  70. }
  71. catch (Exception ex)
  72. {
  73. _logger.LogError(ex, "Error saving metadata for {path}", item.Path ?? item.Name);
  74. }
  75. }
  76. }
  77. }