From 88a6b1cb628e4e334068e861ac5fb56274d88845 Mon Sep 17 00:00:00 2001 From: Alexander Date: Tue, 11 Jun 2024 14:12:30 +0300 Subject: Initial --- middleware/recover.go | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 middleware/recover.go (limited to 'middleware/recover.go') diff --git a/middleware/recover.go b/middleware/recover.go new file mode 100644 index 0000000..6b5f2cb --- /dev/null +++ b/middleware/recover.go @@ -0,0 +1,34 @@ +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) + }) + } +} -- cgit v1.2.3