123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 |
- package logger
- import (
- "go.uber.org/zap"
- "go.uber.org/zap/zapcore"
- "os"
- )
- var hookCore []zapcore.Core
- type L struct {
- log *zap.Logger
- }
- func (l *L) Debug(msg string, field ...zap.Field) {
- l.log.Debug(msg, field...)
- }
- func (l *L) Warn(msg string, field ...zap.Field) {
- l.log.Warn(msg, field...)
- }
- func (l *L) Info(msg string, field ...zap.Field) {
- l.log.Info(msg, field...)
- }
- func (l *L) Error(msg string, field ...zap.Field) {
- l.log.Error(msg, field...)
- }
- func (l *L) Fatal(msg string, field ...zap.Field) {
- l.log.Fatal(msg, field...)
- }
- func Err(err error) zap.Field {
- return zap.Error(err)
- }
- func String(key string, val string) zap.Field {
- return zap.String(key, val)
- }
- func Any(key string, value interface{}) zap.Field {
- return zap.Any(key, value)
- }
- func Binary(key string, val []byte) zap.Field {
- return zap.Binary(key, val)
- }
- func Bool(key string, val bool) zap.Field {
- return zap.Bool(key, val)
- }
- func ByteString(key string, val []byte) zap.Field {
- return zap.ByteString(key, val)
- }
- func Float64(key string, val float64) zap.Field {
- return zap.Float64(key, val)
- }
- func Float32(key string, val float32) zap.Field {
- return zap.Float32(key, val)
- }
- func NewEncoderConfig() zapcore.EncoderConfig {
- encoderConfig := zap.NewProductionEncoderConfig()
- encoderConfig.CallerKey = "line"
- encoderConfig.TimeKey = "time"
- encoderConfig.StacktraceKey = ""
- encoderConfig.EncodeTime = zapcore.ISO8601TimeEncoder
- return encoderConfig
- }
- func newHook(core zapcore.Core) {
- hookCore = []zapcore.Core{
- core,
- }
- }
- func consoleHook(path string) zapcore.Core {
- encoderConfig := NewEncoderConfig()
- encoderConfig.EncodeLevel = zapcore.CapitalColorLevelEncoder
- level := zap.LevelEnablerFunc(func(lv zapcore.Level) bool {
- return lv <= zap.FatalLevel
- })
- consoleWriter := zapcore.AddSync(os.Stdout)
- return zapcore.NewCore(zapcore.NewConsoleEncoder(encoderConfig), consoleWriter, level)
- }
- func New(path string) *L {
- newHook(consoleHook(path))
- return &L{log: zap.New(zapcore.NewTee(hookCore...), zap.AddCaller(), zap.AddCallerSkip(2))}
- }
- func Int(key string, val int) zap.Field {
- return Int64(key, int64(val))
- }
- func Int64(key string, val int64) zap.Field {
- return zap.Int64(key, val)
- }
- func Int8(key string, val int8) zap.Field {
- return zap.Int8(key, val)
- }
- func Uint(key string, val uint) zap.Field {
- return Uint64(key, uint64(val))
- }
- func Uint64(key string, val uint64) zap.Field {
- return zap.Uint64(key, val)
- }
- func Uint8(key string, val uint8) zap.Field {
- return zap.Uint8(key, val)
- }
- func SetLevel(level string) zap.AtomicLevel {
- switch level {
- case "debug":
- return zap.NewAtomicLevelAt(zap.DebugLevel)
- case "info":
- return zap.NewAtomicLevelAt(zap.InfoLevel)
- case "warn":
- return zap.NewAtomicLevelAt(zap.WarnLevel)
- case "error":
- return zap.NewAtomicLevelAt(zap.ErrorLevel)
- case "fatal":
- return zap.NewAtomicLevelAt(zap.FatalLevel)
- case "panic":
- return zap.NewAtomicLevelAt(zap.PanicLevel)
- default:
- return zap.NewAtomicLevelAt(zap.DebugLevel)
- }
- }
|