logger.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. package logger
  2. import (
  3. "fmt"
  4. "os"
  5. "path/filepath"
  6. "runtime"
  7. "sync"
  8. "github.com/rs/zerolog"
  9. lumberjack "gopkg.in/natefinch/lumberjack.v2"
  10. )
  11. const (
  12. dateFormat = "2006-01-02T15:04:05.000" // YYYY-MM-DDTHH:MM:SS.ZZZ
  13. )
  14. var (
  15. logger zerolog.Logger
  16. consoleLogger zerolog.Logger
  17. )
  18. // GetLogger get the configured logger instance
  19. func GetLogger() *zerolog.Logger {
  20. return &logger
  21. }
  22. // InitLogger initialize loggers
  23. func InitLogger(logFilePath string, logMaxSize, logMaxBackups, logMaxAge int, logCompress bool, level zerolog.Level) {
  24. zerolog.TimeFieldFormat = dateFormat
  25. if isLogFilePathValid(logFilePath) {
  26. logger = zerolog.New(&lumberjack.Logger{
  27. Filename: logFilePath,
  28. MaxSize: logMaxSize,
  29. MaxBackups: logMaxBackups,
  30. MaxAge: logMaxAge,
  31. Compress: logCompress,
  32. })
  33. EnableConsoleLogger(level)
  34. } else {
  35. logger = zerolog.New(logSyncWrapper{
  36. output: os.Stdout,
  37. lock: new(sync.Mutex)})
  38. consoleLogger = zerolog.Nop()
  39. }
  40. logger.Level(level)
  41. }
  42. // DisableLogger disable the main logger.
  43. // ConsoleLogger will not be affected
  44. func DisableLogger() {
  45. logger = zerolog.Nop()
  46. }
  47. // EnableConsoleLogger enables the console logger
  48. func EnableConsoleLogger(level zerolog.Level) {
  49. consoleOutput := zerolog.ConsoleWriter{
  50. Out: os.Stdout,
  51. TimeFormat: dateFormat,
  52. NoColor: runtime.GOOS == "windows",
  53. }
  54. consoleLogger = zerolog.New(consoleOutput).With().Timestamp().Logger().Level(level)
  55. }
  56. // Debug logs at debug level for the specified sender
  57. func Debug(prefix, requestID string, format string, v ...interface{}) {
  58. logger.Debug().
  59. Timestamp().
  60. Str("sender", prefix).
  61. Str("request_id", requestID).
  62. Msg(fmt.Sprintf(format, v...))
  63. }
  64. // Info logs at info level for the specified sender
  65. func Info(prefix, requestID string, format string, v ...interface{}) {
  66. logger.Info().
  67. Timestamp().
  68. Str("sender", prefix).
  69. Str("request_id", requestID).
  70. Msg(fmt.Sprintf(format, v...))
  71. }
  72. // Warn logs at warn level for the specified sender
  73. func Warn(prefix, requestID string, format string, v ...interface{}) {
  74. logger.Warn().
  75. Timestamp().
  76. Str("sender", prefix).
  77. Str("request_id", requestID).
  78. Msg(fmt.Sprintf(format, v...))
  79. }
  80. // Error logs at error level for the specified sender
  81. func Error(prefix, requestID string, format string, v ...interface{}) {
  82. logger.Error().
  83. Timestamp().
  84. Str("sender", prefix).
  85. Str("request_id", requestID).
  86. Msg(fmt.Sprintf(format, v...))
  87. }
  88. // DebugToConsole logs at debug level to stdout
  89. func DebugToConsole(format string, v ...interface{}) {
  90. consoleLogger.Debug().Msg(fmt.Sprintf(format, v...))
  91. }
  92. // InfoToConsole logs at info level to stdout
  93. func InfoToConsole(format string, v ...interface{}) {
  94. consoleLogger.Info().Msg(fmt.Sprintf(format, v...))
  95. }
  96. // WarnToConsole logs at info level to stdout
  97. func WarnToConsole(format string, v ...interface{}) {
  98. consoleLogger.Warn().Msg(fmt.Sprintf(format, v...))
  99. }
  100. // ErrorToConsole logs at error level to stdout
  101. func ErrorToConsole(format string, v ...interface{}) {
  102. consoleLogger.Error().Msg(fmt.Sprintf(format, v...))
  103. }
  104. func isLogFilePathValid(logFilePath string) bool {
  105. cleanInput := filepath.Clean(logFilePath)
  106. if cleanInput == "." || cleanInput == ".." {
  107. return false
  108. }
  109. return true
  110. }