2014-08-01 13:34:06 -04:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2014-09-08 19:08:28 -04:00
|
|
|
"fmt"
|
2014-08-01 13:34:06 -04:00
|
|
|
"os"
|
|
|
|
"path/filepath"
|
2014-10-21 19:15:26 -04:00
|
|
|
"runtime"
|
2015-05-07 19:18:13 -04:00
|
|
|
"sort"
|
2014-08-01 13:34:06 -04:00
|
|
|
|
2014-08-11 18:30:01 -04:00
|
|
|
"github.com/docker/docker/opts"
|
2015-02-06 13:18:49 -05:00
|
|
|
"github.com/docker/docker/pkg/homedir"
|
2014-08-01 13:34:06 -04:00
|
|
|
flag "github.com/docker/docker/pkg/mflag"
|
|
|
|
)
|
|
|
|
|
2015-05-07 19:18:13 -04:00
|
|
|
type command struct {
|
|
|
|
name string
|
|
|
|
description string
|
|
|
|
}
|
|
|
|
|
|
|
|
type byName []command
|
|
|
|
|
|
|
|
func (a byName) Len() int { return len(a) }
|
|
|
|
func (a byName) Swap(i, j int) { a[i], a[j] = a[j], a[i] }
|
|
|
|
func (a byName) Less(i, j int) bool { return a[i].name < a[j].name }
|
|
|
|
|
2014-08-01 13:34:06 -04:00
|
|
|
var (
|
2014-10-10 11:02:04 -04:00
|
|
|
dockerCertPath = os.Getenv("DOCKER_CERT_PATH")
|
|
|
|
dockerTlsVerify = os.Getenv("DOCKER_TLS_VERIFY") != ""
|
2015-05-07 19:18:13 -04:00
|
|
|
|
|
|
|
dockerCommands = []command{
|
|
|
|
{"attach", "Attach to a running container"},
|
|
|
|
{"build", "Build an image from a Dockerfile"},
|
|
|
|
{"commit", "Create a new image from a container's changes"},
|
|
|
|
{"cp", "Copy files/folders from a container's filesystem to the host path"},
|
|
|
|
{"create", "Create a new container"},
|
|
|
|
{"diff", "Inspect changes on a container's filesystem"},
|
|
|
|
{"events", "Get real time events from the server"},
|
|
|
|
{"exec", "Run a command in a running container"},
|
|
|
|
{"export", "Stream the contents of a container as a tar archive"},
|
|
|
|
{"history", "Show the history of an image"},
|
|
|
|
{"images", "List images"},
|
|
|
|
{"import", "Create a new filesystem image from the contents of a tarball"},
|
|
|
|
{"info", "Display system-wide information"},
|
|
|
|
{"inspect", "Return low-level information on a container or image"},
|
|
|
|
{"kill", "Kill a running container"},
|
|
|
|
{"load", "Load an image from a tar archive"},
|
|
|
|
{"login", "Register or log in to a Docker registry server"},
|
|
|
|
{"logout", "Log out from a Docker registry server"},
|
|
|
|
{"logs", "Fetch the logs of a container"},
|
|
|
|
{"port", "Lookup the public-facing port that is NAT-ed to PRIVATE_PORT"},
|
|
|
|
{"pause", "Pause all processes within a container"},
|
|
|
|
{"ps", "List containers"},
|
|
|
|
{"pull", "Pull an image or a repository from a Docker registry server"},
|
|
|
|
{"push", "Push an image or a repository to a Docker registry server"},
|
|
|
|
{"rename", "Rename an existing container"},
|
|
|
|
{"restart", "Restart a running container"},
|
|
|
|
{"rm", "Remove one or more containers"},
|
|
|
|
{"rmi", "Remove one or more images"},
|
|
|
|
{"run", "Run a command in a new container"},
|
|
|
|
{"save", "Save an image to a tar archive"},
|
|
|
|
{"search", "Search for an image on the Docker Hub"},
|
|
|
|
{"start", "Start a stopped container"},
|
|
|
|
{"stats", "Display a stream of a containers' resource usage statistics"},
|
|
|
|
{"stop", "Stop a running container"},
|
|
|
|
{"tag", "Tag an image into a repository"},
|
|
|
|
{"top", "Lookup the running processes of a container"},
|
|
|
|
{"unpause", "Unpause a paused container"},
|
|
|
|
{"version", "Show the Docker version information"},
|
|
|
|
{"wait", "Block until a container stops, then print its exit code"},
|
|
|
|
}
|
2014-08-01 13:34:06 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
2014-08-04 20:17:23 -04:00
|
|
|
if dockerCertPath == "" {
|
2015-02-06 13:18:49 -05:00
|
|
|
dockerCertPath = filepath.Join(homedir.Get(), ".docker")
|
2014-08-01 13:34:06 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-21 11:14:30 -05:00
|
|
|
func getDaemonConfDir() string {
|
2015-01-22 13:29:15 -05:00
|
|
|
// TODO: update for Windows daemon
|
2015-01-21 11:14:30 -05:00
|
|
|
if runtime.GOOS == "windows" {
|
2015-02-06 13:18:49 -05:00
|
|
|
return filepath.Join(homedir.Get(), ".docker")
|
2015-01-21 11:14:30 -05:00
|
|
|
}
|
|
|
|
return "/etc/docker"
|
|
|
|
}
|
|
|
|
|
2014-08-01 13:34:06 -04:00
|
|
|
var (
|
2015-01-29 21:55:22 -05:00
|
|
|
flVersion = flag.Bool([]string{"v", "-version"}, false, "Print version information and quit")
|
|
|
|
flDaemon = flag.Bool([]string{"d", "-daemon"}, false, "Enable daemon mode")
|
|
|
|
flDebug = flag.Bool([]string{"D", "-debug"}, false, "Enable debug mode")
|
|
|
|
flLogLevel = flag.String([]string{"l", "-log-level"}, "info", "Set the logging level")
|
2015-02-18 17:04:42 -05:00
|
|
|
flTls = flag.Bool([]string{"-tls"}, false, "Use TLS; implied by --tlsverify")
|
2015-01-29 21:55:22 -05:00
|
|
|
flHelp = flag.Bool([]string{"h", "-help"}, false, "Print usage")
|
|
|
|
flTlsVerify = flag.Bool([]string{"-tlsverify"}, dockerTlsVerify, "Use TLS and verify the remote")
|
2014-08-01 13:34:06 -04:00
|
|
|
|
2014-08-04 20:17:23 -04:00
|
|
|
// these are initialized in init() below since their default values depend on dockerCertPath which isn't fully initialized until init() runs
|
2014-09-26 17:24:04 -04:00
|
|
|
flTrustKey *string
|
|
|
|
flCa *string
|
|
|
|
flCert *string
|
|
|
|
flKey *string
|
|
|
|
flHosts []string
|
2014-08-01 13:34:06 -04:00
|
|
|
)
|
|
|
|
|
2015-01-21 11:14:30 -05:00
|
|
|
func setDefaultConfFlag(flag *string, def string) {
|
|
|
|
if *flag == "" {
|
|
|
|
if *flDaemon {
|
|
|
|
*flag = filepath.Join(getDaemonConfDir(), def)
|
|
|
|
} else {
|
2015-02-06 13:18:49 -05:00
|
|
|
*flag = filepath.Join(homedir.Get(), ".docker", def)
|
2015-01-21 11:14:30 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-01 13:34:06 -04:00
|
|
|
func init() {
|
2015-01-21 11:14:30 -05:00
|
|
|
var placeholderTrustKey string
|
|
|
|
// TODO use flag flag.String([]string{"i", "-identity"}, "", "Path to libtrust key file")
|
|
|
|
flTrustKey = &placeholderTrustKey
|
2014-09-26 17:24:04 -04:00
|
|
|
|
2015-02-03 22:51:35 -05:00
|
|
|
flCa = flag.String([]string{"-tlscacert"}, filepath.Join(dockerCertPath, defaultCaFile), "Trust certs signed only by this CA")
|
2014-08-04 20:17:23 -04:00
|
|
|
flCert = flag.String([]string{"-tlscert"}, filepath.Join(dockerCertPath, defaultCertFile), "Path to TLS certificate file")
|
|
|
|
flKey = flag.String([]string{"-tlskey"}, filepath.Join(dockerCertPath, defaultKeyFile), "Path to TLS key file")
|
2015-02-18 17:04:42 -05:00
|
|
|
opts.HostListVar(&flHosts, []string{"H", "-host"}, "Daemon socket(s) to connect to")
|
2014-09-08 19:08:28 -04:00
|
|
|
|
|
|
|
flag.Usage = func() {
|
2014-10-15 17:14:12 -04:00
|
|
|
fmt.Fprint(os.Stdout, "Usage: docker [OPTIONS] COMMAND [arg...]\n\nA self-sufficient runtime for linux containers.\n\nOptions:\n")
|
2014-09-08 19:08:28 -04:00
|
|
|
|
2014-10-15 17:14:12 -04:00
|
|
|
flag.CommandLine.SetOutput(os.Stdout)
|
2014-09-08 19:08:28 -04:00
|
|
|
flag.PrintDefaults()
|
|
|
|
|
|
|
|
help := "\nCommands:\n"
|
|
|
|
|
2015-05-07 19:18:13 -04:00
|
|
|
sort.Sort(byName(dockerCommands))
|
|
|
|
|
|
|
|
for _, cmd := range dockerCommands {
|
|
|
|
help += fmt.Sprintf(" %-10.10s%s\n", cmd.name, cmd.description)
|
2014-09-08 19:08:28 -04:00
|
|
|
}
|
2015-05-07 19:18:13 -04:00
|
|
|
|
2014-09-08 19:09:16 -04:00
|
|
|
help += "\nRun 'docker COMMAND --help' for more information on a command."
|
2014-10-15 17:14:12 -04:00
|
|
|
fmt.Fprintf(os.Stdout, "%s\n", help)
|
2014-09-08 19:08:28 -04:00
|
|
|
}
|
2014-08-01 13:34:06 -04:00
|
|
|
}
|