You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
67 lines
1.4 KiB
67 lines
1.4 KiB
2 years ago
|
package log
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"log"
|
||
|
)
|
||
|
|
||
|
// DefaultLogger is default logger.
|
||
|
var DefaultLogger = NewStdLogger(log.Writer())
|
||
|
|
||
|
// Logger is a logger interface.
|
||
|
type Logger interface {
|
||
|
Log(level Level, keyvals ...interface{}) error
|
||
|
}
|
||
|
|
||
|
type logger struct {
|
||
|
logger Logger
|
||
|
prefix []interface{}
|
||
|
hasValuer bool
|
||
|
ctx context.Context
|
||
|
}
|
||
|
|
||
|
func (c *logger) Log(level Level, keyvals ...interface{}) error {
|
||
|
kvs := make([]interface{}, 0, len(c.prefix)+len(keyvals))
|
||
|
kvs = append(kvs, c.prefix...)
|
||
|
if c.hasValuer {
|
||
|
bindValues(c.ctx, kvs)
|
||
|
}
|
||
|
kvs = append(kvs, keyvals...)
|
||
|
if err := c.logger.Log(level, kvs...); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
// With with logger fields.
|
||
|
func With(l Logger, kv ...interface{}) Logger {
|
||
|
c, ok := l.(*logger)
|
||
|
if !ok {
|
||
|
return &logger{logger: l, prefix: kv, hasValuer: containsValuer(kv), ctx: context.Background()}
|
||
|
}
|
||
|
kvs := make([]interface{}, 0, len(c.prefix)+len(kv))
|
||
|
kvs = append(kvs, c.prefix...)
|
||
|
kvs = append(kvs, kv...)
|
||
|
return &logger{
|
||
|
logger: c.logger,
|
||
|
prefix: kvs,
|
||
|
hasValuer: containsValuer(kvs),
|
||
|
ctx: c.ctx,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// 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 {
|
||
|
c, ok := l.(*logger)
|
||
|
if !ok {
|
||
|
return &logger{logger: l, ctx: ctx}
|
||
|
}
|
||
|
return &logger{
|
||
|
logger: c.logger,
|
||
|
prefix: c.prefix,
|
||
|
hasValuer: c.hasValuer,
|
||
|
ctx: ctx,
|
||
|
}
|
||
|
}
|