Add recovery to http handler
This commit is contained in:
parent
f495623b2a
commit
52ea329b8b
1 changed files with 24 additions and 1 deletions
|
@ -6,6 +6,7 @@ import (
|
||||||
log "github.com/sirupsen/logrus"
|
log "github.com/sirupsen/logrus"
|
||||||
"golang.org/x/net/webdav"
|
"golang.org/x/net/webdav"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
@ -31,7 +32,7 @@ func main() {
|
||||||
Handler: wdHandler,
|
Handler: wdHandler,
|
||||||
}
|
}
|
||||||
|
|
||||||
http.Handle("/", app.NewBasicAuthWebdavHandler(a))
|
http.Handle("/", wrapRecovery(app.NewBasicAuthWebdavHandler(a)))
|
||||||
|
|
||||||
connAddr := fmt.Sprintf("%s:%s", config.Address, config.Port)
|
connAddr := fmt.Sprintf("%s:%s", config.Address, config.Port)
|
||||||
|
|
||||||
|
@ -51,3 +52,25 @@ func main() {
|
||||||
log.Fatal(http.ListenAndServe(connAddr, nil))
|
log.Fatal(http.ListenAndServe(connAddr, nil))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func wrapRecovery(handler http.Handler) http.Handler {
|
||||||
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
var err error
|
||||||
|
defer func() {
|
||||||
|
r := recover()
|
||||||
|
switch t := r.(type) {
|
||||||
|
case string:
|
||||||
|
err = errors.New(t)
|
||||||
|
case error:
|
||||||
|
err = t
|
||||||
|
default:
|
||||||
|
err = errors.New("Unknown error")
|
||||||
|
}
|
||||||
|
|
||||||
|
log.WithError(err).Error("An error occurred handling a webdav request")
|
||||||
|
http.Error(w, "Internal server error", http.StatusInternalServerError)
|
||||||
|
}()
|
||||||
|
|
||||||
|
handler.ServeHTTP(w, r)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue