From af75b81b1635bc9721a8a0a084a53352dcd84f0e Mon Sep 17 00:00:00 2001 From: aliraza556 Date: Tue, 17 Dec 2024 01:26:02 +0500 Subject: [PATCH] feat: add stack trace logging for 500 internal server errors --- routes/index.go | 16 ++++++++++++++-- routes/test_routes.go | 17 +++++++++++++++++ 2 files changed, 31 insertions(+), 2 deletions(-) create mode 100644 routes/test_routes.go diff --git a/routes/index.go b/routes/index.go index bc12cdc1b..687cea645 100644 --- a/routes/index.go +++ b/routes/index.go @@ -6,6 +6,7 @@ import ( "io" "net/http" "os" + "runtime" "time" "github.com/go-chi/chi" @@ -41,6 +42,7 @@ func NewRouter() *http.Server { r.Mount("/workflows", WorkflowRoutes()) r.Mount("/bounties/ticket", TicketRoutes()) r.Mount("/hivechat", ChatRoutes()) + r.Mount("/test", TestRoutes()) r.Group(func(r chi.Router) { r.Get("/tribe_by_feed", tribeHandlers.GetFirstTribeByFeed) @@ -145,17 +147,27 @@ func getFromAuth(path string) (*extractResponse, error) { // Middleware to handle InternalServerError func internalServerErrorHandler(next http.Handler) http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + fmt.Println("Inside Internal Server Middleware") + rr := negroni.NewResponseWriter(w) next.ServeHTTP(rr, r) if rr.Status() == http.StatusInternalServerError { - fmt.Printf("Internal Server Error: %s %s\n", r.Method, r.URL.Path) + // Get stack trace + buf := make([]byte, 1024) + n := runtime.Stack(buf, false) + stackTrace := string(buf[:n]) + + fmt.Printf("Internal Server Error: %s %s\nStack Trace:\n%s\n", + r.Method, + r.URL.Path, + stackTrace, + ) http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError) } }) } - func initChi() *chi.Mux { r := chi.NewRouter() r.Use(middleware.RequestID) diff --git a/routes/test_routes.go b/routes/test_routes.go new file mode 100644 index 000000000..8f8ad0235 --- /dev/null +++ b/routes/test_routes.go @@ -0,0 +1,17 @@ +package routes + +import ( + "net/http" + + "github.com/go-chi/chi" +) + +func TestRoutes() chi.Router { + r := chi.NewRouter() + + r.Get("/internal-server-error", func(w http.ResponseWriter, r *http.Request) { + http.Error(w, "Forced internal server error", http.StatusInternalServerError) + }) + + return r +}