package middleware import ( "log/slog" "net/http" "time" ) type wrappedWriter struct { http.ResponseWriter statusCode int } func (w *wrappedWriter) WriteHeader(statusCode int) { w.ResponseWriter.WriteHeader(statusCode) w.statusCode = statusCode } func Logging(logger *slog.Logger, next http.Handler) http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { start := time.Now() wrapped := &wrappedWriter{ ResponseWriter: w, statusCode: http.StatusOK, } next.ServeHTTP(wrapped, r) logger.Info( "handled request", slog.Int("statusCode", wrapped.statusCode), slog.String("method", r.Method), slog.String("path", r.URL.Path), slog.Any("duration", time.Since(start)), ) }) }