go-kit/kit

transport/http ServerFinalizer should accept error for better logging support

Open

#807 创建于 2018年12月1日

在 GitHub 查看
 (14 评论) (2 反应) (0 负责人)Go (27,422 star) (2,446 fork)batch import
enhancementhelp wanted

描述

We have three systems where logs are sent: our internal ELK stack, NewRelic and Airbrake. Some of our endpoints send errors to all of this systems, some endpoints send errors to only one of it.

We want log entries to have both error message and http status code. And also some http request context (uri, method, user-agent, ip...)

The only place which has access to both error and http status is ServerErrorEncoder. But since different endpoints need different sets of log outputs, we would have to create multiple error encoders just for sake of logging. Also, ServerErrorEncoder is not a good place for logging, because we would like it to do only one job - encode errors.

ServerFinalizer seems to be a great place to send logs, but there is no access to actual error message.

贡献者指南

transport/http ServerFinalizer should accept error for better logging support · go-kit/kit#807 | Good First Issue