| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 | using System;using System.Globalization;using System.IO;using Emby.Server.Implementations.AppBase;using Jellyfin.Data.Events;using MediaBrowser.Common.Configuration;using MediaBrowser.Controller;using MediaBrowser.Controller.Configuration;using MediaBrowser.Model.Configuration;using MediaBrowser.Model.Serialization;using Microsoft.Extensions.Logging;namespace Emby.Server.Implementations.Configuration{    /// <summary>    /// Class ServerConfigurationManager.    /// </summary>    public class ServerConfigurationManager : BaseConfigurationManager, IServerConfigurationManager    {        /// <summary>        /// Initializes a new instance of the <see cref="ServerConfigurationManager" /> class.        /// </summary>        /// <param name="applicationPaths">The application paths.</param>        /// <param name="loggerFactory">The logger factory.</param>        /// <param name="xmlSerializer">The XML serializer.</param>        public ServerConfigurationManager(            IApplicationPaths applicationPaths,            ILoggerFactory loggerFactory,            IXmlSerializer xmlSerializer)            : base(applicationPaths, loggerFactory, xmlSerializer)        {            UpdateMetadataPath();        }        /// <summary>        /// Configuration updating event.        /// </summary>        public event EventHandler<GenericEventArgs<ServerConfiguration>>? ConfigurationUpdating;        /// <summary>        /// Gets the type of the configuration.        /// </summary>        /// <value>The type of the configuration.</value>        protected override Type ConfigurationType => typeof(ServerConfiguration);        /// <summary>        /// Gets the application paths.        /// </summary>        /// <value>The application paths.</value>        public IServerApplicationPaths ApplicationPaths => (IServerApplicationPaths)CommonApplicationPaths;        /// <summary>        /// Gets the configuration.        /// </summary>        /// <value>The configuration.</value>        public ServerConfiguration Configuration => (ServerConfiguration)CommonConfiguration;        /// <summary>        /// Called when [configuration updated].        /// </summary>        protected override void OnConfigurationUpdated()        {            UpdateMetadataPath();            base.OnConfigurationUpdated();        }        /// <summary>        /// Updates the metadata path.        /// </summary>        /// <exception cref="UnauthorizedAccessException">If the directory does not exist, and the caller does not have the required permission to create it.</exception>        /// <exception cref="NotSupportedException">If there is a custom path transcoding path specified, but it is invalid.</exception>        /// <exception cref="IOException">If the directory does not exist, and it also could not be created.</exception>        private void UpdateMetadataPath()        {            ((ServerApplicationPaths)ApplicationPaths).InternalMetadataPath = string.IsNullOrWhiteSpace(Configuration.MetadataPath)                ? ApplicationPaths.DefaultInternalMetadataPath                : Configuration.MetadataPath;            Directory.CreateDirectory(ApplicationPaths.InternalMetadataPath);        }        /// <summary>        /// Replaces the configuration.        /// </summary>        /// <param name="newConfiguration">The new configuration.</param>        /// <exception cref="DirectoryNotFoundException">If the configuration path doesn't exist.</exception>        public override void ReplaceConfiguration(BaseApplicationConfiguration newConfiguration)        {            var newConfig = (ServerConfiguration)newConfiguration;            ValidateMetadataPath(newConfig);            ConfigurationUpdating?.Invoke(this, new GenericEventArgs<ServerConfiguration>(newConfig));            base.ReplaceConfiguration(newConfiguration);        }        /// <summary>        /// Validates the metadata path.        /// </summary>        /// <param name="newConfig">The new configuration.</param>        /// <exception cref="DirectoryNotFoundException">The new config path doesn't exist.</exception>        private void ValidateMetadataPath(ServerConfiguration newConfig)        {            var newPath = newConfig.MetadataPath;            if (!string.IsNullOrWhiteSpace(newPath)                && !string.Equals(Configuration.MetadataPath, newPath, StringComparison.Ordinal))            {                if (!Directory.Exists(newPath))                {                    throw new DirectoryNotFoundException(                        string.Format(                            CultureInfo.InvariantCulture,                            "{0} does not exist.",                            newPath));                }                EnsureWriteAccess(newPath);            }        }    }}
 |