mirror of
https://gitlab.durp.info/durfy/modules/durpify.git
synced 2026-05-07 08:00:30 -05:00
30 lines
597 B
Go
30 lines
597 B
Go
|
|
package middleware
|
||
|
|
|
||
|
|
import (
|
||
|
|
"log"
|
||
|
|
"net/http"
|
||
|
|
"runtime/debug"
|
||
|
|
|
||
|
|
"gitlab.com/durfy/durpify/handlers"
|
||
|
|
)
|
||
|
|
|
||
|
|
func Recovery(next http.Handler) http.Handler {
|
||
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||
|
|
defer func() {
|
||
|
|
if err := recover(); err != nil {
|
||
|
|
msg := "Caught panic: %v, Stack trace: %s"
|
||
|
|
log.Printf(msg, err, string(debug.Stack()))
|
||
|
|
|
||
|
|
resp := handlers.NewFailureResponse(
|
||
|
|
"Unternal Server Error",
|
||
|
|
http.StatusInternalServerError,
|
||
|
|
[]string{err.(string)},
|
||
|
|
)
|
||
|
|
resp.SendReponse(w, r)
|
||
|
|
return
|
||
|
|
}
|
||
|
|
}()
|
||
|
|
next.ServeHTTP(w, r)
|
||
|
|
})
|
||
|
|
}
|