|
|
@ -35,6 +35,8 @@ import (
|
|
|
|
notaryclient "github.com/theupdateframework/notary/client"
|
|
|
|
notaryclient "github.com/theupdateframework/notary/client"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const defaultInitTimeout = 2 * time.Second
|
|
|
|
|
|
|
|
|
|
|
|
// Streams is an interface which exposes the standard input and output streams
|
|
|
|
// Streams is an interface which exposes the standard input and output streams
|
|
|
|
type Streams interface {
|
|
|
|
type Streams interface {
|
|
|
|
In() *streams.In
|
|
|
|
In() *streams.In
|
|
|
@ -77,6 +79,7 @@ type DockerCli struct {
|
|
|
|
currentContext string
|
|
|
|
currentContext string
|
|
|
|
dockerEndpoint docker.Endpoint
|
|
|
|
dockerEndpoint docker.Endpoint
|
|
|
|
contextStoreConfig store.Config
|
|
|
|
contextStoreConfig store.Config
|
|
|
|
|
|
|
|
initTimeout time.Duration
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// DefaultVersion returns api.defaultVersion.
|
|
|
|
// DefaultVersion returns api.defaultVersion.
|
|
|
@ -216,7 +219,7 @@ func (cli *DockerCli) Initialize(opts *cliflags.ClientOptions, ops ...Initialize
|
|
|
|
cli.contextStore = &ContextStoreWithDefault{
|
|
|
|
cli.contextStore = &ContextStoreWithDefault{
|
|
|
|
Store: baseContextStore,
|
|
|
|
Store: baseContextStore,
|
|
|
|
Resolver: func() (*DefaultContext, error) {
|
|
|
|
Resolver: func() (*DefaultContext, error) {
|
|
|
|
return ResolveDefaultContext(opts.Common, cli.ConfigFile(), cli.contextStoreConfig, cli.Err())
|
|
|
|
return ResolveDefaultContext(opts.Common, cli.contextStoreConfig)
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
cli.currentContext, err = resolveContextName(opts.Common, cli.configFile, cli.contextStore)
|
|
|
|
cli.currentContext, err = resolveContextName(opts.Common, cli.configFile, cli.contextStore)
|
|
|
@ -244,7 +247,7 @@ func NewAPIClientFromFlags(opts *cliflags.CommonOptions, configFile *configfile.
|
|
|
|
contextStore := &ContextStoreWithDefault{
|
|
|
|
contextStore := &ContextStoreWithDefault{
|
|
|
|
Store: store.New(config.ContextStoreDir(), storeConfig),
|
|
|
|
Store: store.New(config.ContextStoreDir(), storeConfig),
|
|
|
|
Resolver: func() (*DefaultContext, error) {
|
|
|
|
Resolver: func() (*DefaultContext, error) {
|
|
|
|
return ResolveDefaultContext(opts, configFile, storeConfig, io.Discard)
|
|
|
|
return ResolveDefaultContext(opts, storeConfig)
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
contextName, err := resolveContextName(opts, configFile, contextStore)
|
|
|
|
contextName, err := resolveContextName(opts, configFile, contextStore)
|
|
|
@ -313,13 +316,20 @@ func resolveDefaultDockerEndpoint(opts *cliflags.CommonOptions) (docker.Endpoint
|
|
|
|
}, nil
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func (cli *DockerCli) getInitTimeout() time.Duration {
|
|
|
|
|
|
|
|
if cli.initTimeout != 0 {
|
|
|
|
|
|
|
|
return cli.initTimeout
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return defaultInitTimeout
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func (cli *DockerCli) initializeFromClient() {
|
|
|
|
func (cli *DockerCli) initializeFromClient() {
|
|
|
|
ctx := context.Background()
|
|
|
|
ctx := context.Background()
|
|
|
|
if strings.HasPrefix(cli.DockerEndpoint().Host, "tcp://") {
|
|
|
|
if !strings.HasPrefix(cli.DockerEndpoint().Host, "ssh://") {
|
|
|
|
// @FIXME context.WithTimeout doesn't work with connhelper / ssh connections
|
|
|
|
// @FIXME context.WithTimeout doesn't work with connhelper / ssh connections
|
|
|
|
// time="2020-04-10T10:16:26Z" level=warning msg="commandConn.CloseWrite: commandconn: failed to wait: signal: killed"
|
|
|
|
// time="2020-04-10T10:16:26Z" level=warning msg="commandConn.CloseWrite: commandconn: failed to wait: signal: killed"
|
|
|
|
var cancel func()
|
|
|
|
var cancel func()
|
|
|
|
ctx, cancel = context.WithTimeout(ctx, 2*time.Second)
|
|
|
|
ctx, cancel = context.WithTimeout(ctx, cli.getInitTimeout())
|
|
|
|
defer cancel()
|
|
|
|
defer cancel()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -456,10 +466,10 @@ func resolveContextName(opts *cliflags.CommonOptions, config *configfile.ConfigF
|
|
|
|
if len(opts.Hosts) > 0 {
|
|
|
|
if len(opts.Hosts) > 0 {
|
|
|
|
return DefaultContextName, nil
|
|
|
|
return DefaultContextName, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if _, present := os.LookupEnv(client.EnvOverrideHost); present {
|
|
|
|
if os.Getenv(client.EnvOverrideHost) != "" {
|
|
|
|
return DefaultContextName, nil
|
|
|
|
return DefaultContextName, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ctxName, ok := os.LookupEnv("DOCKER_CONTEXT"); ok {
|
|
|
|
if ctxName := os.Getenv("DOCKER_CONTEXT"); ctxName != "" {
|
|
|
|
return ctxName, nil
|
|
|
|
return ctxName, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if config != nil && config.CurrentContext != "" {
|
|
|
|
if config != nil && config.CurrentContext != "" {
|
|
|
|