mirror of
https://gitee.com/ThingsGateway/ThingsGateway.git
synced 2025-10-26 05:20:16 +08:00
134 lines
3.5 KiB
C#
134 lines
3.5 KiB
C#
// ------------------------------------------------------------------------
|
||
// 版权信息
|
||
// 版权归百小僧及百签科技(广东)有限公司所有。
|
||
// 所有权利保留。
|
||
// 官方网站:https://baiqian.com
|
||
//
|
||
// 许可证信息
|
||
// 项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。
|
||
// 许可证的完整文本可以在源代码树根目录中的 LICENSE-APACHE 和 LICENSE-MIT 文件中找到。
|
||
// ------------------------------------------------------------------------
|
||
|
||
using Microsoft.Extensions.Logging;
|
||
|
||
using ThingsGateway.Templates.Extensions;
|
||
|
||
namespace ThingsGateway.Logging;
|
||
|
||
/// <summary>
|
||
/// 构建字符串日志部分类
|
||
/// </summary>
|
||
public sealed partial class StringLoggingPart
|
||
{
|
||
/// <summary>
|
||
/// 设置消息
|
||
/// </summary>
|
||
/// <param name="message"></param>
|
||
public StringLoggingPart SetMessage(string message)
|
||
{
|
||
// 支持读取配置渲染
|
||
if (message != null) Message = message.Render();
|
||
return this;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 设置日志级别
|
||
/// </summary>
|
||
/// <param name="level"></param>
|
||
public StringLoggingPart SetLevel(LogLevel level)
|
||
{
|
||
Level = level;
|
||
return this;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 设置消息格式化参数
|
||
/// </summary>
|
||
/// <param name="args"></param>
|
||
public StringLoggingPart SetArgs(params object[] args)
|
||
{
|
||
if (args?.Length > 0) Args = args;
|
||
return this;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 设置事件 Id
|
||
/// </summary>
|
||
/// <param name="eventId"></param>
|
||
public StringLoggingPart SetEventId(EventId eventId)
|
||
{
|
||
EventId = eventId;
|
||
return this;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 设置日志分类
|
||
/// </summary>
|
||
/// <typeparam name="TClass"></typeparam>
|
||
public StringLoggingPart SetCategory<TClass>()
|
||
{
|
||
CategoryType = typeof(TClass);
|
||
return this;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 设置异常对象
|
||
/// </summary>
|
||
public StringLoggingPart SetException(Exception exception)
|
||
{
|
||
if (exception != null) Exception = exception;
|
||
return this;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 设置日志服务作用域
|
||
/// </summary>
|
||
/// <param name="serviceProvider"></param>
|
||
/// <returns></returns>
|
||
public StringLoggingPart SetLoggerScoped(IServiceProvider serviceProvider)
|
||
{
|
||
if (serviceProvider != null) LoggerScoped = serviceProvider;
|
||
return this;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 配置日志上下文
|
||
/// </summary>
|
||
/// <param name="properties">建议使用 NonBlockingDictionary 类型</param>
|
||
/// <returns></returns>
|
||
public StringLoggingPart ScopeContext(IDictionary<string, object> properties)
|
||
{
|
||
if (properties == null) return this;
|
||
LogContext = new LogContext { Properties = properties };
|
||
|
||
return this;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 配置日志上下文
|
||
/// </summary>
|
||
/// <param name="configure"></param>
|
||
/// <returns></returns>
|
||
public StringLoggingPart ScopeContext(Action<LogContext> configure)
|
||
{
|
||
var logContext = new LogContext();
|
||
configure?.Invoke(logContext);
|
||
|
||
LogContext = logContext;
|
||
|
||
return this;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 配置日志上下文
|
||
/// </summary>
|
||
/// <param name="context"></param>
|
||
/// <returns></returns>
|
||
public StringLoggingPart ScopeContext(LogContext context)
|
||
{
|
||
if (context == null) return this;
|
||
LogContext = context;
|
||
|
||
return this;
|
||
}
|
||
} |