logger.go 3.1 KB

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