From 54cd78b2c2bafe2fc9b191f7375d652d17e15e95 Mon Sep 17 00:00:00 2001 From: JP Appel Date: Wed, 9 Oct 2024 17:36:10 -0400 Subject: Add logger middleware --- middleware/log.go | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 middleware/log.go (limited to 'middleware/log.go') 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) + }) +} -- cgit v1.2.3