2017-02-07 22:33:23 +01:00
|
|
|
package utils
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io"
|
|
|
|
"net"
|
|
|
|
"net/http"
|
2018-07-07 10:14:03 +02:00
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
2017-02-07 22:33:23 +01:00
|
|
|
)
|
|
|
|
|
2018-07-11 10:08:03 +02:00
|
|
|
// ErrorHandler error handler
|
2017-02-07 22:33:23 +01:00
|
|
|
type ErrorHandler interface {
|
|
|
|
ServeHTTP(w http.ResponseWriter, req *http.Request, err error)
|
|
|
|
}
|
|
|
|
|
2018-07-11 10:08:03 +02:00
|
|
|
// DefaultHandler default error handler
|
2017-02-07 22:33:23 +01:00
|
|
|
var DefaultHandler ErrorHandler = &StdHandler{}
|
|
|
|
|
2018-07-11 10:08:03 +02:00
|
|
|
// StdHandler Standard error handler
|
|
|
|
type StdHandler struct{}
|
2017-02-07 22:33:23 +01:00
|
|
|
|
|
|
|
func (e *StdHandler) ServeHTTP(w http.ResponseWriter, req *http.Request, err error) {
|
|
|
|
statusCode := http.StatusInternalServerError
|
|
|
|
if e, ok := err.(net.Error); ok {
|
|
|
|
if e.Timeout() {
|
|
|
|
statusCode = http.StatusGatewayTimeout
|
|
|
|
} else {
|
|
|
|
statusCode = http.StatusBadGateway
|
|
|
|
}
|
|
|
|
} else if err == io.EOF {
|
|
|
|
statusCode = http.StatusBadGateway
|
|
|
|
}
|
|
|
|
w.WriteHeader(statusCode)
|
|
|
|
w.Write([]byte(http.StatusText(statusCode)))
|
2018-07-07 10:14:03 +02:00
|
|
|
log.Debugf("'%d %s' caused by: %v", statusCode, http.StatusText(statusCode), err)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
2018-07-11 10:08:03 +02:00
|
|
|
// ErrorHandlerFunc error handler function type
|
2017-02-07 22:33:23 +01:00
|
|
|
type ErrorHandlerFunc func(http.ResponseWriter, *http.Request, error)
|
|
|
|
|
|
|
|
// ServeHTTP calls f(w, r).
|
|
|
|
func (f ErrorHandlerFunc) ServeHTTP(w http.ResponseWriter, r *http.Request, err error) {
|
|
|
|
f(w, r, err)
|
|
|
|
}
|