2020-11-14 17:51:18 +01:00
|
|
|
package utils
|
|
|
|
|
|
|
|
import (
|
2021-02-14 14:40:17 +01:00
|
|
|
"encoding/json"
|
2020-11-14 17:51:18 +01:00
|
|
|
"fmt"
|
2021-02-14 14:40:17 +01:00
|
|
|
"io"
|
2020-11-14 17:51:18 +01:00
|
|
|
"net/http"
|
2020-11-14 18:27:20 +01:00
|
|
|
|
|
|
|
"github.com/rs/zerolog/log"
|
2020-11-14 17:51:18 +01:00
|
|
|
)
|
|
|
|
|
2022-07-28 12:20:20 +02:00
|
|
|
func HttpJsonRequest(w http.ResponseWriter, r *http.Request, res any) error {
|
2021-09-17 00:24:33 +02:00
|
|
|
err := json.NewDecoder(r.Body).Decode(res)
|
|
|
|
|
|
|
|
if err == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
if err == io.EOF {
|
|
|
|
return HttpBadRequest("no data provided").WithInternalErr(err)
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
2021-09-17 00:24:33 +02:00
|
|
|
return HttpBadRequest("unable to parse provided data").WithInternalErr(err)
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
2022-07-28 12:20:20 +02:00
|
|
|
func HttpJsonResponse(w http.ResponseWriter, code int, res any) {
|
2020-11-14 17:51:18 +01:00
|
|
|
w.Header().Set("Content-Type", "application/json")
|
2021-09-16 20:16:51 +02:00
|
|
|
w.WriteHeader(code)
|
2020-11-14 17:51:18 +01:00
|
|
|
|
|
|
|
if err := json.NewEncoder(w).Encode(res); err != nil {
|
2021-09-01 23:10:06 +02:00
|
|
|
log.Err(err).Str("module", "http").Msg("sending http json response failed")
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-28 12:20:20 +02:00
|
|
|
func HttpSuccess(w http.ResponseWriter, res ...any) error {
|
2020-11-14 17:51:18 +01:00
|
|
|
if len(res) == 0 {
|
|
|
|
w.WriteHeader(http.StatusNoContent)
|
|
|
|
} else {
|
|
|
|
HttpJsonResponse(w, http.StatusOK, res[0])
|
|
|
|
}
|
2021-09-17 00:24:33 +02:00
|
|
|
|
|
|
|
return nil
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
2021-09-16 20:16:51 +02:00
|
|
|
// HTTPError is an error with a message and an HTTP status code.
|
|
|
|
type HTTPError struct {
|
|
|
|
Code int `json:"code"`
|
|
|
|
Message string `json:"message"`
|
|
|
|
|
|
|
|
InternalErr error `json:"-"`
|
|
|
|
InternalMsg string `json:"-"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e *HTTPError) Error() string {
|
|
|
|
if e.InternalMsg != "" {
|
|
|
|
return e.InternalMsg
|
|
|
|
}
|
|
|
|
return fmt.Sprintf("%d: %s", e.Code, e.Message)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e *HTTPError) Cause() error {
|
|
|
|
if e.InternalErr != nil {
|
|
|
|
return e.InternalErr
|
|
|
|
}
|
|
|
|
return e
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
2021-09-16 20:16:51 +02:00
|
|
|
// WithInternalErr adds internal error information to the error
|
|
|
|
func (e *HTTPError) WithInternalErr(err error) *HTTPError {
|
|
|
|
e.InternalErr = err
|
|
|
|
return e
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
2021-09-16 20:16:51 +02:00
|
|
|
// WithInternalMsg adds internal message information to the error
|
|
|
|
func (e *HTTPError) WithInternalMsg(msg string) *HTTPError {
|
|
|
|
e.InternalMsg = msg
|
|
|
|
return e
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
2021-09-16 20:16:51 +02:00
|
|
|
// WithInternalMsg adds internal formated message information to the error
|
2022-07-28 12:20:20 +02:00
|
|
|
func (e *HTTPError) WithInternalMsgf(fmtStr string, args ...any) *HTTPError {
|
2021-09-16 20:16:51 +02:00
|
|
|
e.InternalMsg = fmt.Sprintf(fmtStr, args...)
|
|
|
|
return e
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
2021-09-16 20:16:51 +02:00
|
|
|
// Sends error with custom formated message
|
2022-07-28 12:20:20 +02:00
|
|
|
func (e *HTTPError) Msgf(fmtSt string, args ...any) *HTTPError {
|
2021-09-16 20:16:51 +02:00
|
|
|
e.Message = fmt.Sprintf(fmtSt, args...)
|
2021-09-17 00:24:33 +02:00
|
|
|
return e
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
2021-09-16 20:16:51 +02:00
|
|
|
// Sends error with custom message
|
2021-09-17 00:24:33 +02:00
|
|
|
func (e *HTTPError) Msg(str string) *HTTPError {
|
2021-09-16 20:16:51 +02:00
|
|
|
e.Message = str
|
2021-09-17 00:24:33 +02:00
|
|
|
return e
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
2021-09-17 00:24:33 +02:00
|
|
|
func HttpError(code int, res ...string) *HTTPError {
|
|
|
|
err := &HTTPError{
|
|
|
|
Code: code,
|
|
|
|
Message: http.StatusText(code),
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
2021-09-16 20:16:51 +02:00
|
|
|
|
2021-09-17 00:24:33 +02:00
|
|
|
if len(res) == 1 {
|
|
|
|
err.Message = res[0]
|
2021-09-16 20:16:51 +02:00
|
|
|
}
|
|
|
|
|
2021-09-17 00:24:33 +02:00
|
|
|
return err
|
2021-09-16 20:16:51 +02:00
|
|
|
}
|
|
|
|
|
2021-09-17 00:24:33 +02:00
|
|
|
func HttpBadRequest(res ...string) *HTTPError {
|
|
|
|
return HttpError(http.StatusBadRequest, res...)
|
2021-09-16 20:16:51 +02:00
|
|
|
}
|
|
|
|
|
2021-09-17 00:24:33 +02:00
|
|
|
func HttpUnauthorized(res ...string) *HTTPError {
|
|
|
|
return HttpError(http.StatusUnauthorized, res...)
|
2021-09-16 20:16:51 +02:00
|
|
|
}
|
|
|
|
|
2021-09-17 00:24:33 +02:00
|
|
|
func HttpForbidden(res ...string) *HTTPError {
|
|
|
|
return HttpError(http.StatusForbidden, res...)
|
2021-09-16 20:16:51 +02:00
|
|
|
}
|
|
|
|
|
2021-09-17 00:24:33 +02:00
|
|
|
func HttpNotFound(res ...string) *HTTPError {
|
|
|
|
return HttpError(http.StatusNotFound, res...)
|
2021-09-16 20:16:51 +02:00
|
|
|
}
|
|
|
|
|
2021-09-17 00:24:33 +02:00
|
|
|
func HttpUnprocessableEntity(res ...string) *HTTPError {
|
|
|
|
return HttpError(http.StatusUnprocessableEntity, res...)
|
2021-09-16 20:16:51 +02:00
|
|
|
}
|
|
|
|
|
2021-09-17 00:24:33 +02:00
|
|
|
func HttpInternalServerError(res ...string) *HTTPError {
|
|
|
|
return HttpError(http.StatusInternalServerError, res...)
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|