From 9343f31e538a7f0a48920beea592ed0716e2d2e8 Mon Sep 17 00:00:00 2001 From: shell-skrimp <116320856+shell-skrimp@users.noreply.github.com> Date: Thu, 26 Oct 2023 14:46:22 -0500 Subject: [PATCH] add external logger support --- logger.go | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/logger.go b/logger.go index b4efcc05..c0400e31 100644 --- a/logger.go +++ b/logger.go @@ -1,6 +1,7 @@ package cron import ( + "io" "io/ioutil" "log" "os" @@ -56,6 +57,33 @@ func (pl printfLogger) Error(err error, msg string, keysAndValues ...interface{} append([]interface{}{msg, "error", err}, keysAndValues...)...) } +type externalLogger struct { + logger *log.Logger +} + +// NewExternalLogger allows for providing an external logging interface through an io.Writer +func NewExternalLogger(w io.Writer) *externalLogger { + l := log.New(w, "cron: ", log.Llongfile) + + el := externalLogger{ + logger: l, + } + + return &el +} + +func (el *externalLogger) Info(msg string, keysAndValues ...interface{}) { + el.logger.Printf( + formatString(len(keysAndValues)), + append([]interface{}{msg}, keysAndValues...)...) +} + +func (el *externalLogger) Error(err error, msg string, keysAndValues ...interface{}) { + el.logger.Printf( + formatString(len(keysAndValues)+2), + append([]interface{}{msg, "error", err}, keysAndValues...)...) +} + // formatString returns a logfmt-like format string for the number of // key/values. func formatString(numKeysAndValues int) string {