/
kubeconfig.go
101 lines (88 loc) · 2.51 KB
/
kubeconfig.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/*
Copyright 2019 The Kubernetes Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// Package kubeconfig implements the `kubeconfig` command
package kubeconfig
import (
"io"
"os"
"github.com/pkg/errors"
"github.com/spf13/cobra"
"sigs.k8s.io/kind/pkg/cluster"
clusternodes "sigs.k8s.io/kind/pkg/cluster/nodes"
"sigs.k8s.io/kind/pkg/exec"
)
type flagpole struct {
Name string
Internal bool
}
// NewCommand returns a new cobra.Command for getting the kubeconfig with the internal node IP address
func NewCommand() *cobra.Command {
flags := &flagpole{}
cmd := &cobra.Command{
Args: cobra.NoArgs,
Use: "kubeconfig",
Short: "prints cluster kubeconfig",
Long: "prints cluster kubeconfig",
RunE: func(cmd *cobra.Command, args []string) error {
return runE(flags, cmd, args)
},
}
cmd.Flags().StringVar(
&flags.Name,
"name",
cluster.DefaultName,
"the cluster context name",
)
cmd.Flags().BoolVar(
&flags.Internal,
"internal",
false,
"use internal address instead of external",
)
return cmd
}
func runE(flags *flagpole, cmd *cobra.Command, args []string) error {
// List nodes by cluster context name
n, err := clusternodes.ListByCluster()
if err != nil {
return err
}
nodes, known := n[flags.Name]
if !known {
return errors.Errorf("unknown cluster %q", flags.Name)
}
// get the bootstrap node to get the kubeconfig
node, err := clusternodes.BootstrapControlPlaneNode(nodes)
if err != nil {
return err
}
if flags.Internal {
// grab kubeconfig version from one of the control plane nodes
cmdNode := node.Command("cat", "/etc/kubernetes/admin.conf")
exec.InheritOutput(cmdNode)
if err := cmdNode.Run(); err != nil {
return errors.Wrap(err, "failed to get cluster internal kubeconfig")
}
return nil
}
ctx := cluster.NewContext(flags.Name)
f, err := os.Open(ctx.KubeConfigPath())
if err != nil {
return errors.Wrap(err, "failed to get cluster kubeconfig")
}
defer f.Close()
if _, err := io.Copy(os.Stdout, f); err != nil {
return errors.Wrap(err, "failed to copy kubeconfig")
}
return nil
}