123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- package system
- import (
- "runtime"
- "time"
- "golang.org/x/net/context"
- "github.com/docker/docker/api/client"
- "github.com/docker/docker/cli"
- "github.com/docker/docker/dockerversion"
- "github.com/docker/docker/utils"
- "github.com/docker/docker/utils/templates"
- "github.com/docker/engine-api/types"
- "github.com/spf13/cobra"
- )
- var versionTemplate = `Client:
- Version: {{.Client.Version}}
- API version: {{.Client.APIVersion}}
- Go version: {{.Client.GoVersion}}
- Git commit: {{.Client.GitCommit}}
- Built: {{.Client.BuildTime}}
- OS/Arch: {{.Client.Os}}/{{.Client.Arch}}{{if .Client.Experimental}}
- Experimental: {{.Client.Experimental}}{{end}}{{if .ServerOK}}
- Server:
- Version: {{.Server.Version}}
- API version: {{.Server.APIVersion}}
- Go version: {{.Server.GoVersion}}
- Git commit: {{.Server.GitCommit}}
- Built: {{.Server.BuildTime}}
- OS/Arch: {{.Server.Os}}/{{.Server.Arch}}{{if .Server.Experimental}}
- Experimental: {{.Server.Experimental}}{{end}}{{end}}`
- type versionOptions struct {
- format string
- }
- // NewVersionCommand creates a new cobra.Command for `docker version`
- func NewVersionCommand(dockerCli *client.DockerCli) *cobra.Command {
- var opts versionOptions
- cmd := &cobra.Command{
- Use: "version [OPTIONS]",
- Short: "Show the Docker version information",
- Args: cli.NoArgs,
- RunE: func(cmd *cobra.Command, args []string) error {
- return runVersion(dockerCli, &opts)
- },
- }
- flags := cmd.Flags()
- flags.StringVarP(&opts.format, "format", "f", "", "Format the output using the given go template")
- return cmd
- }
- func runVersion(dockerCli *client.DockerCli, opts *versionOptions) error {
- ctx := context.Background()
- templateFormat := versionTemplate
- if opts.format != "" {
- templateFormat = opts.format
- }
- tmpl, err := templates.Parse(templateFormat)
- if err != nil {
- return cli.StatusError{StatusCode: 64,
- Status: "Template parsing error: " + err.Error()}
- }
- vd := types.VersionResponse{
- Client: &types.Version{
- Version: dockerversion.Version,
- APIVersion: dockerCli.Client().ClientVersion(),
- GoVersion: runtime.Version(),
- GitCommit: dockerversion.GitCommit,
- BuildTime: dockerversion.BuildTime,
- Os: runtime.GOOS,
- Arch: runtime.GOARCH,
- Experimental: utils.ExperimentalBuild(),
- },
- }
- serverVersion, err := dockerCli.Client().ServerVersion(ctx)
- if err == nil {
- vd.Server = &serverVersion
- }
- // first we need to make BuildTime more human friendly
- t, errTime := time.Parse(time.RFC3339Nano, vd.Client.BuildTime)
- if errTime == nil {
- vd.Client.BuildTime = t.Format(time.ANSIC)
- }
- if vd.ServerOK() {
- t, errTime = time.Parse(time.RFC3339Nano, vd.Server.BuildTime)
- if errTime == nil {
- vd.Server.BuildTime = t.Format(time.ANSIC)
- }
- }
- if err2 := tmpl.Execute(dockerCli.Out(), vd); err2 != nil && err == nil {
- err = err2
- }
- dockerCli.Out().Write([]byte{'\n'})
- return err
- }
|