diff options
Diffstat (limited to 'middleware')
| -rw-r--r-- | middleware/log.go | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/middleware/log.go b/middleware/log.go new file mode 100644 index 0000000..57eb218 --- /dev/null +++ b/middleware/log.go @@ -0,0 +1,20 @@ +package middleware + +import ( + "log/slog" + "net/http" +) + +func Log(next http.Handler, logger *slog.Logger) http.Handler { + return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + + user, _, ok := r.BasicAuth() + if ok { + logger = logger.With(slog.String("user", user)) + } + + logger.InfoContext(r.Context(), "Recieved Request", slog.Group("request", "method", r.Method, "url", r.URL, "user agent", r.UserAgent)) + + next.ServeHTTP(w, r) + }) +} |
