2021-02-01 00:10:16 +01:00
|
|
|
package log
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io"
|
2021-09-27 17:01:40 +02:00
|
|
|
|
|
|
|
"github.com/go-kit/log"
|
2021-02-01 00:10:16 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// StdlibWriter implements io.Writer by invoking the stdlib log.Print. It's
|
|
|
|
// designed to be passed to a Go kit logger as the writer, for cases where
|
|
|
|
// it's necessary to redirect all Go kit log output to the stdlib logger.
|
|
|
|
//
|
|
|
|
// If you have any choice in the matter, you shouldn't use this. Prefer to
|
|
|
|
// redirect the stdlib log to the Go kit logger via NewStdlibAdapter.
|
2021-09-27 17:01:40 +02:00
|
|
|
type StdlibWriter = log.StdlibWriter
|
2021-02-01 00:10:16 +01:00
|
|
|
|
|
|
|
// StdlibAdapter wraps a Logger and allows it to be passed to the stdlib
|
|
|
|
// logger's SetOutput. It will extract date/timestamps, filenames, and
|
|
|
|
// messages, and place them under relevant keys.
|
2021-09-27 17:01:40 +02:00
|
|
|
type StdlibAdapter = log.StdlibAdapter
|
2021-02-01 00:10:16 +01:00
|
|
|
|
|
|
|
// StdlibAdapterOption sets a parameter for the StdlibAdapter.
|
2021-09-27 17:01:40 +02:00
|
|
|
type StdlibAdapterOption = log.StdlibAdapterOption
|
2021-02-01 00:10:16 +01:00
|
|
|
|
|
|
|
// TimestampKey sets the key for the timestamp field. By default, it's "ts".
|
|
|
|
func TimestampKey(key string) StdlibAdapterOption {
|
2021-09-27 17:01:40 +02:00
|
|
|
return log.TimestampKey(key)
|
2021-02-01 00:10:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// FileKey sets the key for the file and line field. By default, it's "caller".
|
|
|
|
func FileKey(key string) StdlibAdapterOption {
|
2021-09-27 17:01:40 +02:00
|
|
|
return log.FileKey(key)
|
2021-02-01 00:10:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// MessageKey sets the key for the actual log message. By default, it's "msg".
|
|
|
|
func MessageKey(key string) StdlibAdapterOption {
|
2021-09-27 17:01:40 +02:00
|
|
|
return log.MessageKey(key)
|
2021-02-01 00:10:16 +01:00
|
|
|
}
|
|
|
|
|
2021-07-07 15:10:33 +02:00
|
|
|
// Prefix configures the adapter to parse a prefix from stdlib log events. If
|
|
|
|
// you provide a non-empty prefix to the stdlib logger, then your should provide
|
|
|
|
// that same prefix to the adapter via this option.
|
|
|
|
//
|
|
|
|
// By default, the prefix isn't included in the msg key. Set joinPrefixToMsg to
|
|
|
|
// true if you want to include the parsed prefix in the msg.
|
|
|
|
func Prefix(prefix string, joinPrefixToMsg bool) StdlibAdapterOption {
|
2021-09-27 17:01:40 +02:00
|
|
|
return log.Prefix(prefix, joinPrefixToMsg)
|
2021-07-07 15:10:33 +02:00
|
|
|
}
|
|
|
|
|
2021-02-01 00:10:16 +01:00
|
|
|
// NewStdlibAdapter returns a new StdlibAdapter wrapper around the passed
|
|
|
|
// logger. It's designed to be passed to log.SetOutput.
|
|
|
|
func NewStdlibAdapter(logger Logger, options ...StdlibAdapterOption) io.Writer {
|
2021-09-27 17:01:40 +02:00
|
|
|
return log.NewStdlibAdapter(logger, options...)
|
2021-02-01 00:10:16 +01:00
|
|
|
}
|