package utility import ( "log/slog" "net/http" "time" ) // Logger is an HTTP middleware that logs each request. func Logger(next http.Handler) http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { if !slog.Default().Enabled(r.Context(), slog.LevelInfo) { next.ServeHTTP(w, r) return } start := time.Now() rw := &responseWriter{ResponseWriter: w, code: http.StatusOK} next.ServeHTTP(rw, r) attrs := []slog.Attr{ slog.String("method", r.Method), slog.String("path", r.URL.Path), slog.Int("code", rw.code), slog.String("duration", time.Since(start).String()), slog.String("remote", r.RemoteAddr), } slog.LogAttrs(r.Context(), slog.LevelInfo, "http request", attrs...) }) } type responseWriter struct { http.ResponseWriter code int } func (rw *responseWriter) WriteHeader(code int) { rw.code = code rw.ResponseWriter.WriteHeader(code) }