| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 | 
							- using System;
 
- using System.Threading;
 
- using System.Threading.Tasks;
 
- using MediaBrowser.Common.Configuration;
 
- using MediaBrowser.Controller.Library;
 
- using MediaBrowser.Controller.Providers;
 
- using MediaBrowser.Model.Entities;
 
- using MediaBrowser.XbmcMetadata.Configuration;
 
- using MediaBrowser.XbmcMetadata.Savers;
 
- using Microsoft.Extensions.Hosting;
 
- using Microsoft.Extensions.Logging;
 
- namespace MediaBrowser.XbmcMetadata;
 
- /// <summary>
 
- /// <see cref="IHostedService"/> responsible for updating NFO files' user data.
 
- /// </summary>
 
- public sealed class NfoUserDataSaver : IHostedService
 
- {
 
-     private readonly ILogger<NfoUserDataSaver> _logger;
 
-     private readonly IConfigurationManager _config;
 
-     private readonly IUserDataManager _userDataManager;
 
-     private readonly IProviderManager _providerManager;
 
-     /// <summary>
 
-     /// Initializes a new instance of the <see cref="NfoUserDataSaver"/> class.
 
-     /// </summary>
 
-     /// <param name="logger">The <see cref="ILogger"/>.</param>
 
-     /// <param name="config">The <see cref="IConfigurationManager"/>.</param>
 
-     /// <param name="userDataManager">The <see cref="IUserDataManager"/>.</param>
 
-     /// <param name="providerManager">The <see cref="IProviderManager"/>.</param>
 
-     public NfoUserDataSaver(
 
-         ILogger<NfoUserDataSaver> logger,
 
-         IConfigurationManager config,
 
-         IUserDataManager userDataManager,
 
-         IProviderManager providerManager)
 
-     {
 
-         _logger = logger;
 
-         _config = config;
 
-         _userDataManager = userDataManager;
 
-         _providerManager = providerManager;
 
-     }
 
-     /// <inheritdoc />
 
-     public Task StartAsync(CancellationToken cancellationToken)
 
-     {
 
-         _userDataManager.UserDataSaved += OnUserDataSaved;
 
-         return Task.CompletedTask;
 
-     }
 
-     /// <inheritdoc />
 
-     public Task StopAsync(CancellationToken cancellationToken)
 
-     {
 
-         _userDataManager.UserDataSaved -= OnUserDataSaved;
 
-         return Task.CompletedTask;
 
-     }
 
-     private async void OnUserDataSaved(object? sender, UserDataSaveEventArgs e)
 
-     {
 
-         if (e.SaveReason is not (UserDataSaveReason.PlaybackFinished
 
-             or UserDataSaveReason.TogglePlayed or UserDataSaveReason.UpdateUserRating))
 
-         {
 
-             return;
 
-         }
 
-         if (string.IsNullOrWhiteSpace(_config.GetNfoConfiguration().UserId))
 
-         {
 
-             return;
 
-         }
 
-         var item = e.Item;
 
-         if (!item.IsFileProtocol || !item.SupportsLocalMetadata)
 
-         {
 
-             return;
 
-         }
 
-         try
 
-         {
 
-             await _providerManager.SaveMetadataAsync(item, ItemUpdateType.MetadataDownload, [BaseNfoSaver.SaverName])
 
-                 .ConfigureAwait(false);
 
-         }
 
-         catch (Exception ex)
 
-         {
 
-             _logger.LogError(ex, "Error saving metadata for {Path}", item.Path ?? item.Name);
 
-         }
 
-     }
 
- }
 
 
  |