NewHandler injects log into requests context.
(log zerolog.Logger)
| 22 | |
| 23 | // NewHandler injects log into requests context. |
| 24 | func NewHandler(log zerolog.Logger) func(http.Handler) http.Handler { |
| 25 | return func(next http.Handler) http.Handler { |
| 26 | return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { |
| 27 | // Create a copy of the logger (including internal context slice) |
| 28 | // to prevent data race when using UpdateContext. |
| 29 | l := log.With().Logger() |
| 30 | r = r.WithContext(l.WithContext(r.Context())) |
| 31 | next.ServeHTTP(w, r) |
| 32 | }) |
| 33 | } |
| 34 | } |
| 35 | |
| 36 | // URLHandler adds the requested URL as a field to the context's logger |
| 37 | // using fieldKey as field key. |