2020-11-27 14:00:45 +01:00
|
|
|
package logger
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"sync"
|
|
|
|
|
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
defaultLogger Logger
|
|
|
|
mu sync.RWMutex
|
|
|
|
)
|
|
|
|
|
|
|
|
type log struct{}
|
|
|
|
|
|
|
|
func init() {
|
2021-11-18 20:21:30 +01:00
|
|
|
defaultLogger = &logger{fl: logrus.New()}
|
2020-11-27 14:00:45 +01:00
|
|
|
}
|
|
|
|
|
2021-11-28 09:33:32 +01:00
|
|
|
var C = From
|
|
|
|
|
2020-11-27 14:00:45 +01:00
|
|
|
func SetDefault(logger Logger) {
|
|
|
|
mu.Lock()
|
|
|
|
defer mu.Unlock()
|
|
|
|
defaultLogger = logger
|
|
|
|
}
|
|
|
|
|
|
|
|
func Set(ctx context.Context, logger Logger) context.Context {
|
|
|
|
return context.WithValue(ctx, log{}, logger)
|
|
|
|
}
|
|
|
|
|
|
|
|
func From(ctx context.Context) Logger {
|
|
|
|
log, ok := ctx.Value(log{}).(Logger)
|
|
|
|
if ok {
|
2024-10-17 17:15:05 +02:00
|
|
|
return log.WithContext(ctx)
|
2020-11-27 14:00:45 +01:00
|
|
|
}
|
|
|
|
if defaultLogger != nil {
|
|
|
|
return defaultLogger
|
|
|
|
}
|
|
|
|
logr := New()
|
|
|
|
mu.Lock()
|
|
|
|
defer mu.Unlock()
|
|
|
|
defaultLogger = logr
|
2024-10-17 17:15:05 +02:00
|
|
|
return defaultLogger.WithContext(ctx)
|
2020-11-27 14:00:45 +01:00
|
|
|
}
|