muxtool/middleware/recover.go

35 lines
672 B
Go
Raw Permalink Normal View History

2024-06-11 14:12:30 +03:00
package middleware
import (
"net/http"
"runtime/debug"
"log/slog"
)
func Recover(logger *slog.Logger) Middleware {
return func(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
defer func() {
err := recover()
if err == nil {
return
}
debug.PrintStack()
requestID := GetRequestID(r)
logger.ErrorContext(
r.Context(),
"panic",
slog.Any("panic", err),
slog.String("proto", r.Proto),
slog.String("method", r.Method),
slog.String("request_uri", r.RequestURI),
slog.String("request_id", requestID),
)
}()
next.ServeHTTP(w, r)
})
}
}