Lidarr/src/NzbDrone.Core/Instrumentation/ReconfigureLogging.cs

80 lines
2.5 KiB
C#
Raw Normal View History

2017-09-04 02:20:56 +00:00
using System.Collections.Generic;
2013-07-24 15:08:31 +00:00
using System.Linq;
using NLog;
using NLog.Config;
using NzbDrone.Core.Configuration;
using NzbDrone.Core.Configuration.Events;
using NzbDrone.Core.Messaging.Events;
2013-07-24 15:08:31 +00:00
namespace NzbDrone.Core.Instrumentation
{
public class ReconfigureLogging : IHandleAsync<ConfigFileSavedEvent>
2013-07-24 15:08:31 +00:00
{
private readonly IConfigFileProvider _configFileProvider;
public ReconfigureLogging(IConfigFileProvider configFileProvider)
2013-07-24 15:08:31 +00:00
{
_configFileProvider = configFileProvider;
}
public void Reconfigure()
{
var minimumLogLevel = LogLevel.FromString(_configFileProvider.LogLevel);
2013-07-24 15:08:31 +00:00
var rules = LogManager.Configuration.LoggingRules;
//Console
SetMinimumLogLevel(rules, "consoleLogger", minimumLogLevel);
//Log Files
SetMinimumLogLevel(rules, "appFileInfo", minimumLogLevel <= LogLevel.Info ? LogLevel.Info : LogLevel.Off);
SetMinimumLogLevel(rules, "appFileDebug", minimumLogLevel <= LogLevel.Debug ? LogLevel.Debug : LogLevel.Off);
SetMinimumLogLevel(rules, "appFileTrace", minimumLogLevel <= LogLevel.Trace ? LogLevel.Trace : LogLevel.Off);
2013-08-31 02:32:30 +00:00
LogManager.ReconfigExistingLoggers();
}
private void SetMinimumLogLevel(IList<LoggingRule> rules, string target, LogLevel minimumLogLevel)
{
foreach (var rule in rules.Where(v => v.Targets.Any(t => t.Name == target)))
{
SetMinimumLogLevel(rule, minimumLogLevel);
}
}
private void SetMinimumLogLevel(LoggingRule rule, LogLevel minimumLogLevel)
{
foreach (var logLevel in GetLogLevels())
{
if (logLevel < minimumLogLevel)
{
rule.DisableLoggingForLevel(logLevel);
}
else
{
rule.EnableLoggingForLevel(logLevel);
}
}
}
private List<LogLevel> GetLogLevels()
{
return new List<LogLevel>
{
LogLevel.Trace,
LogLevel.Debug,
LogLevel.Info,
LogLevel.Warn,
LogLevel.Error,
LogLevel.Fatal
};
2013-07-24 15:08:31 +00:00
}
public void HandleAsync(ConfigFileSavedEvent message)
{
Reconfigure();
}
}
}