2021-02-17 11:14:47 +02:00
|
|
|
package log
|
|
|
|
|
2021-03-14 09:36:00 +02:00
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
)
|
2021-02-22 11:50:43 +02:00
|
|
|
|
2021-02-17 11:14:47 +02:00
|
|
|
var (
|
|
|
|
// DefaultLogger is default logger.
|
2021-03-14 09:36:00 +02:00
|
|
|
DefaultLogger Logger = NewStdLogger(log.Writer())
|
2021-02-17 11:14:47 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// Logger is a logger interface.
|
|
|
|
type Logger interface {
|
|
|
|
Print(pairs ...interface{})
|
|
|
|
}
|
|
|
|
|
2021-03-14 09:36:00 +02:00
|
|
|
type context struct {
|
|
|
|
logs []Logger
|
|
|
|
prefix []interface{}
|
2021-02-17 11:14:47 +02:00
|
|
|
}
|
|
|
|
|
2021-03-14 09:36:00 +02:00
|
|
|
func (c *context) Print(a ...interface{}) {
|
|
|
|
kvs := make([]interface{}, 0, len(c.prefix)+len(a))
|
|
|
|
kvs = append(kvs, c.prefix...)
|
|
|
|
kvs = append(kvs, a...)
|
|
|
|
for _, log := range c.logs {
|
|
|
|
log.Print(kvs...)
|
|
|
|
}
|
2021-02-17 11:14:47 +02:00
|
|
|
}
|
|
|
|
|
2021-03-14 09:36:00 +02:00
|
|
|
// With with logger fields.
|
|
|
|
func With(l Logger, a ...interface{}) Logger {
|
|
|
|
if c, ok := l.(*context); ok {
|
|
|
|
kvs := make([]interface{}, 0, len(c.prefix)+len(a))
|
|
|
|
kvs = append(kvs, a...)
|
|
|
|
kvs = append(kvs, c.prefix...)
|
|
|
|
return &context{
|
|
|
|
logs: c.logs,
|
|
|
|
prefix: kvs,
|
|
|
|
}
|
2021-02-17 11:14:47 +02:00
|
|
|
}
|
2021-03-14 09:36:00 +02:00
|
|
|
return &context{logs: []Logger{l}, prefix: a}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Wrap wraps multi logger.
|
|
|
|
func Wrap(logs ...Logger) Logger {
|
|
|
|
return &context{logs: logs}
|
2021-02-17 11:14:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Debug returns a debug logger.
|
|
|
|
func Debug(log Logger) Logger {
|
|
|
|
return With(log, LevelKey, LevelDebug)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Info returns a info logger.
|
|
|
|
func Info(log Logger) Logger {
|
|
|
|
return With(log, LevelKey, LevelInfo)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Warn return a warn logger.
|
|
|
|
func Warn(log Logger) Logger {
|
|
|
|
return With(log, LevelKey, LevelWarn)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Error returns a error logger.
|
|
|
|
func Error(log Logger) Logger {
|
|
|
|
return With(log, LevelKey, LevelError)
|
|
|
|
}
|