2019-12-27 11:55:15 -03:00
|
|
|
package logext
|
|
|
|
|
2021-07-23 08:09:29 -03:00
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"io"
|
|
|
|
"strings"
|
2019-12-27 11:55:15 -03:00
|
|
|
|
2021-07-23 08:09:29 -03:00
|
|
|
"github.com/apex/log"
|
|
|
|
"github.com/apex/log/handlers/cli"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Output type of the log output.
|
|
|
|
type Output int
|
|
|
|
|
|
|
|
const (
|
|
|
|
// Info usually is used with stdout.
|
|
|
|
Info Output = iota
|
|
|
|
|
|
|
|
// Error usually is used with stderr.
|
|
|
|
Error
|
|
|
|
)
|
2019-12-27 11:55:15 -03:00
|
|
|
|
2020-05-26 00:48:10 -03:00
|
|
|
// NewWriter creates a new log writer.
|
2021-07-23 08:09:29 -03:00
|
|
|
func NewWriter(fields log.Fields, out Output) io.Writer {
|
2021-12-06 10:07:47 -03:00
|
|
|
return NewConditionalWriter(fields, out, false)
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewConditionalWriter creates a new log writer that only writes when the given condition is met or debug is enabled.
|
|
|
|
func NewConditionalWriter(fields log.Fields, out Output, condition bool) io.Writer {
|
|
|
|
if condition || isDebug() {
|
2021-07-23 08:09:29 -03:00
|
|
|
return logWriter{
|
|
|
|
ctx: newLogger(fields),
|
|
|
|
out: out,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return io.Discard
|
|
|
|
}
|
|
|
|
|
|
|
|
type logWriter struct {
|
|
|
|
ctx *log.Entry
|
|
|
|
out Output
|
2019-12-27 11:55:15 -03:00
|
|
|
}
|
|
|
|
|
2021-07-23 08:09:29 -03:00
|
|
|
func (w logWriter) Write(p []byte) (int, error) {
|
|
|
|
for _, line := range strings.Split(toString(p), "\n") {
|
|
|
|
switch w.out {
|
|
|
|
case Info:
|
|
|
|
w.ctx.Info(line)
|
|
|
|
case Error:
|
|
|
|
w.ctx.Error(line)
|
|
|
|
}
|
|
|
|
}
|
2019-12-27 11:55:15 -03:00
|
|
|
return len(p), nil
|
|
|
|
}
|
2020-05-10 17:03:49 +01:00
|
|
|
|
2021-07-23 08:09:29 -03:00
|
|
|
func newLogger(fields log.Fields) *log.Entry {
|
|
|
|
handler := cli.New(cli.Default.Writer)
|
|
|
|
handler.Padding = cli.Default.Padding + 3
|
|
|
|
logger := log.WithFields(fields)
|
|
|
|
logger.Logger.Handler = handler
|
|
|
|
return logger
|
2020-05-10 17:03:49 +01:00
|
|
|
}
|
|
|
|
|
2021-07-23 08:09:29 -03:00
|
|
|
func isDebug() bool {
|
|
|
|
return logLevel() == log.DebugLevel
|
2020-05-10 17:03:49 +01:00
|
|
|
}
|
|
|
|
|
2021-07-23 08:09:29 -03:00
|
|
|
func logLevel() log.Level {
|
|
|
|
if logger, ok := log.Log.(*log.Logger); ok {
|
|
|
|
return logger.Level
|
|
|
|
}
|
|
|
|
return log.InfoLevel
|
|
|
|
}
|
|
|
|
|
|
|
|
func toString(b []byte) string {
|
|
|
|
return string(bytes.TrimSuffix(b, []byte("\n")))
|
2020-05-10 17:03:49 +01:00
|
|
|
}
|