EntryPoint.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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. _ = SaveMetadataForItemAsync(e.Item, ItemUpdateType.MetadataDownload);
  45. }
  46. }
  47. }
  48. /// <inheritdoc />
  49. public void Dispose()
  50. {
  51. _userDataManager.UserDataSaved -= OnUserDataSaved;
  52. }
  53. private async Task SaveMetadataForItemAsync(BaseItem item, ItemUpdateType updateReason)
  54. {
  55. if (!item.IsFileProtocol || !item.SupportsLocalMetadata)
  56. {
  57. return;
  58. }
  59. try
  60. {
  61. await _providerManager.SaveMetadataAsync(item, updateReason, new[] { BaseNfoSaver.SaverName }).ConfigureAwait(false);
  62. }
  63. catch (Exception ex)
  64. {
  65. _logger.LogError(ex, "Error saving metadata for {Path}", item.Path ?? item.Name);
  66. }
  67. }
  68. }
  69. }