1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- 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 class EntryPoint : IServerEntryPoint
- {
- private readonly IUserDataManager _userDataManager;
- private readonly ILogger _logger;
- private readonly IProviderManager _providerManager;
- private readonly IConfigurationManager _config;
- public EntryPoint(
- IUserDataManager userDataManager,
- ILogger 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);
- }
- }
- }
- }
|