2022-01-18 14:17:06 -04:00
|
|
|
package utils
|
|
|
|
|
|
|
|
import (
|
2022-06-01 16:03:26 -04:00
|
|
|
"fmt"
|
|
|
|
|
2022-01-18 14:17:06 -04:00
|
|
|
"go.uber.org/zap"
|
|
|
|
"go.uber.org/zap/zapcore"
|
|
|
|
)
|
|
|
|
|
|
|
|
var log *zap.Logger = nil
|
|
|
|
var atom = zap.NewAtomicLevel()
|
|
|
|
|
2022-04-25 23:31:26 +04:00
|
|
|
// SetLogLevel sets a custom log level
|
2022-01-18 14:17:06 -04:00
|
|
|
func SetLogLevel(level string) error {
|
|
|
|
lvl := zapcore.InfoLevel // zero value
|
|
|
|
err := lvl.Set(level)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
atom.SetLevel(lvl)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-04-25 23:31:26 +04:00
|
|
|
// Logger creates a zap.Logger with some reasonable defaults
|
2022-05-27 09:25:06 -04:00
|
|
|
func Logger() *zap.Logger {
|
2022-01-18 14:17:06 -04:00
|
|
|
if log == nil {
|
2022-06-01 16:03:26 -04:00
|
|
|
InitLogger("console")
|
2022-01-18 14:17:06 -04:00
|
|
|
}
|
2022-05-27 09:25:06 -04:00
|
|
|
return log
|
2022-01-18 14:17:06 -04:00
|
|
|
}
|
2022-06-01 16:03:26 -04:00
|
|
|
|
2022-07-25 11:28:17 -04:00
|
|
|
// InitLogger initializes a global logger using an specific encoding
|
2022-06-01 16:03:26 -04:00
|
|
|
func InitLogger(encoding string) {
|
|
|
|
cfg := zap.Config{
|
|
|
|
Encoding: encoding,
|
|
|
|
Level: atom,
|
|
|
|
OutputPaths: []string{"stderr"},
|
|
|
|
ErrorOutputPaths: []string{"stderr"},
|
|
|
|
EncoderConfig: zapcore.EncoderConfig{
|
|
|
|
MessageKey: "message",
|
|
|
|
LevelKey: "level",
|
|
|
|
EncodeLevel: zapcore.CapitalLevelEncoder,
|
|
|
|
TimeKey: "time",
|
|
|
|
EncodeTime: zapcore.ISO8601TimeEncoder,
|
|
|
|
NameKey: "caller",
|
|
|
|
EncodeCaller: zapcore.ShortCallerEncoder,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
logger, err := cfg.Build()
|
|
|
|
if err != nil {
|
|
|
|
panic(fmt.Errorf("could not create logger: %s", err.Error()))
|
|
|
|
}
|
|
|
|
|
|
|
|
log = logger.Named("gowaku")
|
|
|
|
}
|