using Microsoft.Extensions.Logging;
using WIDESEAWCS_Core.LogHelper;
namespace WIDESEAWCS_Tasks;
///
/// Quartz 作业日志帮助类 - 统一封装 ILogger 和 QuartzLogger 的双通道日志记录
///
///
/// 所有 Quartz Job 中需要同时写入 ILogger(Serilog)和 QuartzLogger(文件日志)的场景,
/// 统一调用此帮助类的方法,避免重复编写两行日志代码。
///
public static class QuartzLogHelper
{
///
/// 记录错误日志(带异常对象)
///
/// ILogger 实例
/// 异常对象
/// ILogger 的结构化日志模板(支持占位符)
/// QuartzLogger 的日志消息
/// 设备编码
/// ILogger 结构化日志的参数
public static void LogError(ILogger logger, Exception ex, string loggerMessage, string quartzMessage, string deviceCode, params object[] args)
{
logger.LogError(ex, loggerMessage, args);
QuartzLogger.Error(quartzMessage, deviceCode, ex);
}
///
/// 记录错误日志(不带异常对象)
///
/// ILogger 实例
/// ILogger 的结构化日志模板(支持占位符)
/// QuartzLogger 的日志消息
/// 设备编码
/// ILogger 结构化日志的参数
public static void LogError(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args)
{
logger.LogError(loggerMessage, args);
QuartzLogger.Error(quartzMessage, deviceCode);
}
///
/// 记录信息日志
///
/// ILogger 实例
/// ILogger 的结构化日志模板(支持占位符)
/// QuartzLogger 的日志消息
/// 设备编码
/// ILogger 结构化日志的参数
public static void LogInfo(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args)
{
logger.LogInformation(loggerMessage, args);
QuartzLogger.Info(quartzMessage, deviceCode);
}
///
/// 记录警告日志
///
/// ILogger 实例
/// ILogger 的结构化日志模板(支持占位符)
/// QuartzLogger 的日志消息
/// 设备编码
/// ILogger 结构化日志的参数
public static void LogWarn(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args)
{
logger.LogWarning(loggerMessage, args);
QuartzLogger.Warn(quartzMessage, deviceCode);
}
///
/// 记录调试日志
///
/// ILogger 实例
/// ILogger 的结构化日志模板(支持占位符)
/// QuartzLogger 的日志消息
/// 设备编码
/// ILogger 结构化日志的参数
public static void LogDebug(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args)
{
logger.LogDebug(loggerMessage, args);
QuartzLogger.Debug(quartzMessage, deviceCode);
}
}