zhaolei
2020-11-20 921de2254ff5712a44ed8575ee8efe34252f6603
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#if !NET45
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Logging;
#endif
using System;
 
namespace Prow.Logging
{
    /// <summary>
    /// 后台服务管理日志操作类
    /// </summary>
#if !NET45
    public class LoggerProvider : ILoggerProvider
#else
    public class LoggerProvider : IDisposable
#endif
    {
        /// <summary>
        /// 获得/设置 日志回掉方法
        /// </summary>
        protected Action<string>? LogCallback { get; set; }
 
        /// <summary>
        /// 获得/设置 日志过滤器
        /// </summary>
        protected Func<string, LogLevel, bool>? Filter { get; set; }
 
#if !NET45
        /// <summary>
        /// 获得/设置  IConfiguration 实例
        /// </summary>
        protected IConfiguration? Configuration { get; set; }
        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="logCallback"></param>
        /// <param name="filter"></param>
        /// <param name="config"></param>
        public LoggerProvider(Action<string>? logCallback, Func<string, LogLevel, bool>? filter = null, IConfiguration? config = null)
        {
            Configuration = config;
            LogCallback = logCallback;
            Filter = filter;
        }
#else
        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="logCallback"></param>
        /// <param name="filter"></param>
        public LoggerProvider(Action<string>? logCallback, Func<string, LogLevel, bool>? filter = null)
        {
            LogCallback = logCallback;
            Filter = filter;
        }
#endif
 
        /// <summary>
        /// 创建 ILogger 实例方法
        /// </summary>
        /// <param name="categoryName"></param>
        /// <returns></returns>
#if !NET45
        public virtual ILogger CreateLogger(string categoryName) => new Logger(categoryName, LogCallback, Filter, null, Configuration);
#else
        public virtual ILogger CreateLogger(string categoryName) => new Logger(categoryName, LogCallback, Filter, null);
#endif
 
        /// <summary>
        /// 创建 ILogger 实例方法
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <returns></returns>
        public virtual ILogger CreateLogger<T>() => CreateLogger(typeof(T).Name);
 
        /// <summary>
        /// Dispose
        /// </summary>
        /// <param name="disposing"></param>
        protected virtual void Dispose(bool disposing)
        {
            if (disposing)
            {
 
            }
        }
 
        // This code added to correctly implement the disposable pattern.
        /// <summary>
        /// Dispose 方法
        /// </summary>
        public void Dispose()
        {
            // Do not change this code. Put cleanup code in Dispose(bool disposing) above.
            Dispose(true);
            GC.SuppressFinalize(this);
        }
    }
}