aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/middleware
diff options
context:
space:
mode:
Diffstat (limited to 'middleware')
-rw-r--r--middleware/log.go20
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)
+ })
+}