You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
156 lines
5.0 KiB
Go
156 lines
5.0 KiB
Go
3 years ago
|
package context
|
||
6 years ago
|
|
||
|
import (
|
||
5 years ago
|
"os"
|
||
|
"path/filepath"
|
||
|
|
||
|
"github.com/docker/cli/cli/command"
|
||
6 years ago
|
"github.com/docker/cli/cli/context"
|
||
|
"github.com/docker/cli/cli/context/store"
|
||
5 years ago
|
"github.com/docker/docker/pkg/homedir"
|
||
6 years ago
|
"k8s.io/client-go/tools/clientcmd"
|
||
|
clientcmdapi "k8s.io/client-go/tools/clientcmd/api"
|
||
|
)
|
||
|
|
||
|
// EndpointMeta is a typed wrapper around a context-store generic endpoint describing
|
||
|
// a Kubernetes endpoint, without TLS data
|
||
|
type EndpointMeta struct {
|
||
|
context.EndpointMetaBase
|
||
|
DefaultNamespace string `json:",omitempty"`
|
||
|
AuthProvider *clientcmdapi.AuthProviderConfig `json:",omitempty"`
|
||
|
Exec *clientcmdapi.ExecConfig `json:",omitempty"`
|
||
5 years ago
|
UsernamePassword *UsernamePassword `json:"usernamePassword,omitempty"`
|
||
|
}
|
||
|
|
||
|
// UsernamePassword contains username/password auth info
|
||
|
type UsernamePassword struct {
|
||
|
Username string `json:"username,omitempty"`
|
||
|
Password string `json:"password,omitempty"`
|
||
6 years ago
|
}
|
||
|
|
||
5 years ago
|
var _ command.EndpointDefaultResolver = &EndpointMeta{}
|
||
|
|
||
6 years ago
|
// Endpoint is a typed wrapper around a context-store generic endpoint describing
|
||
|
// a Kubernetes endpoint, with TLS data
|
||
|
type Endpoint struct {
|
||
|
EndpointMeta
|
||
|
TLSData *context.TLSData
|
||
|
}
|
||
|
|
||
5 years ago
|
func init() {
|
||
|
command.RegisterDefaultStoreEndpoints(
|
||
|
store.EndpointTypeGetter(KubernetesEndpoint, func() interface{} { return &EndpointMeta{} }),
|
||
|
)
|
||
|
}
|
||
|
|
||
6 years ago
|
// WithTLSData loads TLS materials for the endpoint
|
||
6 years ago
|
func (c *EndpointMeta) WithTLSData(s store.Reader, contextName string) (Endpoint, error) {
|
||
6 years ago
|
tlsData, err := context.LoadTLSData(s, contextName, KubernetesEndpoint)
|
||
|
if err != nil {
|
||
|
return Endpoint{}, err
|
||
|
}
|
||
|
return Endpoint{
|
||
|
EndpointMeta: *c,
|
||
|
TLSData: tlsData,
|
||
|
}, nil
|
||
|
}
|
||
|
|
||
|
// KubernetesConfig creates the kubernetes client config from the endpoint
|
||
|
func (c *Endpoint) KubernetesConfig() clientcmd.ClientConfig {
|
||
|
cfg := clientcmdapi.NewConfig()
|
||
|
cluster := clientcmdapi.NewCluster()
|
||
|
cluster.Server = c.Host
|
||
|
cluster.InsecureSkipTLSVerify = c.SkipTLSVerify
|
||
|
authInfo := clientcmdapi.NewAuthInfo()
|
||
|
if c.TLSData != nil {
|
||
|
cluster.CertificateAuthorityData = c.TLSData.CA
|
||
|
authInfo.ClientCertificateData = c.TLSData.Cert
|
||
|
authInfo.ClientKeyData = c.TLSData.Key
|
||
|
}
|
||
5 years ago
|
if c.UsernamePassword != nil {
|
||
|
authInfo.Username = c.UsernamePassword.Username
|
||
|
authInfo.Password = c.UsernamePassword.Password
|
||
|
}
|
||
6 years ago
|
authInfo.AuthProvider = c.AuthProvider
|
||
|
authInfo.Exec = c.Exec
|
||
|
cfg.Clusters["cluster"] = cluster
|
||
|
cfg.AuthInfos["authInfo"] = authInfo
|
||
|
ctx := clientcmdapi.NewContext()
|
||
|
ctx.AuthInfo = "authInfo"
|
||
|
ctx.Cluster = "cluster"
|
||
|
ctx.Namespace = c.DefaultNamespace
|
||
|
cfg.Contexts["context"] = ctx
|
||
|
cfg.CurrentContext = "context"
|
||
|
return clientcmd.NewDefaultClientConfig(*cfg, &clientcmd.ConfigOverrides{})
|
||
|
}
|
||
|
|
||
5 years ago
|
// ResolveDefault returns endpoint metadata for the default Kubernetes
|
||
|
// endpoint, which is derived from the env-based kubeconfig.
|
||
3 years ago
|
func (c *EndpointMeta) ResolveDefault() (interface{}, *store.EndpointTLSData, error) {
|
||
5 years ago
|
kubeconfig := os.Getenv("KUBECONFIG")
|
||
|
if kubeconfig == "" {
|
||
|
kubeconfig = filepath.Join(homedir.Get(), ".kube/config")
|
||
|
}
|
||
|
kubeEP, err := FromKubeConfig(kubeconfig, "", "")
|
||
|
if err != nil {
|
||
|
// We deliberately quash the error here, returning nil
|
||
|
// for the first argument is sufficient to indicate we weren't able to
|
||
|
// provide a default
|
||
|
return nil, nil, nil
|
||
|
}
|
||
|
var tls *store.EndpointTLSData
|
||
|
if kubeEP.TLSData != nil {
|
||
|
tls = kubeEP.TLSData.ToStoreTLSData()
|
||
|
}
|
||
|
return kubeEP.EndpointMeta, tls, nil
|
||
|
}
|
||
|
|
||
6 years ago
|
// EndpointFromContext extracts kubernetes endpoint info from current context
|
||
6 years ago
|
func EndpointFromContext(metadata store.Metadata) *EndpointMeta {
|
||
6 years ago
|
ep, ok := metadata.Endpoints[KubernetesEndpoint]
|
||
|
if !ok {
|
||
|
return nil
|
||
|
}
|
||
|
typed, ok := ep.(EndpointMeta)
|
||
|
if !ok {
|
||
|
return nil
|
||
|
}
|
||
|
return &typed
|
||
|
}
|
||
|
|
||
|
// ConfigFromContext resolves a kubernetes client config for the specified context.
|
||
|
// If kubeconfigOverride is specified, use this config file instead of the context defaults.ConfigFromContext
|
||
|
// if command.ContextDockerHost is specified as the context name, fallsback to the default user's kubeconfig file
|
||
6 years ago
|
func ConfigFromContext(name string, s store.Reader) (clientcmd.ClientConfig, error) {
|
||
|
ctxMeta, err := s.GetMetadata(name)
|
||
6 years ago
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
epMeta := EndpointFromContext(ctxMeta)
|
||
|
if epMeta != nil {
|
||
|
ep, err := epMeta.WithTLSData(s, name)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ep.KubernetesConfig(), nil
|
||
|
}
|
||
|
// context has no kubernetes endpoint
|
||
3 years ago
|
return NewKubernetesConfig(""), nil
|
||
|
}
|
||
|
|
||
|
// NewKubernetesConfig resolves the path to the desired Kubernetes configuration
|
||
|
// file based on the KUBECONFIG environment variable and command line flags.
|
||
|
func NewKubernetesConfig(configPath string) clientcmd.ClientConfig {
|
||
|
kubeConfig := configPath
|
||
|
if kubeConfig == "" {
|
||
|
if config := os.Getenv("KUBECONFIG"); config != "" {
|
||
|
kubeConfig = config
|
||
|
} else {
|
||
|
kubeConfig = filepath.Join(homedir.Get(), ".kube/config")
|
||
|
}
|
||
|
}
|
||
|
return clientcmd.NewNonInteractiveDeferredLoadingClientConfig(
|
||
|
&clientcmd.ClientConfigLoadingRules{ExplicitPath: kubeConfig},
|
||
|
&clientcmd.ConfigOverrides{})
|
||
6 years ago
|
}
|