BaseConfigurationManager.cs 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. using MediaBrowser.Common.Configuration;
  2. using MediaBrowser.Common.Events;
  3. using MediaBrowser.Model.Configuration;
  4. using MediaBrowser.Model.Logging;
  5. using MediaBrowser.Model.Serialization;
  6. using System;
  7. using System.Threading;
  8. namespace MediaBrowser.Common.Implementations.Configuration
  9. {
  10. /// <summary>
  11. /// Class BaseConfigurationManager
  12. /// </summary>
  13. public abstract class BaseConfigurationManager : IConfigurationManager
  14. {
  15. /// <summary>
  16. /// Gets the type of the configuration.
  17. /// </summary>
  18. /// <value>The type of the configuration.</value>
  19. protected abstract Type ConfigurationType { get; }
  20. /// <summary>
  21. /// Occurs when [configuration updated].
  22. /// </summary>
  23. public event EventHandler<EventArgs> ConfigurationUpdated;
  24. /// <summary>
  25. /// Gets the logger.
  26. /// </summary>
  27. /// <value>The logger.</value>
  28. protected ILogger Logger { get; private set; }
  29. /// <summary>
  30. /// Gets the XML serializer.
  31. /// </summary>
  32. /// <value>The XML serializer.</value>
  33. protected IXmlSerializer XmlSerializer { get; private set; }
  34. /// <summary>
  35. /// Gets or sets the application paths.
  36. /// </summary>
  37. /// <value>The application paths.</value>
  38. public IApplicationPaths CommonApplicationPaths { get; private set; }
  39. /// <summary>
  40. /// The _configuration loaded
  41. /// </summary>
  42. private bool _configurationLoaded;
  43. /// <summary>
  44. /// The _configuration sync lock
  45. /// </summary>
  46. private object _configurationSyncLock = new object();
  47. /// <summary>
  48. /// The _configuration
  49. /// </summary>
  50. private BaseApplicationConfiguration _configuration;
  51. /// <summary>
  52. /// Gets the system configuration
  53. /// </summary>
  54. /// <value>The configuration.</value>
  55. public BaseApplicationConfiguration CommonConfiguration
  56. {
  57. get
  58. {
  59. // Lazy load
  60. LazyInitializer.EnsureInitialized(ref _configuration, ref _configurationLoaded, ref _configurationSyncLock, () => (BaseApplicationConfiguration)ConfigurationHelper.GetXmlConfiguration(ConfigurationType, CommonApplicationPaths.SystemConfigurationFilePath, XmlSerializer));
  61. return _configuration;
  62. }
  63. protected set
  64. {
  65. _configuration = value;
  66. _configurationLoaded = value != null;
  67. }
  68. }
  69. /// <summary>
  70. /// Initializes a new instance of the <see cref="BaseConfigurationManager" /> class.
  71. /// </summary>
  72. /// <param name="applicationPaths">The application paths.</param>
  73. /// <param name="logManager">The log manager.</param>
  74. /// <param name="xmlSerializer">The XML serializer.</param>
  75. protected BaseConfigurationManager(IApplicationPaths applicationPaths, ILogManager logManager, IXmlSerializer xmlSerializer)
  76. {
  77. CommonApplicationPaths = applicationPaths;
  78. XmlSerializer = xmlSerializer;
  79. Logger = logManager.GetLogger(GetType().Name);
  80. }
  81. /// <summary>
  82. /// The _save lock
  83. /// </summary>
  84. private readonly object _configurationSaveLock = new object();
  85. /// <summary>
  86. /// Saves the configuration.
  87. /// </summary>
  88. public void SaveConfiguration()
  89. {
  90. lock (_configurationSaveLock)
  91. {
  92. XmlSerializer.SerializeToFile(CommonConfiguration, CommonApplicationPaths.SystemConfigurationFilePath);
  93. }
  94. OnConfigurationUpdated();
  95. }
  96. /// <summary>
  97. /// Called when [configuration updated].
  98. /// </summary>
  99. protected virtual void OnConfigurationUpdated()
  100. {
  101. EventHelper.QueueEventIfNotNull(ConfigurationUpdated, this, EventArgs.Empty, Logger);
  102. }
  103. /// <summary>
  104. /// Replaces the configuration.
  105. /// </summary>
  106. /// <param name="newConfiguration">The new configuration.</param>
  107. /// <exception cref="System.ArgumentNullException">newConfiguration</exception>
  108. public virtual void ReplaceConfiguration(BaseApplicationConfiguration newConfiguration)
  109. {
  110. if (newConfiguration == null)
  111. {
  112. throw new ArgumentNullException("newConfiguration");
  113. }
  114. CommonConfiguration = newConfiguration;
  115. SaveConfiguration();
  116. }
  117. }
  118. }