using System;
using System.IO;
using System.Linq;
using System.Text;
using System.Xml.Linq;
using Emby.Server.Implementations;
using Microsoft.Extensions.Logging;
namespace Jellyfin.Server.Migrations.PreStartupRoutines;
/// 
#pragma warning disable CS0618 // Type or member is obsolete
[JellyfinMigration("2025-04-20T04:00:00", nameof(RenameEnableGroupingIntoCollections), "E73B777D-CD5C-4E71-957A-B86B3660B7CF", Stage = Stages.JellyfinMigrationStageTypes.PreInitialisation)]
public class RenameEnableGroupingIntoCollections : IMigrationRoutine
#pragma warning restore CS0618 // Type or member is obsolete
{
    private readonly ServerApplicationPaths _applicationPaths;
    private readonly ILogger _logger;
    /// 
    /// Initializes a new instance of the  class.
    /// 
    /// An instance of .
    /// An instance of the  interface.
    public RenameEnableGroupingIntoCollections(ServerApplicationPaths applicationPaths, ILoggerFactory loggerFactory)
    {
        _applicationPaths = applicationPaths;
        _logger = loggerFactory.CreateLogger();
    }
    /// 
    public void Perform()
    {
        string path = Path.Combine(_applicationPaths.ConfigurationDirectoryPath, "system.xml");
        if (!File.Exists(path))
        {
            _logger.LogWarning("Configuration file not found: {Path}", path);
            return;
        }
        try
        {
            XDocument xmlDocument = XDocument.Load(path);
            var element = xmlDocument.Descendants("EnableGroupingIntoCollections").FirstOrDefault();
            if (element is not null)
            {
                element.Name = "EnableGroupingMoviesIntoCollections";
                _logger.LogInformation("The tag  was successfully renamed to .");
                xmlDocument.Save(path);
            }
        }
        catch (Exception ex)
        {
            _logger.LogError(ex, "An error occurred while updating the XML file: {Message}", ex.Message);
        }
    }
}