using System;
using System.Threading;
using System.Threading.Tasks;
using MediaBrowser.Controller.Library;
using MediaBrowser.Controller.Persistence;
using Microsoft.Extensions.Logging;
namespace Emby.Server.Implementations.Library.Validators;
/// 
/// Class MusicGenresValidator.
/// 
public class MusicGenresValidator
{
    /// 
    /// The library manager.
    /// 
    private readonly ILibraryManager _libraryManager;
    /// 
    /// The logger.
    /// 
    private readonly ILogger _logger;
    private readonly IItemRepository _itemRepo;
    /// 
    /// Initializes a new instance of the  class.
    /// 
    /// The library manager.
    /// The logger.
    /// The item repository.
    public MusicGenresValidator(ILibraryManager libraryManager, ILogger logger, IItemRepository itemRepo)
    {
        _libraryManager = libraryManager;
        _logger = logger;
        _itemRepo = itemRepo;
    }
    /// 
    /// Runs the specified progress.
    /// 
    /// The progress.
    /// The cancellation token.
    /// Task.
    public async Task Run(IProgress progress, CancellationToken cancellationToken)
    {
        var names = _itemRepo.GetMusicGenreNames();
        var numComplete = 0;
        var count = names.Count;
        foreach (var name in names)
        {
            try
            {
                var item = _libraryManager.GetMusicGenre(name);
                await item.RefreshMetadata(cancellationToken).ConfigureAwait(false);
            }
            catch (OperationCanceledException)
            {
                // Don't clutter the log
                throw;
            }
            catch (Exception ex)
            {
                _logger.LogError(ex, "Error refreshing {GenreName}", name);
            }
            numComplete++;
            double percent = numComplete;
            percent /= count;
            percent *= 100;
            progress.Report(percent);
        }
        progress.Report(100);
    }
}