From c9f4aa954ce94359a76f4daf62282cc5446e78da Mon Sep 17 00:00:00 2001 From: Rolf Kristensen Date: Thu, 21 Nov 2024 07:47:58 +0100 Subject: [PATCH] UseNLog fallback to only EnvironmentName when loading NLog config (#773) --- .../Extensions/ConfigureExtensions.cs | 66 +++++++++++-------- 1 file changed, 39 insertions(+), 27 deletions(-) diff --git a/src/NLog.Extensions.Hosting/Extensions/ConfigureExtensions.cs b/src/NLog.Extensions.Hosting/Extensions/ConfigureExtensions.cs index 07d3126b..3b51b3dd 100644 --- a/src/NLog.Extensions.Hosting/Extensions/ConfigureExtensions.cs +++ b/src/NLog.Extensions.Hosting/Extensions/ConfigureExtensions.cs @@ -1,4 +1,5 @@ using System; +using System.IO; using System.Reflection; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; @@ -53,45 +54,56 @@ private static NLogLoggerProvider CreateNLogLoggerProvider(IServiceProvider serv { NLogLoggerProvider provider = serviceProvider.CreateNLogLoggerProvider(hostConfiguration, options, null); - var contentRootPath = hostEnvironment?.ContentRootPath; - if (!string.IsNullOrWhiteSpace(contentRootPath)) + string nlogConfigFile = string.Empty; + string contentRootPath = hostEnvironment?.ContentRootPath; + string environmentName = hostEnvironment?.EnvironmentName; + if (!string.IsNullOrWhiteSpace(contentRootPath) || !string.IsNullOrWhiteSpace(environmentName)) { - TryLoadConfigurationFromContentRootPath(provider.LogFactory, contentRootPath, hostEnvironment?.EnvironmentName); + provider.LogFactory.Setup().LoadConfiguration(cfg => + { + if (!IsLoggingConfigurationLoaded(cfg.Configuration)) + { + nlogConfigFile = ResolveEnvironmentNLogConfigFile(contentRootPath, environmentName); + cfg.Configuration = null; + } + }); } + if (!string.IsNullOrEmpty(nlogConfigFile)) + { + provider.LogFactory.Setup().LoadConfigurationFromFile(nlogConfigFile, optional: true); + } + provider.LogFactory.Setup().SetupLogFactory(ext => ext.AddCallSiteHiddenAssembly(typeof(ConfigureExtensions).Assembly)); return provider; } - private static void TryLoadConfigurationFromContentRootPath(LogFactory logFactory, string contentRootPath, string environmentName) + private static string ResolveEnvironmentNLogConfigFile(string basePath, string environmentName) { - logFactory.Setup().LoadConfiguration(config => + if (!string.IsNullOrWhiteSpace(basePath)) { - if (IsLoggingConfigurationLoaded(config.Configuration)) - return; - - if (!string.IsNullOrEmpty(environmentName)) - { - var nlogConfig = LoadXmlLoggingConfigurationFromPath(contentRootPath, $"NLog.{environmentName}.config", config.LogFactory) ?? - LoadXmlLoggingConfigurationFromPath(contentRootPath, $"nlog.{environmentName}.config", config.LogFactory) ?? - LoadXmlLoggingConfigurationFromPath(contentRootPath, "NLog.config", config.LogFactory) ?? - LoadXmlLoggingConfigurationFromPath(contentRootPath, "nlog.config", config.LogFactory); - config.Configuration = nlogConfig; - } - else + if (!string.IsNullOrWhiteSpace(environmentName)) { - var nlogConfig = LoadXmlLoggingConfigurationFromPath(contentRootPath, "NLog.config", config.LogFactory) ?? - LoadXmlLoggingConfigurationFromPath(contentRootPath, "nlog.config", config.LogFactory); - config.Configuration = nlogConfig; + var nlogConfigEnvFilePath = Path.Combine(basePath, $"nlog.{environmentName}.config"); + if (File.Exists(nlogConfigEnvFilePath)) + return Path.GetFullPath(nlogConfigEnvFilePath); + nlogConfigEnvFilePath = Path.Combine(basePath, $"NLog.{environmentName}.config"); + if (File.Exists(nlogConfigEnvFilePath)) + return Path.GetFullPath(nlogConfigEnvFilePath); } - }); - } - private static LoggingConfiguration LoadXmlLoggingConfigurationFromPath(string contentRootPath, string nlogConfigFileName, LogFactory logFactory) - { - var standardPath = System.IO.Path.Combine(contentRootPath, nlogConfigFileName); - return System.IO.File.Exists(standardPath) ? - new XmlLoggingConfiguration(standardPath, logFactory) : null; + var nlogConfigFilePath = Path.Combine(basePath, "nlog.config"); + if (File.Exists(nlogConfigFilePath)) + return Path.GetFullPath(nlogConfigFilePath); + nlogConfigFilePath = Path.Combine(basePath, "NLog.config"); + if (File.Exists(nlogConfigFilePath)) + return Path.GetFullPath(nlogConfigFilePath); + } + + if (!string.IsNullOrWhiteSpace(environmentName)) + return $"nlog.{environmentName}.config"; + + return null; } private static bool IsLoggingConfigurationLoaded(LoggingConfiguration cfg)