1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- package client // import "github.com/docker/docker/client"
- import (
- "context"
- "fmt"
- "github.com/docker/docker/api/types/versions"
- "github.com/docker/docker/errdefs"
- "github.com/pkg/errors"
- )
- // errConnectionFailed implements an error returned when connection failed.
- type errConnectionFailed struct {
- host string
- }
- // Error returns a string representation of an errConnectionFailed
- func (err errConnectionFailed) Error() string {
- if err.host == "" {
- return "Cannot connect to the Docker daemon. Is the docker daemon running on this host?"
- }
- return fmt.Sprintf("Cannot connect to the Docker daemon at %s. Is the docker daemon running?", err.host)
- }
- // IsErrConnectionFailed returns true if the error is caused by connection failed.
- func IsErrConnectionFailed(err error) bool {
- return errors.As(err, &errConnectionFailed{})
- }
- // ErrorConnectionFailed returns an error with host in the error message when connection to docker daemon failed.
- func ErrorConnectionFailed(host string) error {
- return errConnectionFailed{host: host}
- }
- // IsErrNotFound returns true if the error is a NotFound error, which is returned
- // by the API when some object is not found. It is an alias for [errdefs.IsNotFound].
- func IsErrNotFound(err error) bool {
- return errdefs.IsNotFound(err)
- }
- type objectNotFoundError struct {
- object string
- id string
- }
- func (e objectNotFoundError) NotFound() {}
- func (e objectNotFoundError) Error() string {
- return fmt.Sprintf("Error: No such %s: %s", e.object, e.id)
- }
- // NewVersionError returns an error if the APIVersion required is less than the
- // current supported version.
- //
- // It performs API-version negotiation if the Client is configured with this
- // option, otherwise it assumes the latest API version is used.
- func (cli *Client) NewVersionError(ctx context.Context, APIrequired, feature string) error {
- // Make sure we negotiated (if the client is configured to do so),
- // as code below contains API-version specific handling of options.
- //
- // Normally, version-negotiation (if enabled) would not happen until
- // the API request is made.
- cli.checkVersion(ctx)
- if cli.version != "" && versions.LessThan(cli.version, APIrequired) {
- return fmt.Errorf("%q requires API version %s, but the Docker daemon API version is %s", feature, APIrequired, cli.version)
- }
- return nil
- }
|