2021-02-17 17:14:47 +08:00
|
|
|
package log
|
|
|
|
|
2021-03-14 15:36:00 +08:00
|
|
|
import (
|
2021-06-03 16:56:55 +08:00
|
|
|
"context"
|
2021-03-14 15:36:00 +08:00
|
|
|
"log"
|
|
|
|
)
|
2021-02-22 17:50:43 +08:00
|
|
|
|
2021-02-17 17:14:47 +08:00
|
|
|
var (
|
|
|
|
// DefaultLogger is default logger.
|
2021-03-14 15:36:00 +08:00
|
|
|
DefaultLogger Logger = NewStdLogger(log.Writer())
|
2021-02-17 17:14:47 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
// Logger is a logger interface.
|
|
|
|
type Logger interface {
|
2021-05-17 16:34:28 +08:00
|
|
|
Log(level Level, keyvals ...interface{}) error
|
2021-02-17 17:14:47 +08:00
|
|
|
}
|
|
|
|
|
2021-06-03 16:56:55 +08:00
|
|
|
type logger struct {
|
2021-05-01 01:15:30 +08:00
|
|
|
logs []Logger
|
|
|
|
prefix []interface{}
|
|
|
|
hasValuer bool
|
2021-06-03 16:56:55 +08:00
|
|
|
ctx context.Context
|
2021-02-17 17:14:47 +08:00
|
|
|
}
|
|
|
|
|
2021-06-03 16:56:55 +08:00
|
|
|
func (c *logger) Log(level Level, keyvals ...interface{}) error {
|
2021-05-17 16:34:28 +08:00
|
|
|
kvs := make([]interface{}, 0, len(c.prefix)+len(keyvals))
|
2021-03-14 15:36:00 +08:00
|
|
|
kvs = append(kvs, c.prefix...)
|
2021-05-01 01:15:30 +08:00
|
|
|
if c.hasValuer {
|
2021-06-03 16:56:55 +08:00
|
|
|
bindValues(c.ctx, kvs)
|
2021-03-14 15:36:00 +08:00
|
|
|
}
|
2021-05-17 16:34:28 +08:00
|
|
|
kvs = append(kvs, keyvals...)
|
2021-05-01 01:15:30 +08:00
|
|
|
for _, l := range c.logs {
|
2021-05-17 16:34:28 +08:00
|
|
|
if err := l.Log(level, kvs...); err != nil {
|
2021-05-01 01:15:30 +08:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
2021-02-17 17:14:47 +08:00
|
|
|
}
|
|
|
|
|
2021-03-14 15:36:00 +08:00
|
|
|
// With with logger fields.
|
2021-05-01 01:15:30 +08:00
|
|
|
func With(l Logger, kv ...interface{}) Logger {
|
2021-06-03 16:56:55 +08:00
|
|
|
if c, ok := l.(*logger); ok {
|
2021-05-01 01:15:30 +08:00
|
|
|
kvs := make([]interface{}, 0, len(c.prefix)+len(kv))
|
|
|
|
kvs = append(kvs, kv...)
|
2021-03-14 15:36:00 +08:00
|
|
|
kvs = append(kvs, c.prefix...)
|
2021-06-03 16:56:55 +08:00
|
|
|
return &logger{
|
2021-05-01 01:15:30 +08:00
|
|
|
logs: c.logs,
|
|
|
|
prefix: kvs,
|
|
|
|
hasValuer: containsValuer(kvs),
|
2021-06-03 16:56:55 +08:00
|
|
|
ctx: c.ctx,
|
2021-03-14 15:36:00 +08:00
|
|
|
}
|
2021-02-17 17:14:47 +08:00
|
|
|
}
|
2021-06-03 16:56:55 +08:00
|
|
|
return &logger{logs: []Logger{l}, prefix: kv, hasValuer: containsValuer(kv)}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithContext returns a shallow copy of l with its context changed
|
|
|
|
// to ctx. The provided ctx must be non-nil.
|
|
|
|
func WithContext(ctx context.Context, l Logger) Logger {
|
|
|
|
if c, ok := l.(*logger); ok {
|
|
|
|
return &logger{
|
|
|
|
logs: c.logs,
|
|
|
|
prefix: c.prefix,
|
|
|
|
hasValuer: c.hasValuer,
|
|
|
|
ctx: ctx,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return &logger{logs: []Logger{l}, ctx: ctx}
|
2021-03-14 15:36:00 +08:00
|
|
|
}
|
|
|
|
|
2021-05-01 01:15:30 +08:00
|
|
|
// MultiLogger wraps multi logger.
|
|
|
|
func MultiLogger(logs ...Logger) Logger {
|
2021-06-03 16:56:55 +08:00
|
|
|
return &logger{logs: logs}
|
2021-02-17 17:14:47 +08:00
|
|
|
}
|