123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- package client
- import (
- "encoding/json"
- "runtime"
- "text/template"
- "time"
- "github.com/docker/docker/api"
- "github.com/docker/docker/api/types"
- Cli "github.com/docker/docker/cli"
- "github.com/docker/docker/dockerversion"
- flag "github.com/docker/docker/pkg/mflag"
- "github.com/docker/docker/utils"
- )
- 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 versionData struct {
- Client types.Version
- ServerOK bool
- Server types.Version
- }
- // CmdVersion shows Docker version information.
- //
- // Available version information is shown for: client Docker version, client API version, client Go version, client Git commit, client OS/Arch, server Docker version, server API version, server Go version, server Git commit, and server OS/Arch.
- //
- // Usage: docker version
- func (cli *DockerCli) CmdVersion(args ...string) (err error) {
- cmd := Cli.Subcmd("version", nil, Cli.DockerCommands["version"].Description, true)
- tmplStr := cmd.String([]string{"f", "#format", "-format"}, "", "Format the output using the given go template")
- cmd.Require(flag.Exact, 0)
- cmd.ParseFlags(args, true)
- if *tmplStr == "" {
- *tmplStr = versionTemplate
- }
- var tmpl *template.Template
- if tmpl, err = template.New("").Funcs(funcMap).Parse(*tmplStr); err != nil {
- return Cli.StatusError{StatusCode: 64,
- Status: "Template parsing error: " + err.Error()}
- }
- vd := versionData{
- Client: types.Version{
- Version: dockerversion.Version,
- APIVersion: api.Version,
- GoVersion: runtime.Version(),
- GitCommit: dockerversion.GitCommit,
- BuildTime: dockerversion.BuildTime,
- Os: runtime.GOOS,
- Arch: runtime.GOARCH,
- Experimental: utils.ExperimentalBuild(),
- },
- }
- defer func() {
- // 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)
- }
- t, errTime = time.Parse(time.RFC3339Nano, vd.Server.BuildTime)
- if errTime == nil {
- vd.Server.BuildTime = t.Format(time.ANSIC)
- }
- if err2 := tmpl.Execute(cli.out, vd); err2 != nil && err == nil {
- err = err2
- }
- cli.out.Write([]byte{'\n'})
- }()
- serverResp, err := cli.call("GET", "/version", nil, nil)
- if err != nil {
- return err
- }
- defer serverResp.body.Close()
- if err = json.NewDecoder(serverResp.body).Decode(&vd.Server); err != nil {
- return Cli.StatusError{StatusCode: 1,
- Status: "Error reading remote version: " + err.Error()}
- }
- vd.ServerOK = true
- return
- }
|