2021-08-31 10:14:57 +08:00
|
|
|
// nolint:gomnd
|
2021-04-25 20:19:23 +08:00
|
|
|
package errors
|
|
|
|
|
2021-04-28 23:09:27 +08:00
|
|
|
// BadRequest new BadRequest error that is mapped to a 400 response.
|
2021-05-25 15:01:53 +08:00
|
|
|
func BadRequest(reason, message string) *Error {
|
2022-01-20 23:13:03 +08:00
|
|
|
return New(400, reason, message)
|
2021-04-25 20:19:23 +08:00
|
|
|
}
|
|
|
|
|
2021-04-28 23:09:27 +08:00
|
|
|
// IsBadRequest determines if err is an error which indicates a BadRequest error.
|
|
|
|
// It supports wrapped errors.
|
|
|
|
func IsBadRequest(err error) bool {
|
2021-05-25 15:01:53 +08:00
|
|
|
return Code(err) == 400
|
2021-04-25 20:19:23 +08:00
|
|
|
}
|
2021-04-28 23:09:27 +08:00
|
|
|
|
|
|
|
// Unauthorized new Unauthorized error that is mapped to a 401 response.
|
2021-05-25 15:01:53 +08:00
|
|
|
func Unauthorized(reason, message string) *Error {
|
2022-01-20 23:13:03 +08:00
|
|
|
return New(401, reason, message)
|
2021-04-28 23:09:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// IsUnauthorized determines if err is an error which indicates a Unauthorized error.
|
|
|
|
// It supports wrapped errors.
|
|
|
|
func IsUnauthorized(err error) bool {
|
2021-05-25 15:01:53 +08:00
|
|
|
return Code(err) == 401
|
2021-04-28 23:09:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Forbidden new Forbidden error that is mapped to a 403 response.
|
2021-05-25 15:01:53 +08:00
|
|
|
func Forbidden(reason, message string) *Error {
|
2022-01-20 23:13:03 +08:00
|
|
|
return New(403, reason, message)
|
2021-04-28 23:09:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// IsForbidden determines if err is an error which indicates a Forbidden error.
|
|
|
|
// It supports wrapped errors.
|
|
|
|
func IsForbidden(err error) bool {
|
2021-05-25 15:01:53 +08:00
|
|
|
return Code(err) == 403
|
2021-04-28 23:09:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// NotFound new NotFound error that is mapped to a 404 response.
|
2021-05-25 15:01:53 +08:00
|
|
|
func NotFound(reason, message string) *Error {
|
2022-01-20 23:13:03 +08:00
|
|
|
return New(404, reason, message)
|
2021-04-28 23:09:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// IsNotFound determines if err is an error which indicates an NotFound error.
|
|
|
|
// It supports wrapped errors.
|
|
|
|
func IsNotFound(err error) bool {
|
2021-05-25 15:01:53 +08:00
|
|
|
return Code(err) == 404
|
2021-04-28 23:09:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Conflict new Conflict error that is mapped to a 409 response.
|
2021-05-25 15:01:53 +08:00
|
|
|
func Conflict(reason, message string) *Error {
|
2022-01-20 23:13:03 +08:00
|
|
|
return New(409, reason, message)
|
2021-04-28 23:09:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// IsConflict determines if err is an error which indicates a Conflict error.
|
|
|
|
// It supports wrapped errors.
|
|
|
|
func IsConflict(err error) bool {
|
2021-05-25 15:01:53 +08:00
|
|
|
return Code(err) == 409
|
2021-04-28 23:09:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// InternalServer new InternalServer error that is mapped to a 500 response.
|
2021-05-25 15:01:53 +08:00
|
|
|
func InternalServer(reason, message string) *Error {
|
2022-01-20 23:13:03 +08:00
|
|
|
return New(500, reason, message)
|
2021-04-28 23:09:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// IsInternalServer determines if err is an error which indicates an Internal error.
|
|
|
|
// It supports wrapped errors.
|
|
|
|
func IsInternalServer(err error) bool {
|
2021-05-25 15:01:53 +08:00
|
|
|
return Code(err) == 500
|
2021-04-25 20:19:23 +08:00
|
|
|
}
|
|
|
|
|
2021-04-28 23:09:27 +08:00
|
|
|
// ServiceUnavailable new ServiceUnavailable error that is mapped to a HTTP 503 response.
|
2021-05-25 15:01:53 +08:00
|
|
|
func ServiceUnavailable(reason, message string) *Error {
|
2022-01-20 23:13:03 +08:00
|
|
|
return New(503, reason, message)
|
2021-04-25 20:19:23 +08:00
|
|
|
}
|
|
|
|
|
2021-04-28 23:09:27 +08:00
|
|
|
// IsServiceUnavailable determines if err is an error which indicates a Unavailable error.
|
|
|
|
// It supports wrapped errors.
|
|
|
|
func IsServiceUnavailable(err error) bool {
|
2021-05-25 15:01:53 +08:00
|
|
|
return Code(err) == 503
|
2021-04-25 20:19:23 +08:00
|
|
|
}
|
2021-06-02 21:34:38 +08:00
|
|
|
|
2021-06-02 22:58:43 +08:00
|
|
|
// GatewayTimeout new GatewayTimeout error that is mapped to a HTTP 504 response.
|
2021-06-02 21:34:38 +08:00
|
|
|
func GatewayTimeout(reason, message string) *Error {
|
2022-01-20 23:13:03 +08:00
|
|
|
return New(504, reason, message)
|
2021-06-02 21:34:38 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// IsGatewayTimeout determines if err is an error which indicates a GatewayTimeout error.
|
|
|
|
// It supports wrapped errors.
|
|
|
|
func IsGatewayTimeout(err error) bool {
|
|
|
|
return Code(err) == 504
|
|
|
|
}
|
2021-06-02 22:58:43 +08:00
|
|
|
|
|
|
|
// ClientClosed new ClientClosed error that is mapped to a HTTP 499 response.
|
|
|
|
func ClientClosed(reason, message string) *Error {
|
2022-01-20 23:13:03 +08:00
|
|
|
return New(499, reason, message)
|
2021-06-02 22:58:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// IsClientClosed determines if err is an error which indicates a IsClientClosed error.
|
|
|
|
// It supports wrapped errors.
|
|
|
|
func IsClientClosed(err error) bool {
|
|
|
|
return Code(err) == 499
|
|
|
|
}
|