123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- 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;
- /// <inheritdoc />
- #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<RenameEnableGroupingIntoCollections> _logger;
- /// <summary>
- /// Initializes a new instance of the <see cref="RenameEnableGroupingIntoCollections"/> class.
- /// </summary>
- /// <param name="applicationPaths">An instance of <see cref="ServerApplicationPaths"/>.</param>
- /// <param name="loggerFactory">An instance of the <see cref="ILoggerFactory"/> interface.</param>
- public RenameEnableGroupingIntoCollections(ServerApplicationPaths applicationPaths, ILoggerFactory loggerFactory)
- {
- _applicationPaths = applicationPaths;
- _logger = loggerFactory.CreateLogger<RenameEnableGroupingIntoCollections>();
- }
- /// <inheritdoc />
- 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 <EnableGroupingIntoCollections> was successfully renamed to <EnableGroupingMoviesIntoCollections>.");
- xmlDocument.Save(path);
- }
- }
- catch (Exception ex)
- {
- _logger.LogError(ex, "An error occurred while updating the XML file: {Message}", ex.Message);
- }
- }
- }
|