2021-09-23 20:41:04 +00:00
|
|
|
package apimiddleware
|
2021-06-15 15:28:49 +00:00
|
|
|
|
2021-06-28 11:36:12 +00:00
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
)
|
|
|
|
|
2021-06-15 15:28:49 +00:00
|
|
|
// ---------------
|
|
|
|
// Error handling.
|
|
|
|
// ---------------
|
|
|
|
|
|
|
|
// ErrorJson describes common functionality of all JSON error representations.
|
|
|
|
type ErrorJson interface {
|
|
|
|
StatusCode() int
|
|
|
|
SetCode(code int)
|
|
|
|
Msg() string
|
2021-10-07 18:50:03 +00:00
|
|
|
SetMsg(msg string)
|
2021-06-15 15:28:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// DefaultErrorJson is a JSON representation of a simple error value, containing only a message and an error code.
|
|
|
|
type DefaultErrorJson struct {
|
|
|
|
Message string `json:"message"`
|
|
|
|
Code int `json:"code"`
|
|
|
|
}
|
|
|
|
|
2021-06-28 11:36:12 +00:00
|
|
|
// InternalServerErrorWithMessage returns a DefaultErrorJson with 500 code and a custom message.
|
|
|
|
func InternalServerErrorWithMessage(err error, message string) *DefaultErrorJson {
|
|
|
|
e := errors.Wrapf(err, message)
|
|
|
|
return &DefaultErrorJson{
|
|
|
|
Message: e.Error(),
|
|
|
|
Code: http.StatusInternalServerError,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// InternalServerError returns a DefaultErrorJson with 500 code.
|
|
|
|
func InternalServerError(err error) *DefaultErrorJson {
|
|
|
|
return &DefaultErrorJson{
|
|
|
|
Message: err.Error(),
|
|
|
|
Code: http.StatusInternalServerError,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-24 18:01:37 +00:00
|
|
|
func TimeoutError() *DefaultErrorJson {
|
|
|
|
return &DefaultErrorJson{
|
|
|
|
Message: "Request timeout",
|
|
|
|
Code: http.StatusRequestTimeout,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-15 15:28:49 +00:00
|
|
|
// StatusCode returns the error's underlying error code.
|
|
|
|
func (e *DefaultErrorJson) StatusCode() int {
|
|
|
|
return e.Code
|
|
|
|
}
|
|
|
|
|
|
|
|
// Msg returns the error's underlying message.
|
|
|
|
func (e *DefaultErrorJson) Msg() string {
|
|
|
|
return e.Message
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetCode sets the error's underlying error code.
|
|
|
|
func (e *DefaultErrorJson) SetCode(code int) {
|
|
|
|
e.Code = code
|
|
|
|
}
|
2021-10-07 18:50:03 +00:00
|
|
|
|
|
|
|
// SetMsg sets the error's underlying message.
|
|
|
|
func (e *DefaultErrorJson) SetMsg(msg string) {
|
|
|
|
e.Message = msg
|
|
|
|
}
|