2017-05-23 18:56:10 +00:00
|
|
|
package error
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
)
|
|
|
|
|
2018-06-11 13:13:19 +00:00
|
|
|
type (
|
|
|
|
// LoggerHandler defines a HTTP handler that includes a HandlerError return pointer
|
|
|
|
LoggerHandler func(http.ResponseWriter, *http.Request) *HandlerError
|
|
|
|
// HandlerError represents an error raised inside a HTTP handler
|
|
|
|
HandlerError struct {
|
|
|
|
StatusCode int
|
|
|
|
Message string
|
|
|
|
Err error
|
|
|
|
}
|
|
|
|
errorResponse struct {
|
|
|
|
Err string `json:"err,omitempty"`
|
|
|
|
}
|
|
|
|
)
|
2017-05-23 18:56:10 +00:00
|
|
|
|
2018-06-11 13:13:19 +00:00
|
|
|
func (handler LoggerHandler) ServeHTTP(rw http.ResponseWriter, r *http.Request) {
|
|
|
|
err := handler(rw, r)
|
|
|
|
if err != nil {
|
|
|
|
writeErrorResponse(rw, err)
|
2017-05-23 18:56:10 +00:00
|
|
|
}
|
2018-06-11 13:13:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func writeErrorResponse(rw http.ResponseWriter, err *HandlerError) {
|
|
|
|
log.Printf("http error: %s (err=%s) (code=%d)\n", err.Message, err.Err, err.StatusCode)
|
|
|
|
rw.Header().Set("Content-Type", "application/json")
|
|
|
|
rw.WriteHeader(err.StatusCode)
|
|
|
|
json.NewEncoder(rw).Encode(&errorResponse{Err: err.Message})
|
|
|
|
}
|
2017-05-23 18:56:10 +00:00
|
|
|
|
2018-06-11 13:13:19 +00:00
|
|
|
// WriteError is a convenience function that creates a new HandlerError before calling writeErrorResponse.
|
|
|
|
// For use outside of the standard http handlers.
|
|
|
|
func WriteError(rw http.ResponseWriter, code int, message string, err error) {
|
|
|
|
writeErrorResponse(rw, &HandlerError{code, message, err})
|
2017-05-23 18:56:10 +00:00
|
|
|
}
|