From de4f6f0eeb11d61afd17e4d78f109f9a53583498 Mon Sep 17 00:00:00 2001 From: kevkevin Date: Fri, 13 Dec 2024 13:22:38 -0600 Subject: [PATCH] feat: added middleware to catch when there is an internal server error (#2129) --- routes/index.go | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/routes/index.go b/routes/index.go index e00df0f9a..27d4931c8 100644 --- a/routes/index.go +++ b/routes/index.go @@ -141,11 +141,36 @@ func getFromAuth(path string) (*extractResponse, error) { }, nil } +// Middleware to handle InternalServerError +func internalServerErrorHandler(next http.Handler) http.Handler { + return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + rr := &responseRecorder{ResponseWriter: w, statusCode: http.StatusOK} + next.ServeHTTP(rr, r) + + if rr.statusCode == http.StatusInternalServerError { + fmt.Printf("Internal Server Error: %s %s\n", r.Method, r.URL.Path) + http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError) + } + }) +} + +// Custom ResponseWriter to capture status codes +type responseRecorder struct { + http.ResponseWriter + statusCode int +} + +func (rr *responseRecorder) WriteHeader(code int) { + rr.statusCode = code + rr.ResponseWriter.WriteHeader(code) +} + func initChi() *chi.Mux { r := chi.NewRouter() r.Use(middleware.RequestID) r.Use(middleware.Logger) r.Use(middleware.Recoverer) + r.Use(internalServerErrorHandler) cors := cors.New(cors.Options{ AllowedOrigins: []string{"*"}, AllowedMethods: []string{"GET", "POST", "PUT", "DELETE", "OPTIONS"},