Add adapters

This commit is contained in:
2023-01-14 23:06:25 -08:00
parent ed50ff00ef
commit be389eb931
14 changed files with 913 additions and 4 deletions

16
adapters/zerolog/go.mod Normal file
View File

@@ -0,0 +1,16 @@
module go.arsenm.dev/logger/adapters/zerolog
go 1.18
require (
github.com/rs/zerolog v1.28.0
go.arsenm.dev/logger v0.0.0-20230104225304-d706171ea6df
)
require (
github.com/gookit/color v1.5.1 // indirect
github.com/mattn/go-colorable v0.1.12 // indirect
github.com/mattn/go-isatty v0.0.14 // indirect
github.com/xo/terminfo v0.0.0-20210125001918-ca9a967f8778 // indirect
golang.org/x/sys v0.0.0-20210927094055-39ccf1dd6fa6 // indirect
)

30
adapters/zerolog/go.sum Normal file
View File

@@ -0,0 +1,30 @@
github.com/coreos/go-systemd/v22 v22.3.3-0.20220203105225-a9a7ef127534/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc=
github.com/davecgh/go-spew v1.1.0 h1:ZDRjVQ15GmhC3fiQ8ni8+OwkZQO4DARzQgrnXU1Liz8=
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
github.com/gookit/color v1.5.1 h1:Vjg2VEcdHpwq+oY63s/ksHrgJYCTo0bwWvmmYWdE9fQ=
github.com/gookit/color v1.5.1/go.mod h1:wZFzea4X8qN6vHOSP2apMb4/+w/orMznEzYsIHPaqKM=
github.com/mattn/go-colorable v0.1.12 h1:jF+Du6AlPIjs2BiUiQlKOX0rt3SujHxPnksPKZbaA40=
github.com/mattn/go-colorable v0.1.12/go.mod h1:u5H1YNBxpqRaxsYJYSkiCWKzEfiAb1Gb520KVy5xxl4=
github.com/mattn/go-isatty v0.0.14 h1:yVuAays6BHfxijgZPzw+3Zlu5yQgKGP2/hcQbHb7S9Y=
github.com/mattn/go-isatty v0.0.14/go.mod h1:7GGIvUiUoEMVVmxf/4nioHXj79iQHKdU27kJ6hsGG94=
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
github.com/rs/xid v1.4.0/go.mod h1:trrq9SKmegXys3aeAKXMUTdJsYXVwGY3RLcfgqegfbg=
github.com/rs/zerolog v1.28.0 h1:MirSo27VyNi7RJYP3078AA1+Cyzd2GB66qy3aUHvsWY=
github.com/rs/zerolog v1.28.0/go.mod h1:NILgTygv/Uej1ra5XxGf82ZFSLk58MFGAUS2o6usyD0=
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
github.com/stretchr/testify v1.7.2 h1:4jaiDzPyXQvSd7D0EjG45355tLlV3VOECpq10pLC+8s=
github.com/stretchr/testify v1.7.2/go.mod h1:R6va5+xMeoiuVRoj+gSkQ7d3FALtqAAGI1FQKckRals=
github.com/xo/terminfo v0.0.0-20210125001918-ca9a967f8778 h1:QldyIu/L63oPpyvQmHgvgickp1Yw510KJOqX7H24mg8=
github.com/xo/terminfo v0.0.0-20210125001918-ca9a967f8778/go.mod h1:2MuV+tbUrU1zIOPMxZ5EncGwgmMJsa+9ucAQZXxsObs=
go.arsenm.dev/logger v0.0.0-20230104225304-d706171ea6df h1:8mBHvEe7BJmpOeKSMA5YLqrGo9dCpePocTeR0C1+/2w=
go.arsenm.dev/logger v0.0.0-20230104225304-d706171ea6df/go.mod h1:RV2qydKDdoyaRkhAq8JEGvojR8eJ6bjq5WnSIlH7gYw=
golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210927094055-39ccf1dd6fa6 h1:foEbQz/B0Oz6YIqu/69kfXPYeFQAuuMYFkjaqXzl5Wo=
golang.org/x/sys v0.0.0-20210927094055-39ccf1dd6fa6/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=

232
adapters/zerolog/zerolog.go Normal file
View File

