Documentation ¶
Overview ¶
Package errdefs defines a set of error interfaces that packages should use for communicating classes of errors. Errors that cross the package boundary should implement one (and only one) of these interfaces.
Packages should not reference these interfaces directly, only implement them. To check if a particular error implements one of these interfaces, there are helper functions provided (e.g. `Is<SomeError>`) which can be used rather than asserting the interfaces directly. If you must assert on these interfaces, be sure to check the causal chain (`err.Cause()`).
Index ¶
- Constants
- func Cancelled(err error) error
- func Conflict(err error) error
- func DataLoss(err error) error
- func Deadline(err error) error
- func Forbidden(err error) error
- func FromContext(ctx context.Context) error
- func FromStatusCode(err error, statusCode int) error
- func GetHTTPErrorStatusCode(err error, adapters ...Adapter) int
- func InvalidParameter(err error) error
- func IsCancelled(err error) bool
- func IsConflict(err error) bool
- func IsDataLoss(err error) bool
- func IsDeadline(err error) bool
- func IsForbidden(err error) bool
- func IsInvalidParameter(err error) bool
- func IsNotFound(err error) bool
- func IsNotImplemented(err error) bool
- func IsNotModified(err error) bool
- func IsSystem(err error) bool
- func IsUnauthorized(err error) bool
- func IsUnavailable(err error) bool
- func IsUnknown(err error) bool
- func NotFound(err error) error
- func NotImplemented(err error) error
- func NotModified(err error) error
- func System(err error) error
- func Unauthorized(err error) error
- func Unavailable(err error) error
- func Unknown(err error) error
- type Adapter
- type ErrCancelled
- type ErrConflict
- type ErrDataLoss
- type ErrDeadline
- type ErrForbidden
- type ErrInvalidParameter
- type ErrNotFound
- type ErrNotImplemented
- type ErrNotModified
- type ErrSystem
- type ErrUnauthorized
- type ErrUnavailable
- type ErrUnknown
Constants ¶
const NoSuitableHTTPStatusCode = 0
NoSuitableHTTPStatusCode must be returned by Adapter if no suitable HTTP status was found.
Variables ¶
This section is empty.
Functions ¶
func Cancelled ¶
Cancelled is a helper to create an error of the class with the same name from any error type
func Conflict ¶
Conflict is a helper to create an error of the class with the same name from any error type
func DataLoss ¶
DataLoss is a helper to create an error of the class with the same name from any error type
func Deadline ¶
Deadline is a helper to create an error of the class with the same name from any error type
func Forbidden ¶
Forbidden is a helper to create an error of the class with the same name from any error type
func FromContext ¶
FromContext returns the error class from the passed in context
func FromStatusCode ¶
FromStatusCode creates an errdef error, based on the provided HTTP status-code
func GetHTTPErrorStatusCode ¶
GetHTTPErrorStatusCode retrieves status code from err, or an http.StatusInternalServerError when unable to find a suitable status code.
By default, it only converts error-types matching the errdefs types defined in this package, but additional adapters can be passed.
func InvalidParameter ¶
InvalidParameter is a helper to create an error of the class with the same name from any error type
func IsCancelled ¶
IsCancelled returns if the passed in error is an ErrCancelled
func IsConflict ¶
IsConflict returns if the passed in error is an ErrConflict
func IsDataLoss ¶
IsDataLoss returns if the passed in error is an ErrDataLoss
func IsDeadline ¶
IsDeadline returns if the passed in error is an ErrDeadline
func IsForbidden ¶
IsForbidden returns if the passed in error is an ErrForbidden
func IsInvalidParameter ¶
IsInvalidParameter returns if the passed in error is an ErrInvalidParameter
func IsNotFound ¶
IsNotFound returns if the passed in error is an ErrNotFound
func IsNotImplemented ¶
IsNotImplemented returns if the passed in error is an ErrNotImplemented
func IsNotModified ¶
IsNotModified returns if the passed in error is a NotModified error
func IsUnauthorized ¶
IsUnauthorized returns if the passed in error is an ErrUnauthorized
func IsUnavailable ¶
IsUnavailable returns if the passed in error is an ErrUnavailable
func NotFound ¶
NotFound is a helper to create an error of the class with the same name from any error type
func NotImplemented ¶
NotImplemented is a helper to create an error of the class with the same name from any error type
func NotModified ¶
NotModified is a helper to create an error of the class with the same name from any error type
func System ¶
System is a helper to create an error of the class with the same name from any error type
func Unauthorized ¶
Unauthorized is a helper to create an error of the class with the same name from any error type
func Unavailable ¶
Unavailable is a helper to create an error of the class with the same name from any error type
Types ¶
type Adapter ¶
Adapter converts an error from a subsystem (such as containerd, grpc, or the distribution API into a suitable HTTP status code or NoSuitableHTTPStatusCode if no suitable status code was found ("unknown").
type ErrCancelled ¶
type ErrCancelled interface {
Cancelled()
}
ErrCancelled signals that the action was cancelled.
type ErrConflict ¶
type ErrConflict interface {
Conflict()
}
ErrConflict signals that some internal state conflicts with the requested action and can't be performed. A change in state should be able to clear this error.
type ErrDataLoss ¶
type ErrDataLoss interface {
DataLoss()
}
ErrDataLoss indicates that data was lost or there is data corruption.
type ErrDeadline ¶
type ErrDeadline interface {
DeadlineExceeded()
}
ErrDeadline signals that the deadline was reached before the action completed.
type ErrForbidden ¶
type ErrForbidden interface {
Forbidden()
}
ErrForbidden signals that the requested action cannot be performed under any circumstances. When a ErrForbidden is returned, the caller should never retry the action.
type ErrInvalidParameter ¶
type ErrInvalidParameter interface {
InvalidParameter()
}
ErrInvalidParameter signals that the user input is invalid
type ErrNotFound ¶
type ErrNotFound interface {
NotFound()
}
ErrNotFound signals that the requested object doesn't exist
type ErrNotImplemented ¶
type ErrNotImplemented interface {
NotImplemented()
}
ErrNotImplemented signals that the requested action/feature is not implemented on the system as configured.
type ErrNotModified ¶
type ErrNotModified interface {
NotModified()
}
ErrNotModified signals that an action can't be performed because it's already in the desired state
type ErrSystem ¶
type ErrSystem interface {
System()
}
ErrSystem signals that some internal error occurred. An example of this would be a failed mount request.
type ErrUnauthorized ¶
type ErrUnauthorized interface {
}ErrUnauthorized is used to signify that the user is not authorized to perform a specific action
type ErrUnavailable ¶
type ErrUnavailable interface {
}ErrUnavailable signals that the requested action/subsystem is not available.
type ErrUnknown ¶
type ErrUnknown interface {
Unknown()
}
ErrUnknown signals that the kind of error that occurred is not known.