DatabaseLoggingWriter.cs 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. namespace Admin.NET.Core;
  2. /// <summary>
  3. /// 数据库日志写入器
  4. /// </summary>
  5. public class DatabaseLoggingWriter : IDatabaseLoggingWriter
  6. {
  7. private readonly SqlSugarRepository<SysLogOp> _sysLogOpRep; // 操作日志
  8. private readonly SqlSugarRepository<SysLogEx> _sysLogExRep; // 异常日志
  9. public DatabaseLoggingWriter(SqlSugarRepository<SysLogOp> sysLogOpRep,
  10. SqlSugarRepository<SysLogEx> sysLogExRep)
  11. {
  12. _sysLogOpRep = sysLogOpRep;
  13. _sysLogExRep = sysLogExRep;
  14. }
  15. public void Write(LogMessage logMsg, bool flush)
  16. {
  17. if (logMsg.LogLevel == Microsoft.Extensions.Logging.LogLevel.Information)
  18. {
  19. _sysLogOpRep.Insert(new SysLogOp
  20. {
  21. LogName = logMsg.LogName,
  22. LogLevel = logMsg.LogLevel.ToString(),
  23. EventId = logMsg.EventId.Id.ToString(),
  24. Message = logMsg.Message,
  25. Exception = logMsg.Exception?.ToString(),
  26. State = logMsg.State?.ToString(),
  27. LogDateTime = logMsg.LogDateTime,
  28. ThreadId = logMsg.ThreadId,
  29. TraceId = logMsg.TraceId,
  30. UseUtcTimestamp = logMsg.UseUtcTimestamp,
  31. });
  32. }
  33. else
  34. {
  35. _sysLogExRep.Insert(new SysLogEx
  36. {
  37. LogName = logMsg.LogName,
  38. LogLevel = logMsg.LogLevel.ToString(),
  39. EventId = logMsg.EventId.Id.ToString(),
  40. Message = logMsg.Message,
  41. Exception = logMsg.Exception?.ToString(),
  42. State = logMsg.State?.ToString(),
  43. LogDateTime = logMsg.LogDateTime,
  44. ThreadId = logMsg.ThreadId,
  45. TraceId = logMsg.TraceId,
  46. UseUtcTimestamp = logMsg.UseUtcTimestamp,
  47. });
  48. }
  49. }
  50. }