2020-11-14 17:51:18 +01:00
|
|
|
package utils
|
|
|
|
|
|
|
|
import (
|
2020-12-27 21:07:09 +01:00
|
|
|
"io"
|
2020-11-14 17:51:18 +01:00
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
"encoding/json"
|
2020-11-14 18:27:20 +01:00
|
|
|
|
|
|
|
"github.com/rs/zerolog/log"
|
2020-11-14 17:51:18 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
type ErrResponse struct {
|
|
|
|
Message string `json:"message"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func HttpJsonRequest(w http.ResponseWriter, r *http.Request, res interface{}) bool {
|
|
|
|
if err := json.NewDecoder(r.Body).Decode(res); err != nil {
|
2020-12-27 21:07:09 +01:00
|
|
|
if err == io.EOF {
|
|
|
|
HttpBadRequest(w, "No data provided.")
|
|
|
|
} else {
|
|
|
|
HttpBadRequest(w, err)
|
|
|
|
}
|
|
|
|
|
2020-11-14 17:51:18 +01:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func HttpJsonResponse(w http.ResponseWriter, status int, res interface{}) {
|
|
|
|
w.Header().Set("Content-Type", "application/json")
|
|
|
|
w.WriteHeader(status)
|
|
|
|
|
|
|
|
if err := json.NewEncoder(w).Encode(res); err != nil {
|
2020-11-14 18:27:20 +01:00
|
|
|
log.Warn().Err(err).
|
|
|
|
Str("module", "http").
|
|
|
|
Msg("failed writing json error response")
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func HttpError(w http.ResponseWriter, status int, res interface{}) {
|
|
|
|
HttpJsonResponse(w, status, &ErrResponse{
|
|
|
|
Message: fmt.Sprint(res),
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func HttpSuccess(w http.ResponseWriter, res ...interface{}) {
|
|
|
|
if len(res) == 0 {
|
|
|
|
w.WriteHeader(http.StatusNoContent)
|
|
|
|
} else {
|
|
|
|
HttpJsonResponse(w, http.StatusOK, res[0])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func HttpBadRequest(w http.ResponseWriter, res ...interface{}) {
|
|
|
|
defHttpError(w, http.StatusBadRequest, "Bad Request.", res...)
|
|
|
|
}
|
|
|
|
|
2020-11-28 15:00:21 +01:00
|
|
|
func HttpUnauthorized(w http.ResponseWriter, res ...interface{}) {
|
2020-11-18 22:34:42 +01:00
|
|
|
defHttpError(w, http.StatusUnauthorized, "Access token does not have the required scope.", res...)
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
2020-11-28 15:00:21 +01:00
|
|
|
func HttpForbidden(w http.ResponseWriter, res ...interface{}) {
|
2020-11-18 22:34:42 +01:00
|
|
|
defHttpError(w, http.StatusForbidden, "Invalid or missing access token.", res...)
|
2020-11-14 17:51:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func HttpNotFound(w http.ResponseWriter, res ...interface{}) {
|
|
|
|
defHttpError(w, http.StatusNotFound, "Resource not found.", res...)
|
|
|
|
}
|
|
|
|
|
|
|
|
func HttpUnprocessableEntity(w http.ResponseWriter, res ...interface{}) {
|
|
|
|
defHttpError(w, http.StatusUnprocessableEntity, "Unprocessable Entity.", res...)
|
|
|
|
}
|
|
|
|
|
2020-11-28 15:00:21 +01:00
|
|
|
func HttpInternalServerError(w http.ResponseWriter, res ...interface{}) {
|
2020-11-14 17:51:18 +01:00
|
|
|
defHttpError(w, http.StatusInternalServerError, "Internal server error.", res...)
|
|
|
|
}
|
|
|
|
|
|
|
|
func defHttpError(w http.ResponseWriter, status int, text string, res ...interface{}) {
|
|
|
|
if len(res) == 0 {
|
|
|
|
HttpError(w, status, text)
|
|
|
|
} else {
|
|
|
|
HttpError(w, status, res[0])
|
|
|
|
}
|
|
|
|
}
|