-
Notifications
You must be signed in to change notification settings - Fork 258
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for retrieving logger from context.Context
#182
Comments
This is also something I'm interested in. There is a similar request against the stripe-go logger with some implementation ideas here: stripe/stripe-go#1281 |
We are also very interested in this. I created a zaplogger interface wrapper to meet the LeveledLogger interface that the HTTP client expects (see below). But unfortunately, I can't pass in the context that contains a lot of useful information (X-Correlation-Id, for example). It would be great for each // ZapLeveledLogger wrapper for zap.logger for use with hashicorp's go-retryable LeveledLogger
type ZapLeveledLogger struct {
Logger *zap.Logger
}
// New creates a ZapLeveledLogger with a zap.logger that satisfies standard library log.Logger interface.
func New(logger *zap.Logger) retryablehttp.LeveledLogger {
return &ZapLeveledLogger{Logger: logger}
}
func (l *ZapLeveledLogger) Error(msg string, keysAndValues ...interface{}) {
l.Logger.Error(msg, keysAndValuesToFields(keysAndValues)...)
}
func (l *ZapLeveledLogger) Info(msg string, keysAndValues ...interface{}) {
l.Logger.Info(msg, keysAndValuesToFields(keysAndValues)...)
}
func (l *ZapLeveledLogger) Debug(msg string, keysAndValues ...interface{}) {
l.Logger.Debug(msg, keysAndValuesToFields(keysAndValues)...)
}
func (l *ZapLeveledLogger) Warn(msg string, keysAndValues ...interface{}) {
l.Logger.Warn(msg, keysAndValuesToFields(keysAndValues)...)
}
func keysAndValuesToFields(keysAndValues []interface{}) []zapcore.Field {
fields := []zapcore.Field{}
// we've already failed if we have an odd number of arguments
failed := len(keysAndValues)%2 != 0
for i := 0; (i < len(keysAndValues)-1) && !failed; {
// get the next key safely, to check if it's a string
key, hasKey := keysAndValues[i].(string)
// check that there is an associated value
hasValue := (i + 1) < len(keysAndValues)
// if there is a key and value, include it
if hasKey && hasValue {
fields = append(fields, zap.Any(key, keysAndValues[i+1]))
i += 2
} else {
// give up, the key-value pairs are malformed.
// we can't know what's a key and what's a value, so just log everything.
failed = true
break
}
}
if failed {
fields = []zapcore.Field{
zap.Any("leveled_logger_fields", keysAndValues),
}
}
return fields
} |
@marianoasselborn @ryanuber @claire-labry |
Hi all, adding my 0.02c, my team would really like to see this added to the library. Some different possible implementation ideas:
type ContextLeveledLogger interface {
Error(ctx context.Context, msg string, keysAndValues ...interface{})
Info(ctx context.Context, msg string, keysAndValues ...interface{})
Debug(ctx context.Context, msg string, keysAndValues ...interface{})
Warn(ctx context.Context, msg string, keysAndValues ...interface{})
}
type Client struct {
HTTPClient *http.Client
Logger interface{}
LoggerKeyValuesFromCtx func(context.Context) []string
...
}
...
func (c *Client) Do(req *Request) (*http.Response, error) {
...
logger := c.logger()
if logger != nil {
switch v := logger.(type) {
case LeveledLogger:
v.Debug("performing request", "method", req.Method, "url", req.URL, c.LoggerKeyValuesFromCtx(req.Ctx())...)
case Logger:
v.Printf("[DEBUG] %s %s", req.Method, req.URL, c.LoggerKeyValuesFromCtx(req.Ctx())...)
}
}
...
} |
I have some code ready to go on a branch, but obviously don't have permission to push the branch. Should I push to a fork? |
@jcass8695 you'll need to push to a fork, then you can open a pull request for this repository. |
It's a common pattern to have a logger saved into the
context.Context
so that various pieces of information can be added to it - trace ID, user ID, etc. The problem is that the library doesn't support passing the context into the logger.The text was updated successfully, but these errors were encountered: