aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/middleware/log.go
blob: 4c4109c3e1743a856ae2dba59dfe8a3fcc9cf4f5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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", "Address", r.RemoteAddr, "method", r.Method, "url", r.URL, "user agent", r.UserAgent))

		next.ServeHTTP(w, r)
	})
}