From 2deb185550e8452b065ccf6f764d13930ed03eb2 Mon Sep 17 00:00:00 2001 From: Jens Langhammer Date: Sat, 14 Jan 2023 23:27:34 +0100 Subject: [PATCH] internal: fix empty scheme field Signed-off-by: Jens Langhammer --- internal/utils/web/middleware.go | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/internal/utils/web/middleware.go b/internal/utils/web/middleware.go index 8688e6c73..d061e666d 100644 --- a/internal/utils/web/middleware.go +++ b/internal/utils/web/middleware.go @@ -14,10 +14,9 @@ import ( // responseLogger is wrapper of http.ResponseWriter that keeps track of its HTTP status // code and body size type responseLogger struct { - w http.ResponseWriter - status int - size int - upstream string + w http.ResponseWriter + status int + size int } // Header returns the ResponseWriter's Header @@ -98,15 +97,18 @@ func (h loggingHandler) ServeHTTP(w http.ResponseWriter, req *http.Request) { responseLogger := &responseLogger{w: w} h.handler.ServeHTTP(responseLogger, req) duration := float64(time.Since(t)) / float64(time.Millisecond) + scheme := "http" + if req.TLS != nil { + scheme = "https" + } h.afterHandler(h.logger.WithFields(log.Fields{ "remote": req.RemoteAddr, "host": GetHost(req), "runtime": fmt.Sprintf("%0.3f", duration), "method": req.Method, - "scheme": req.URL.Scheme, + "scheme": scheme, "size": responseLogger.Size(), "status": responseLogger.Status(), - "upstream": responseLogger.upstream, "user_agent": req.UserAgent(), }), req).Info(url.RequestURI()) }