12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- #pragma warning disable CS1591
- using System;
- using System.Threading.Tasks;
- using MediaBrowser.Common.Configuration;
- using MediaBrowser.Controller.Entities;
- using MediaBrowser.Controller.Library;
- using MediaBrowser.Controller.Plugins;
- using MediaBrowser.Controller.Providers;
- using MediaBrowser.Model.Entities;
- using MediaBrowser.XbmcMetadata.Configuration;
- using MediaBrowser.XbmcMetadata.Savers;
- using Microsoft.Extensions.Logging;
- namespace MediaBrowser.XbmcMetadata
- {
- public sealed class EntryPoint : IServerEntryPoint
- {
- private readonly IUserDataManager _userDataManager;
- private readonly ILogger<EntryPoint> _logger;
- private readonly IProviderManager _providerManager;
- private readonly IConfigurationManager _config;
- public EntryPoint(
- IUserDataManager userDataManager,
- ILogger<EntryPoint> logger,
- IProviderManager providerManager,
- IConfigurationManager config)
- {
- _userDataManager = userDataManager;
- _logger = logger;
- _providerManager = providerManager;
- _config = config;
- }
- /// <inheritdoc />
- public Task RunAsync()
- {
- _userDataManager.UserDataSaved += OnUserDataSaved;
- return Task.CompletedTask;
- }
- private void OnUserDataSaved(object sender, UserDataSaveEventArgs e)
- {
- if (e.SaveReason == UserDataSaveReason.PlaybackFinished || e.SaveReason == UserDataSaveReason.TogglePlayed || e.SaveReason == UserDataSaveReason.UpdateUserRating)
- {
- if (!string.IsNullOrWhiteSpace(_config.GetNfoConfiguration().UserId))
- {
- SaveMetadataForItem(e.Item, ItemUpdateType.MetadataDownload);
- }
- }
- }
- /// <inheritdoc />
- public void Dispose()
- {
- _userDataManager.UserDataSaved -= OnUserDataSaved;
- }
- private void SaveMetadataForItem(BaseItem item, ItemUpdateType updateReason)
- {
- if (!item.IsFileProtocol)
- {
- return;
- }
- if (!item.SupportsLocalMetadata)
- {
- return;
- }
- if (!item.IsSaveLocalMetadataEnabled())
- {
- return;
- }
- try
- {
- _providerManager.SaveMetadata(item, updateReason, new[] { BaseNfoSaver.SaverName });
- }
- catch (Exception ex)
- {
- _logger.LogError(ex, "Error saving metadata for {path}", item.Path ?? item.Name);
- }
- }
- }
- }
|