-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathLoggerFilterConfigureOptions.cs
More file actions
68 lines (62 loc) · 2.53 KB
/
LoggerFilterConfigureOptions.cs
File metadata and controls
68 lines (62 loc) · 2.53 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/* ===============================================
* 功能描述:AspNetCore.Logging.LoggerFilterConfigureOptions
* 创 建 者:WeiGe
* 创建日期:1/2/2019 10:00:17 PM
* ===============================================*/
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
namespace AspNetCore.FileLog
{
internal class LoggerFilterConfigureOptions : IConfigureOptions<Microsoft.Extensions.Logging.LoggerFilterOptions>
{
public LoggerFilterConfigureOptions(IConfiguration configuration)
{
LoggerSettings.JsonConfiguration=(configuration as ConfigurationRoot).Providers.FirstOrDefault()
as Microsoft.Extensions.Configuration.Json.JsonConfigurationProvider;
}
public void Configure(Microsoft.Extensions.Logging.LoggerFilterOptions options)
{
if (LoggerSettings.JsonConfiguration == null)
{
return;
}
var source = LoggerSettings.JsonConfiguration?.Source;
var file = source?.FileProvider.GetFileInfo(source.Path);
if (file != null && !file.IsDirectory && file.Exists)
{
using (var reader = new System.IO.StreamReader(file.CreateReadStream()))
{
var content = reader.ReadToEnd();
var jToken = JsonConvert.DeserializeObject<JToken>(content);
if (jToken != null)
{
try
{
var rules = jToken.SelectToken(LoggerSettings.RulesKey, false)
.ToObject<List<LoggerFilterRule>>();
foreach (var _rule in rules)
{
options.Rules.Add(_rule);
}
return;
}
catch
{
}
}
}
System.IO.File.WriteAllText(file.PhysicalPath, LoggerSettings.LoggingJsonContent);
}
var rule = LoggerFilterRule.Default;
rule.LogScope = LogScope.All;
options.Rules.Add(rule);
}
}
}