using System;
using System.Globalization;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
using Jellyfin.Data.Enums;
using MediaBrowser.Controller.Entities;
using MediaBrowser.Controller.Entities.Audio;
using MediaBrowser.Controller.Library;
using MediaBrowser.Controller.Persistence;
using Microsoft.Extensions.Logging;
namespace Emby.Server.Implementations.Library.Validators;
/// 
/// Class ArtistsValidator.
/// 
public class ArtistsValidator
{
    /// 
    /// 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 ArtistsValidator(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.GetAllArtistNames();
        var numComplete = 0;
        var count = names.Count;
        foreach (var name in names)
        {
            try
            {
                var item = _libraryManager.GetArtist(name);
                await item.RefreshMetadata(cancellationToken).ConfigureAwait(false);
            }
            catch (OperationCanceledException)
            {
                // Don't clutter the log
                throw;
            }
            catch (Exception ex)
            {
                _logger.LogError(ex, "Error refreshing {ArtistName}", name);
            }
            numComplete++;
            double percent = numComplete;
            percent /= count;
            percent *= 100;
            progress.Report(percent);
        }
        var deadEntities = _libraryManager.GetItemList(new InternalItemsQuery
        {
            IncludeItemTypes = [BaseItemKind.MusicArtist],
            IsDeadArtist = true,
            IsLocked = false
        }).Cast().ToList();
        foreach (var item in deadEntities)
        {
            if (!item.IsAccessedByName)
            {
                continue;
            }
            _logger.LogInformation("Deleting dead {ItemType} {ItemId} {ItemName}", item.GetType().Name, item.Id.ToString("N", CultureInfo.InvariantCulture), item.Name);
            _libraryManager.DeleteItem(
                item,
                new DeleteOptions
                {
                    DeleteFileLocation = false
                },
                false);
        }
        progress.Report(100);
    }
}