@@ -0,0 +1,232 @@
package zerolog
import (
"fmt"
"time"
"github.com/rs/zerolog"
"go.arsenm.dev/logger"
)
var _ logger.Logger = &ZerologLogger{}
var _ logger.LogBuilder = &ZerologLogBuilder{}
type ZerologLogger struct {
logger zerolog.Logger
}
func New(z zerolog.Logger) *ZerologLogger {
return &ZerologLogger{z}
}
// NoPanic is a no-op because Zerolog does not provide this functionality
func (l *ZerologLogger) NoPanic() {}
// NoPanic is a no-op because Zerolog does not provide this functionality
func (l *ZerologLogger) NoExit() {}
// SetLevel sets the log level of the logger.
func (l *ZerologLogger) SetLevel(level logger.LogLevel) {
switch level {
case logger.LogLevelDebug:
l.logger = l.logger.Level(zerolog.DebugLevel)
case logger.LogLevelInfo:
l.logger = l.logger.Level(zerolog.InfoLevel)
case logger.LogLevelWarn:
l.logger = l.logger.Level(zerolog.WarnLevel)
case logger.LogLevelError:
l.logger = l.logger.Level(zerolog.ErrorLevel)
case logger.LogLevelFatal:
l.logger = l.logger.Level(zerolog.FatalLevel)
case logger.LogLevelPanic:
l.logger = l.logger.Level(zerolog.PanicLevel)
}
}
func (l *ZerologLogger) Debug(msg string) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Debug(),
msg: msg,
}
}
func (l *ZerologLogger) Debugf(format string, a ...any) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Debug(),
msg: fmt.Sprintf(format, a...),
}
}
func (l *ZerologLogger) Info(msg string) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Info(),
msg: msg,
}
}
func (l *ZerologLogger) Infof(format string, a ...any) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Info(),
msg: fmt.Sprintf(format, a...),
}
}
func (l *ZerologLogger) Warn(msg string) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Warn(),
msg: msg,
}
}
func (l *ZerologLogger) Warnf(format string, a ...any) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Warn(),
msg: fmt.Sprintf(format, a...),
}
}
func (l *ZerologLogger) Error(msg string) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Error(),
msg: msg,
}
}
func (l *ZerologLogger) Errorf(format string, a ...any) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Error(),
msg: fmt.Sprintf(format, a...),
}
}
func (l *ZerologLogger) Fatal(msg string) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Fatal(),
msg: msg,
}
}
func (l *ZerologLogger) Fatalf(format string, a ...any) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Fatal(),
msg: fmt.Sprintf(format, a...),
}
}
func (l *ZerologLogger) Panic(msg string) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Panic(),
msg: msg,
}
}
func (l *ZerologLogger) Panicf(format string, a ...any) logger.LogBuilder {
return &ZerologLogBuilder{
logEvent: l.logger.Panic(),
msg: fmt.Sprintf(format, a...),
}
}
type ZerologLogBuilder struct {
logEvent *zerolog.Event
msg string
}
func (b *ZerologLogBuilder) Int(key string, value int) logger.LogBuilder {
b.logEvent.Int(key, value)
return b
}
func (b *ZerologLogBuilder) Int8(key string, value int8) logger.LogBuilder {
b.logEvent.Int8(key, value)
return b
}
func (b *ZerologLogBuilder) Int16(key string, value int16) logger.LogBuilder {
b.logEvent.Int16(key, value)
return b
}
func (b *ZerologLogBuilder) Int32(key string, value int32) logger.LogBuilder {
b.logEvent.Int32(key, value)
return b
}
func (b *ZerologLogBuilder) Int64(key string, value int64) logger.LogBuilder {
b.logEvent.Int64(key, value)
return b
}
func (b *ZerologLogBuilder) Uint(key string, value uint) logger.LogBuilder {
b.logEvent.Uint(key, value)
return b
}
func (b *ZerologLogBuilder) Uint8(key string, value uint8) logger.LogBuilder {
b.logEvent.Uint8(key, value)
return b
}
func (b *ZerologLogBuilder) Uint16(key string, value uint16) logger.LogBuilder {
b.logEvent.Uint16(key, value)
return b
}
func (b *ZerologLogBuilder) Uint32(key string, value uint32) logger.LogBuilder {
b.logEvent.Uint32(key, value)
return b
}
func (b *ZerologLogBuilder) Uint64(key string, value uint64) logger.LogBuilder {
b.logEvent.Uint64(key, value)
return b
}
func (b *ZerologLogBuilder) Float32(key string, value float32) logger.LogBuilder {
b.logEvent.Float32(key, value)
return b
}
func (b *ZerologLogBuilder) Float64(key string, value float64) logger.LogBuilder {
b.logEvent.Float64(key, value)
return b
}
func (b *ZerologLogBuilder) Stringer(key string, value fmt.Stringer) logger.LogBuilder {
b.logEvent.Str(key, value.String())
return b
}
func (b *ZerologLogBuilder) Bytes(key string, value []byte) logger.LogBuilder {
b.logEvent.Bytes(key, value)
return b
}
func (b *ZerologLogBuilder) Timestamp() logger.LogBuilder {
b.logEvent.Time("timestamp", time.Now())
return b
}
func (b *ZerologLogBuilder) Bool(key string, value bool) logger.LogBuilder {
b.logEvent.Bool(key, value)
return b
}
func (b *ZerologLogBuilder) Str(key string, value string) logger.LogBuilder {
b.logEvent.Str(key, value)
return b
}
func (b *ZerologLogBuilder) Any(key string, value any) logger.LogBuilder {
b.logEvent.Interface(key, value)
return b
}
func (b *ZerologLogBuilder) Err(err error) logger.LogBuilder {
b.logEvent.Err(err)
return b
}
func (b *ZerologLogBuilder) Send() {
b.logEvent.Msg(b.msg)
}