2021-02-17 11:14:47 +02:00
|
|
|
package log
|
|
|
|
|
2021-02-22 11:50:43 +02:00
|
|
|
import "os"
|
|
|
|
|
2021-02-17 11:14:47 +02:00
|
|
|
var (
|
|
|
|
// DefaultLogger is default logger.
|
2021-02-22 11:50:43 +02:00
|
|
|
DefaultLogger Logger = NewStdLogger(os.Stderr)
|
2021-02-17 11:14:47 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// Logger is a logger interface.
|
|
|
|
type Logger interface {
|
|
|
|
Print(pairs ...interface{})
|
|
|
|
}
|
|
|
|
|
|
|
|
type logger struct {
|
|
|
|
log Logger
|
|
|
|
pairs []interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l *logger) Print(pairs ...interface{}) {
|
|
|
|
l.log.Print(append(pairs, l.pairs...)...)
|
|
|
|
}
|
|
|
|
|
|
|
|
// With with logger kv pairs.
|
|
|
|
func With(log Logger, pairs ...interface{}) Logger {
|
|
|
|
if len(pairs) == 0 {
|
|
|
|
return log
|
|
|
|
}
|
|
|
|
return &logger{log: log, pairs: pairs}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 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)
|
|
|
|
}
|