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) }) }