2020-02-29 02:31:59 +02:00
|
|
|
package logger
|
|
|
|
|
2020-03-13 16:36:42 +02:00
|
|
|
import (
|
2021-09-19 11:40:09 +02:00
|
|
|
"context"
|
2020-03-13 16:36:42 +02:00
|
|
|
"os"
|
|
|
|
)
|
2020-03-04 15:46:01 +02:00
|
|
|
|
2020-02-29 02:31:59 +02:00
|
|
|
type Helper struct {
|
2021-09-22 10:01:03 +02:00
|
|
|
logger Logger
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
2021-09-22 10:01:03 +02:00
|
|
|
func NewHelper(logger Logger) *Helper {
|
|
|
|
return &Helper{logger: logger}
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
2021-09-19 11:40:09 +02:00
|
|
|
// Extract always returns valid Helper with logger from context or with DefaultLogger as fallback.
|
2021-09-23 17:48:08 +02:00
|
|
|
// Can be used in pair with function Inject.
|
|
|
|
// Example: propagate RequestID to logger in service handler methods.
|
2021-09-19 11:40:09 +02:00
|
|
|
func Extract(ctx context.Context) *Helper {
|
|
|
|
if l, ok := FromContext(ctx); ok {
|
|
|
|
return NewHelper(l)
|
|
|
|
}
|
|
|
|
|
|
|
|
return NewHelper(DefaultLogger)
|
|
|
|
}
|
|
|
|
|
2021-09-23 17:48:08 +02:00
|
|
|
func (h *Helper) Inject(ctx context.Context) context.Context {
|
|
|
|
return NewContext(ctx, h.logger)
|
|
|
|
}
|
|
|
|
|
2021-09-22 10:01:03 +02:00
|
|
|
func (h *Helper) Log(level Level, args ...interface{}) {
|
|
|
|
h.logger.Log(level, args...)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Logf(level Level, template string, args ...interface{}) {
|
|
|
|
h.logger.Logf(level, template, args...)
|
|
|
|
}
|
|
|
|
|
2020-02-29 02:31:59 +02:00
|
|
|
func (h *Helper) Info(args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(InfoLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Log(InfoLevel, args...)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Infof(template string, args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(InfoLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Logf(InfoLevel, template, args...)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Trace(args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(TraceLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Log(TraceLevel, args...)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Tracef(template string, args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(TraceLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Logf(TraceLevel, template, args...)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Debug(args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(DebugLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Log(DebugLevel, args...)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Debugf(template string, args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(DebugLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Logf(DebugLevel, template, args...)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Warn(args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(WarnLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Log(WarnLevel, args...)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Warnf(template string, args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(WarnLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Logf(WarnLevel, template, args...)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Error(args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(ErrorLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Log(ErrorLevel, args...)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Errorf(template string, args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(ErrorLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Logf(ErrorLevel, template, args...)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Fatal(args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(FatalLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Log(FatalLevel, args...)
|
2020-03-04 15:46:01 +02:00
|
|
|
os.Exit(1)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) Fatalf(template string, args ...interface{}) {
|
2021-09-22 10:01:03 +02:00
|
|
|
if !h.logger.Options().Level.Enabled(FatalLevel) {
|
2020-03-11 19:55:39 +02:00
|
|
|
return
|
|
|
|
}
|
2021-09-22 10:01:03 +02:00
|
|
|
h.logger.Logf(FatalLevel, template, args...)
|
2020-03-04 15:46:01 +02:00
|
|
|
os.Exit(1)
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Helper) WithError(err error) *Helper {
|
2021-09-22 10:01:03 +02:00
|
|
|
return &Helper{logger: h.logger.Fields(map[string]interface{}{"error": err})}
|
2020-02-29 02:31:59 +02:00
|
|
|
}
|
2020-02-29 02:39:41 +02:00
|
|
|
|
|
|
|
func (h *Helper) WithFields(fields map[string]interface{}) *Helper {
|
2021-09-22 10:01:03 +02:00
|
|
|
return &Helper{logger: h.logger.Fields(fields)}
|
2020-02-29 02:39:41 +02:00
|
|
|
}
|
2022-09-29 16:44:53 +02:00
|
|
|
|
|
|
|
func HelperOrDefault(h *Helper) *Helper {
|
|
|
|
if h == nil {
|
|
|
|
return DefaultHelper
|
|
|
|
}
|
|
|
|
return h
|
|
|
|
}
|