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

15
adapters/logrus/go.mod Normal file
View File

@@ -0,0 +1,15 @@
module go.arsenm.dev/logger/adapters/logrus
go 1.19
require (
github.com/sirupsen/logrus v1.9.0
go.arsenm.dev/logger v0.0.0-20230104225304-d706171ea6df
)
require (
github.com/gookit/color v1.5.1 // 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-20220715151400-c0bba94af5f8 // indirect
)

27
adapters/logrus/go.sum Normal file
View File

@@ -0,0 +1,27 @@
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
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-isatty v0.0.14 h1:yVuAays6BHfxijgZPzw+3Zlu5yQgKGP2/hcQbHb7S9Y=
github.com/mattn/go-isatty v0.0.14/go.mod h1:7GGIvUiUoEMVVmxf/4nioHXj79iQHKdU27kJ6hsGG94=
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/sirupsen/logrus v1.9.0 h1:trlNQbNUG3OdDrDil03MCb1H2o9nJ1x4/5LYw7byDE0=
github.com/sirupsen/logrus v1.9.0/go.mod h1:naHLuLoDiP4jHNo9R0sCBMtWGeIprob74mVsIT4qYEQ=
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
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-20220715151400-c0bba94af5f8 h1:0A+M6Uqn+Eje4kHMK80dtF3JCXC4ykBgQG4Fe06QRhQ=
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/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.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=

244
adapters/logrus/logrus.go Normal file
View File

@@ -0,0 +1,244 @@
package logrus
import (
"fmt"
"time"
"github.com/sirupsen/logrus"
"go.arsenm.dev/logger"
)
var _ logger.Logger = &LogrusLogger{}
var _ logger.LogBuilder = &LogrusLogBuilder{}
type LogrusLogger struct {
logger *logrus.Logger
}
func New(l *logrus.Logger) *LogrusLogger {
return &LogrusLogger{l}
}
// NoPanic is a no-op because logrus does not provide this functionality
func (ll *LogrusLogger) NoPanic() {}
// NoExit prevents the logger from exiting on fatal events
func (ll *LogrusLogger) NoExit() {
ll.logger.ExitFunc = func(int) {}
}
// SetLevel sets the log level of the logger
func (ll *LogrusLogger) SetLevel(logger.LogLevel) {}
// Debug creates a new debug event with the given message
func (ll *LogrusLogger) Debug(msg string) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.DebugLevel,
msg: msg,
}
}
// Debugf creates a new debug event with the formatted message
func (ll *LogrusLogger) Debugf(format string, v ...any) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.DebugLevel,
msg: fmt.Sprintf(format, v...),
}
}
// Info creates a new info event with the given message
func (ll *LogrusLogger) Info(msg string) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.InfoLevel,
msg: msg,
}
}
// Infof creates a new info event with the formatted message
func (ll *LogrusLogger) Infof(format string, v ...any) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.InfoLevel,
msg: fmt.Sprintf(format, v...),
}
}
// Warn creates a new warn event with the given message
func (ll *LogrusLogger) Warn(msg string) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.WarnLevel,
msg: msg,
}
}
// Warnf creates a new warn event with the formatted message
func (ll *LogrusLogger) Warnf(format string, v ...any) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.WarnLevel,
msg: fmt.Sprintf(format, v...),
}
}
// Error creates a new error event with the given message
func (ll *LogrusLogger) Error(msg string) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.ErrorLevel,
msg: msg,
}
}
// Errorf creates a new error event with the formatted message
func (ll *LogrusLogger) Errorf(format string, v ...any) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.ErrorLevel,
msg: fmt.Sprintf(format, v...),
}
}
// Fatal creates a new fatal event with the given message
func (ll *LogrusLogger) Fatal(msg string) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.FatalLevel,
msg: msg,
}
}
// Fatalf creates a new fatal event with the formatted message
func (ll *LogrusLogger) Fatalf(format string, v ...any) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.FatalLevel,
msg: fmt.Sprintf(format, v...),
}
}
// Panic creates a new panic event with the given message
func (ll *LogrusLogger) Panic(msg string) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.PanicLevel,
msg: msg,
}
}
// Panicf creates a new panic event with the formatted message
func (ll *LogrusLogger) Panicf(format string, v ...any) logger.LogBuilder {
return &LogrusLogBuilder{
log: logrus.NewEntry(ll.logger),
lvl: logrus.PanicLevel,
msg: fmt.Sprintf(format, v...),
}
}
type LogrusLogBuilder struct {
log *logrus.Entry
lvl logrus.Level
msg string
}
func (lb *LogrusLogBuilder) Int(name string, value int) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Int8(name string, value int8) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Int16(name string, value int16) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Int32(name string, value int32) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Int64(name string, value int64) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Uint(name string, value uint) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Uint8(name string, value uint8) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Uint16(name string, value uint16) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Uint32(name string, value uint32) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Uint64(name string, value uint64) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Float32(name string, value float32) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Float64(name string, value float64) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Stringer(name string, value fmt.Stringer) logger.LogBuilder {
lb.log = lb.log.WithField(name, value.String())
return lb
}
func (lb *LogrusLogBuilder) Bytes(name string, value []byte) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Timestamp() logger.LogBuilder {
lb.log = lb.log.WithTime(time.Now())
return lb
}
func (lb *LogrusLogBuilder) Bool(name string, value bool) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Str(name string, value string) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Any(name string, value any) logger.LogBuilder {
lb.log = lb.log.WithField(name, value)
return lb
}
func (lb *LogrusLogBuilder) Err(value error) logger.LogBuilder {
lb.log = lb.log.WithError(value)
return lb
}
func (lb *LogrusLogBuilder) Send() {
lb.log.Logln(lb.lvl, lb.msg)
}