keel/utils/net/http/errors.go
2023-07-10 12:22:16 +02:00

57 lines
1.8 KiB
Go

package httputils
import (
"net/http"
httplog "github.com/foomo/keel/net/http/log"
"github.com/pkg/errors"
"go.uber.org/zap"
"github.com/foomo/keel/log"
)
// InternalServerError http response
func InternalServerError(l *zap.Logger, w http.ResponseWriter, r *http.Request, err error) {
ServerError(l, w, r, http.StatusInternalServerError, err)
}
// InternalServiceUnavailable http response
func InternalServiceUnavailable(l *zap.Logger, w http.ResponseWriter, r *http.Request, err error) {
ServerError(l, w, r, http.StatusServiceUnavailable, err)
}
// InternalServiceTooEarly http response
func InternalServiceTooEarly(l *zap.Logger, w http.ResponseWriter, r *http.Request, err error) {
ServerError(l, w, r, http.StatusTooEarly, err)
}
// UnauthorizedServerError http response
func UnauthorizedServerError(l *zap.Logger, w http.ResponseWriter, r *http.Request, err error) {
ServerError(l, w, r, http.StatusUnauthorized, err)
}
// BadRequestServerError http response
func BadRequestServerError(l *zap.Logger, w http.ResponseWriter, r *http.Request, err error) {
ServerError(l, w, r, http.StatusBadRequest, err)
}
// NotFoundServerError http response
func NotFoundServerError(l *zap.Logger, w http.ResponseWriter, r *http.Request, err error) {
ServerError(l, w, r, http.StatusNotFound, err)
}
// ServerError http response
func ServerError(l *zap.Logger, w http.ResponseWriter, r *http.Request, code int, err error) {
if err != nil {
if labeler, ok := httplog.LabelerFromRequest(r); ok {
labeler.Add(log.FErrorType(err), log.FError(errors.Wrap(err, "http server error")))
} else {
l = log.WithError(l, err)
l = log.WithHTTPRequest(l, r)
l.Error("http server error", log.FHTTPStatusCode(code))
}
// w.Header().Set(keelhttp.HeaderXError, err.Error()) TODO make configurable with better value
http.Error(w, http.StatusText(code), code)
}
}