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.
kratos/log/log.go

57 lines
1.1 KiB

4 years ago
package log
import (
"log"
)
4 years ago
var (
// DefaultLogger is default logger.
DefaultLogger Logger = NewStdLogger(log.Writer())
4 years ago
)
// Logger is a logger interface.
type Logger interface {
Log(level Level, keyvals ...interface{}) error
4 years ago
}
type context struct {
logs []Logger
prefix []interface{}
hasValuer bool
4 years ago
}
func (c *context) Log(level Level, keyvals ...interface{}) error {
kvs := make([]interface{}, 0, len(c.prefix)+len(keyvals))
kvs = append(kvs, c.prefix...)
if c.hasValuer {
bindValues(kvs)
}
kvs = append(kvs, keyvals...)
for _, l := range c.logs {
if err := l.Log(level, kvs...); err != nil {
return err
}
}
return nil
4 years ago
}
// With with logger fields.
func With(l Logger, kv ...interface{}) Logger {
if c, ok := l.(*context); ok {
kvs := make([]interface{}, 0, len(c.prefix)+len(kv))
kvs = append(kvs, kv...)
kvs = append(kvs, c.prefix...)
return &context{
logs: c.logs,
prefix: kvs,
hasValuer: containsValuer(kvs),
}
4 years ago
}
return &context{logs: []Logger{l}, prefix: kv, hasValuer: containsValuer(kv)}
}
// MultiLogger wraps multi logger.
func MultiLogger(logs ...Logger) Logger {
return &context{logs: logs}
4 years ago
}