|
|
@ -17,15 +17,11 @@ limitations under the License.
|
|
|
|
package main
|
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
|
|
|
|
"fmt"
|
|
|
|
"fmt"
|
|
|
|
"io"
|
|
|
|
"io"
|
|
|
|
|
|
|
|
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
|
|
|
|
"google.golang.org/grpc/codes"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
apiVersion "k8s.io/apimachinery/pkg/version"
|
|
|
|
|
|
|
|
"k8s.io/helm/pkg/helm"
|
|
|
|
"k8s.io/helm/pkg/helm"
|
|
|
|
pb "k8s.io/helm/pkg/proto/hapi/version"
|
|
|
|
pb "k8s.io/helm/pkg/proto/hapi/version"
|
|
|
|
"k8s.io/helm/pkg/version"
|
|
|
|
"k8s.io/helm/pkg/version"
|
|
|
@ -50,41 +46,23 @@ use '--server'.
|
|
|
|
`
|
|
|
|
`
|
|
|
|
|
|
|
|
|
|
|
|
type versionCmd struct {
|
|
|
|
type versionCmd struct {
|
|
|
|
out io.Writer
|
|
|
|
out io.Writer
|
|
|
|
client helm.Interface
|
|
|
|
short bool
|
|
|
|
showClient bool
|
|
|
|
template string
|
|
|
|
showServer bool
|
|
|
|
|
|
|
|
short bool
|
|
|
|
|
|
|
|
template string
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func newVersionCmd(c helm.Interface, out io.Writer) *cobra.Command {
|
|
|
|
func newVersionCmd(c helm.Interface, out io.Writer) *cobra.Command {
|
|
|
|
version := &versionCmd{
|
|
|
|
version := &versionCmd{out: out}
|
|
|
|
client: c,
|
|
|
|
|
|
|
|
out: out,
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cmd := &cobra.Command{
|
|
|
|
cmd := &cobra.Command{
|
|
|
|
Use: "version",
|
|
|
|
Use: "version",
|
|
|
|
Short: "print the client/server version information",
|
|
|
|
Short: "print the client version information",
|
|
|
|
Long: versionDesc,
|
|
|
|
Long: versionDesc,
|
|
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
|
|
// If neither is explicitly set, show both.
|
|
|
|
|
|
|
|
if !version.showClient && !version.showServer {
|
|
|
|
|
|
|
|
version.showClient, version.showServer = true, true
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if version.showServer {
|
|
|
|
|
|
|
|
// We do this manually instead of in PreRun because we only
|
|
|
|
|
|
|
|
// need a tunnel if server version is requested.
|
|
|
|
|
|
|
|
setupConnection()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
version.client = ensureHelmClient(version.client)
|
|
|
|
|
|
|
|
return version.run()
|
|
|
|
return version.run()
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
f := cmd.Flags()
|
|
|
|
f := cmd.Flags()
|
|
|
|
f.BoolVarP(&version.showClient, "client", "c", false, "client version only")
|
|
|
|
|
|
|
|
f.BoolVarP(&version.showServer, "server", "s", false, "server version only")
|
|
|
|
|
|
|
|
f.BoolVar(&version.short, "short", false, "print the version number")
|
|
|
|
f.BoolVar(&version.short, "short", false, "print the version number")
|
|
|
|
f.StringVar(&version.template, "template", "", "template for version string format")
|
|
|
|
f.StringVar(&version.template, "template", "", "template for version string format")
|
|
|
|
|
|
|
|
|
|
|
@ -95,52 +73,13 @@ func (v *versionCmd) run() error {
|
|
|
|
// Store map data for template rendering
|
|
|
|
// Store map data for template rendering
|
|
|
|
data := map[string]interface{}{}
|
|
|
|
data := map[string]interface{}{}
|
|
|
|
|
|
|
|
|
|
|
|
if v.showClient {
|
|
|
|
cv := version.GetVersionProto()
|
|
|
|
cv := version.GetVersionProto()
|
|
|
|
|
|
|
|
if v.template != "" {
|
|
|
|
|
|
|
|
data["Client"] = cv
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
fmt.Fprintf(v.out, "Client: %s\n", formatVersion(cv, v.short))
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if !v.showServer {
|
|
|
|
|
|
|
|
return tpl(v.template, data, v.out)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if settings.Debug {
|
|
|
|
|
|
|
|
k8sVersion, err := getK8sVersion()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return err
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
fmt.Fprintf(v.out, "Kubernetes: %#v\n", k8sVersion)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
resp, err := v.client.GetVersion()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
if grpc.Code(err) == codes.Unimplemented {
|
|
|
|
|
|
|
|
return errors.New("server is too old to know its version")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
debug("%s", err)
|
|
|
|
|
|
|
|
return errors.New("cannot connect to Tiller")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if v.template != "" {
|
|
|
|
if v.template != "" {
|
|
|
|
data["Server"] = resp.Version
|
|
|
|
data["Client"] = cv
|
|
|
|
} else {
|
|
|
|
return tpl(v.template, data, v.out)
|
|
|
|
fmt.Fprintf(v.out, "Server: %s\n", formatVersion(resp.Version, v.short))
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return tpl(v.template, data, v.out)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func getK8sVersion() (*apiVersion.Info, error) {
|
|
|
|
|
|
|
|
var v *apiVersion.Info
|
|
|
|
|
|
|
|
_, client, err := getKubeClient(settings.KubeContext)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return v, err
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
v, err = client.Discovery().ServerVersion()
|
|
|
|
fmt.Fprintf(v.out, "Client: %s\n", formatVersion(cv, v.short))
|
|
|
|
return v, err
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func formatVersion(v *pb.Version, short bool) string {
|
|
|
|
func formatVersion(v *pb.Version, short bool) string {
|
|
|
|