Expose GetHTTPError()
This commit is contained in:
17
error.go
17
error.go
@@ -99,7 +99,7 @@ func WriteError(w http.ResponseWriter, err error) {
|
|||||||
func Errorf(he *HTTPError, format string, a ...any) error {
|
func Errorf(he *HTTPError, format string, a ...any) error {
|
||||||
err := fmt.Errorf(format, a...) //nolint:goerr113
|
err := fmt.Errorf(format, a...) //nolint:goerr113
|
||||||
|
|
||||||
if hasHTTPError(err) {
|
if GetHTTPError(err) != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -158,22 +158,23 @@ type multiUnwrap interface {
|
|||||||
Unwrap() []error
|
Unwrap() []error
|
||||||
}
|
}
|
||||||
|
|
||||||
func hasHTTPError(err error) bool {
|
func GetHTTPError(err error) *HTTPError {
|
||||||
if _, has := err.(*HTTPError); has { //nolint:errorlint
|
if hErr, has := err.(*HTTPError); has { //nolint:errorlint
|
||||||
return true
|
return hErr
|
||||||
}
|
}
|
||||||
|
|
||||||
if unwrap, ok := err.(singleUnwrap); ok { //nolint:errorlint
|
if unwrap, ok := err.(singleUnwrap); ok { //nolint:errorlint
|
||||||
return hasHTTPError(unwrap.Unwrap())
|
return GetHTTPError(unwrap.Unwrap())
|
||||||
} else if unwrap, ok := err.(multiUnwrap); ok { //nolint:errorlint
|
} else if unwrap, ok := err.(multiUnwrap); ok { //nolint:errorlint
|
||||||
for _, sub := range unwrap.Unwrap() {
|
for _, sub := range unwrap.Unwrap() {
|
||||||
if hasHTTPError(sub) {
|
hErr := GetHTTPError(sub)
|
||||||
return true
|
if hErr != nil {
|
||||||
|
return hErr
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (je *JSONError) importError(err error) {
|
func (je *JSONError) importError(err error) {
|
||||||
|
|||||||
Reference in New Issue
Block a user