2021-03-03 11:28:39 +01:00
|
|
|
package sessionresolver
|
|
|
|
|
2022-06-08 22:01:51 +02:00
|
|
|
//
|
|
|
|
// Error wrapping
|
|
|
|
//
|
|
|
|
|
2021-03-03 11:28:39 +01:00
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
)
|
|
|
|
|
2022-06-08 22:01:51 +02:00
|
|
|
// errWrapper wraps an error to include the URL of the
|
2021-03-03 11:28:39 +01:00
|
|
|
// resolver that we're currently using.
|
2022-06-08 22:01:51 +02:00
|
|
|
type errWrapper struct {
|
|
|
|
err error
|
|
|
|
url string
|
|
|
|
}
|
|
|
|
|
|
|
|
// newErrWrapper creates a new err wrapper.
|
|
|
|
func newErrWrapper(err error, URL string) *errWrapper {
|
|
|
|
return &errWrapper{
|
|
|
|
err: err,
|
|
|
|
url: URL,
|
|
|
|
}
|
2021-03-03 11:28:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Error implements error.Error.
|
2022-06-08 22:01:51 +02:00
|
|
|
func (ew *errWrapper) Error() string {
|
|
|
|
return fmt.Sprintf("<%s> %s", ew.url, ew.err.Error())
|
2021-03-03 11:28:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Is allows consumers to query for the type of the underlying error.
|
2022-06-08 22:01:51 +02:00
|
|
|
func (ew *errWrapper) Is(target error) bool {
|
|
|
|
return errors.Is(ew.err, target)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Unwrap returns the underlying error.
|
|
|
|
func (ew *errWrapper) Unwrap() error {
|
|
|
|
return ew.err
|
2021-03-03 11:28:39 +01:00
|
|
|
}
|