|
@@ -40,8 +40,8 @@ func (cli *DockerCli) getMethod(name string) (reflect.Method, bool) {
|
|
|
return reflect.TypeOf(cli).MethodByName(methodName)
|
|
|
}
|
|
|
|
|
|
-func ParseCommands(addr string, port int, args ...string) error {
|
|
|
- cli := NewDockerCli(addr, port)
|
|
|
+func ParseCommands(proto, addr string, args ...string) error {
|
|
|
+ cli := NewDockerCli(proto, addr)
|
|
|
|
|
|
if len(args) > 0 {
|
|
|
method, exists := cli.getMethod(args[0])
|
|
@@ -74,7 +74,7 @@ func (cli *DockerCli) CmdHelp(args ...string) error {
|
|
|
return nil
|
|
|
}
|
|
|
}
|
|
|
- help := fmt.Sprintf("Usage: docker [OPTIONS] COMMAND [arg...]\n -H=\"%s:%d\": Host:port to bind/connect to\n\nA self-sufficient runtime for linux containers.\n\nCommands:\n", cli.host, cli.port)
|
|
|
+ help := fmt.Sprintf("Usage: docker [OPTIONS] COMMAND [arg...]\n -H=[tcp://%s:%d]: tcp://host:port to bind/connect to or unix://path/to/socker to use\n\nA self-sufficient runtime for linux containers.\n\nCommands:\n", DEFAULTHTTPHOST, DEFAULTHTTPPORT)
|
|
|
for _, command := range [][2]string{
|
|
|
{"attach", "Attach to a running container"},
|
|
|
{"build", "Build a container from a Dockerfile"},
|
|
@@ -197,7 +197,7 @@ func (cli *DockerCli) CmdBuild(args ...string) error {
|
|
|
v := &url.Values{}
|
|
|
v.Set("t", *tag)
|
|
|
// Send the multipart request with correct content-type
|
|
|
- req, err := http.NewRequest("POST", fmt.Sprintf("http://%s:%d%s?%s", cli.host, cli.port, "/build", v.Encode()), multipartBody)
|
|
|
+ req, err := http.NewRequest("POST", fmt.Sprintf("/v%s/build?%s", APIVERSION, v.Encode()), multipartBody)
|
|
|
if err != nil {
|
|
|
return err
|
|
|
}
|
|
@@ -206,8 +206,13 @@ func (cli *DockerCli) CmdBuild(args ...string) error {
|
|
|
req.Header.Set("X-Docker-Context-Compression", compression.Flag())
|
|
|
fmt.Println("Uploading Context...")
|
|
|
}
|
|
|
-
|
|
|
- resp, err := http.DefaultClient.Do(req)
|
|
|
+ dial, err := net.Dial(cli.proto, cli.addr)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+ clientconn := httputil.NewClientConn(dial, nil)
|
|
|
+ resp, err := clientconn.Do(req)
|
|
|
+ defer clientconn.Close()
|
|
|
if err != nil {
|
|
|
return err
|
|
|
}
|
|
@@ -1302,7 +1307,7 @@ func (cli *DockerCli) call(method, path string, data interface{}) ([]byte, int,
|
|
|
params = bytes.NewBuffer(buf)
|
|
|
}
|
|
|
|
|
|
- req, err := http.NewRequest(method, fmt.Sprintf("http://%s:%d/v%g%s", cli.host, cli.port, APIVERSION, path), params)
|
|
|
+ req, err := http.NewRequest(method, fmt.Sprintf("/v%g%s", APIVERSION, path), params)
|
|
|
if err != nil {
|
|
|
return nil, -1, err
|
|
|
}
|
|
@@ -1312,7 +1317,13 @@ func (cli *DockerCli) call(method, path string, data interface{}) ([]byte, int,
|
|
|
} else if method == "POST" {
|
|
|
req.Header.Set("Content-Type", "plain/text")
|
|
|
}
|
|
|
- resp, err := http.DefaultClient.Do(req)
|
|
|
+ dial, err := net.Dial(cli.proto, cli.addr)
|
|
|
+ if err != nil {
|
|
|
+ return nil, -1, err
|
|
|
+ }
|
|
|
+ clientconn := httputil.NewClientConn(dial, nil)
|
|
|
+ resp, err := clientconn.Do(req)
|
|
|
+ defer clientconn.Close()
|
|
|
if err != nil {
|
|
|
if strings.Contains(err.Error(), "connection refused") {
|
|
|
return nil, -1, fmt.Errorf("Can't connect to docker daemon. Is 'docker -d' running on this host?")
|
|
@@ -1337,7 +1348,7 @@ func (cli *DockerCli) stream(method, path string, in io.Reader, out io.Writer) e
|
|
|
if (method == "POST" || method == "PUT") && in == nil {
|
|
|
in = bytes.NewReader([]byte{})
|
|
|
}
|
|
|
- req, err := http.NewRequest(method, fmt.Sprintf("http://%s:%d/v%g%s", cli.host, cli.port, APIVERSION, path), in)
|
|
|
+ req, err := http.NewRequest(method, fmt.Sprintf("/v%g%s", APIVERSION, path), in)
|
|
|
if err != nil {
|
|
|
return err
|
|
|
}
|
|
@@ -1345,7 +1356,13 @@ func (cli *DockerCli) stream(method, path string, in io.Reader, out io.Writer) e
|
|
|
if method == "POST" {
|
|
|
req.Header.Set("Content-Type", "plain/text")
|
|
|
}
|
|
|
- resp, err := http.DefaultClient.Do(req)
|
|
|
+ dial, err := net.Dial(cli.proto, cli.addr)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+ clientconn := httputil.NewClientConn(dial, nil)
|
|
|
+ resp, err := clientconn.Do(req)
|
|
|
+ defer clientconn.Close()
|
|
|
if err != nil {
|
|
|
if strings.Contains(err.Error(), "connection refused") {
|
|
|
return fmt.Errorf("Can't connect to docker daemon. Is 'docker -d' running on this host?")
|
|
@@ -1395,7 +1412,7 @@ func (cli *DockerCli) hijack(method, path string, setRawTerminal bool, in *os.Fi
|
|
|
return err
|
|
|
}
|
|
|
req.Header.Set("Content-Type", "plain/text")
|
|
|
- dial, err := net.Dial("tcp", fmt.Sprintf("%s:%d", cli.host, cli.port))
|
|
|
+ dial, err := net.Dial(cli.proto, cli.addr)
|
|
|
if err != nil {
|
|
|
return err
|
|
|
}
|
|
@@ -1478,13 +1495,13 @@ func Subcmd(name, signature, description string) *flag.FlagSet {
|
|
|
return flags
|
|
|
}
|
|
|
|
|
|
-func NewDockerCli(addr string, port int) *DockerCli {
|
|
|
+func NewDockerCli(proto, addr string) *DockerCli {
|
|
|
authConfig, _ := auth.LoadConfig(os.Getenv("HOME"))
|
|
|
- return &DockerCli{addr, port, authConfig}
|
|
|
+ return &DockerCli{proto, addr, authConfig}
|
|
|
}
|
|
|
|
|
|
type DockerCli struct {
|
|
|
- host string
|
|
|
- port int
|
|
|
+ proto string
|
|
|
+ addr string
|
|
|
authConfig *auth.AuthConfig
|
|
|
}
|