| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- package logger
- import (
- "fmt"
- "io"
- "log"
- "os"
- "path/filepath"
- "runtime"
- "sync"
- "time"
- )
- // Settings stores config for logger
- type Settings struct {
- Path string `yaml:"path"`
- Name string `yaml:"name"`
- Ext string `yaml:"ext"`
- TimeFormat string `yaml:"time-format"`
- }
- var (
- logFile *os.File
- defaultPrefix = ""
- defaultCallerDepth = 2
- logger *log.Logger
- mu sync.Mutex
- logPrefix = ""
- levelFlags = []string{"DEBUG", "INFO", "WARN", "ERROR", "FATAL"}
- )
- type logLevel int
- // log levels
- const (
- DEBUG logLevel = iota
- INFO
- WARNING
- ERROR
- FATAL
- )
- const flags = log.LstdFlags
- func init() {
- logger = log.New(os.Stdout, defaultPrefix, flags)
- }
- // Setup initializes logger
- func Setup(settings *Settings) {
- var err error
- dir := settings.Path
- fileName := fmt.Sprintf("%s-%s.%s",
- settings.Name,
- time.Now().Format(settings.TimeFormat),
- settings.Ext)
- logFile, err := mustOpen(fileName, dir)
- if err != nil {
- log.Fatalf("logging.Setup err: %s", err)
- }
- mw := io.MultiWriter(os.Stdout, logFile)
- logger = log.New(mw, defaultPrefix, flags)
- }
- func setPrefix(level logLevel) {
- _, file, line, ok := runtime.Caller(defaultCallerDepth)
- if ok {
- logPrefix = fmt.Sprintf("[%s][%s:%d] ", levelFlags[level], filepath.Base(file), line)
- } else {
- logPrefix = fmt.Sprintf("[%s] ", levelFlags[level])
- }
- logger.SetPrefix(logPrefix)
- }
- // Debug prints debug log
- func Debug(v ...any) {
- mu.Lock()
- defer mu.Unlock()
- setPrefix(DEBUG)
- logger.Println(v...)
- }
- // Info prints normal log
- func Info(v ...any) {
- mu.Lock()
- defer mu.Unlock()
- setPrefix(INFO)
- logger.Println(v...)
- }
- func InfoC(v ...any) {
- mu.Lock()
- defer mu.Unlock()
- setPrefix(INFO)
- logger.Println(v...)
- }
- // Warn prints warning log
- func Warn(v ...any) {
- mu.Lock()
- defer mu.Unlock()
- setPrefix(WARNING)
- logger.Println(v...)
- }
- // Error prints error log
- func Error(v ...any) {
- mu.Lock()
- defer mu.Unlock()
- setPrefix(ERROR)
- logger.Println(v...)
- }
- // Fatal prints error log then stop the program
- func Fatal(v ...any) {
- mu.Lock()
- defer mu.Unlock()
- setPrefix(FATAL)
- logger.Fatalln(v...)
- }
|