logger.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package logger
  2. import (
  3. "fmt"
  4. "io"
  5. "log"
  6. "os"
  7. "path/filepath"
  8. "runtime"
  9. "sync"
  10. "time"
  11. )
  12. // Settings stores config for logger
  13. type Settings struct {
  14. Path string `yaml:"path"`
  15. Name string `yaml:"name"`
  16. Ext string `yaml:"ext"`
  17. TimeFormat string `yaml:"time-format"`
  18. }
  19. var (
  20. logFile *os.File
  21. defaultPrefix = ""
  22. defaultCallerDepth = 2
  23. logger *log.Logger
  24. mu sync.Mutex
  25. logPrefix = ""
  26. levelFlags = []string{"DEBUG", "INFO", "WARN", "ERROR", "FATAL"}
  27. )
  28. type logLevel int
  29. // log levels
  30. const (
  31. DEBUG logLevel = iota
  32. INFO
  33. WARNING
  34. ERROR
  35. FATAL
  36. )
  37. const flags = log.LstdFlags
  38. func init() {
  39. logger = log.New(os.Stdout, defaultPrefix, flags)
  40. }
  41. // Setup initializes logger
  42. func Setup(settings *Settings) {
  43. var err error
  44. dir := settings.Path
  45. fileName := fmt.Sprintf("%s-%s.%s",
  46. settings.Name,
  47. time.Now().Format(settings.TimeFormat),
  48. settings.Ext)
  49. logFile, err := mustOpen(fileName, dir)
  50. if err != nil {
  51. log.Fatalf("logging.Setup err: %s", err)
  52. }
  53. mw := io.MultiWriter(os.Stdout, logFile)
  54. logger = log.New(mw, defaultPrefix, flags)
  55. }
  56. func setPrefix(level logLevel) {
  57. _, file, line, ok := runtime.Caller(defaultCallerDepth)
  58. if ok {
  59. logPrefix = fmt.Sprintf("[%s][%s:%d] ", levelFlags[level], filepath.Base(file), line)
  60. } else {
  61. logPrefix = fmt.Sprintf("[%s] ", levelFlags[level])
  62. }
  63. logger.SetPrefix(logPrefix)
  64. }
  65. // Debug prints debug log
  66. func Debug(v ...any) {
  67. mu.Lock()
  68. defer mu.Unlock()
  69. setPrefix(DEBUG)
  70. logger.Println(v...)
  71. }
  72. // Info prints normal log
  73. func Info(v ...any) {
  74. mu.Lock()
  75. defer mu.Unlock()
  76. setPrefix(INFO)
  77. logger.Println(v...)
  78. }
  79. // Warn prints warning log
  80. func Warn(v ...any) {
  81. mu.Lock()
  82. defer mu.Unlock()
  83. setPrefix(WARNING)
  84. logger.Println(v...)
  85. }
  86. // Error prints error log
  87. func Error(v ...any) {
  88. mu.Lock()
  89. defer mu.Unlock()
  90. setPrefix(ERROR)
  91. logger.Println(v...)
  92. }
  93. // Fatal prints error log then stop the program
  94. func Fatal(v ...any) {
  95. mu.Lock()
  96. defer mu.Unlock()
  97. setPrefix(FATAL)
  98. logger.Fatalln(v...)
  99. }