forked from boot2docker/boot2docker-cli
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig.go
213 lines (181 loc) · 7.77 KB
/
config.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
package main
import (
"bytes"
"fmt"
"net"
"os"
"path/filepath"
"regexp"
"runtime"
toml "github.com/BurntSushi/toml"
"github.com/boot2docker/boot2docker-cli/driver"
flag "github.com/ogier/pflag"
)
var (
// Pattern to parse a key=value line in config profile.
reFlagLine = regexp.MustCompile(`^\s*(\w+)\s*=\s*([^#;]+)`)
B2D = driver.MachineConfig{}
)
func homeDir() (string, error) {
dir := ""
// *nix and MSYS Windows
if dir = os.Getenv("HOME"); dir == "" {
// Windows (if not running under MSYS)
dir = os.Getenv("USERPROFILE")
}
if _, err := os.Stat(dir); err != nil {
return "", err
}
return dir, nil
}
func cfgDir(name string) (string, error) {
if name == ".boot2docker" {
if b2dDir := os.Getenv("BOOT2DOCKER_DIR"); b2dDir != "" {
return b2dDir, nil
}
}
dir, err := homeDir()
if err != nil {
return "", err
}
dir = filepath.Join(dir, name)
if err := os.MkdirAll(dir, 0755); err != nil {
return "", err
}
return dir, nil
}
func cfgFilename(dir string) string {
filename := os.Getenv("BOOT2DOCKER_PROFILE")
if filename == "" {
filename = filepath.Join(dir, "profile")
}
return filename
}
// Write configuration set by the combination of profile and flags
// Should result in a format that can be piped into a profile file
func printConfig() string {
var buf bytes.Buffer
e := toml.NewEncoder(&buf)
err := e.Encode(B2D)
if err != nil {
return ""
}
return buf.String()
}
// Read configuration from both profile and flags. Flags override profile.
func config() (*flag.FlagSet, error) {
dir, err := cfgDir(".boot2docker")
if err != nil {
return nil, fmt.Errorf("failed to get boot2docker directory: %s", err)
}
flags := flag.NewFlagSet(os.Args[0], flag.ContinueOnError)
flags.Usage = func() { usageLong(flags) }
driver.ConfigFlags(&B2D, flags)
// Add the generic flags
flags.StringVar(&B2D.VM, "vm", "boot2docker-vm", "virtual machine name.")
// removed for now, requires re-parsing a new config file which is too messy
//flags.StringVarP(&B2D.Dir, "dir", "d", dir, "boot2docker config directory.")
B2D.Dir = dir
flags.StringVar(&B2D.ISOURL, "iso-url", "https://api.github.com/repos/boot2docker/boot2docker/releases", "source URL to provision the boot2docker ISO image.")
flags.StringVar(&B2D.ISO, "iso", filepath.Join(dir, "boot2docker.iso"), "path to boot2docker ISO image.")
// clobber (overwrite client binary) by default on OSX. it's more likely that
// users have installed through package manager on Linux, and if so, they should
// upgrade that way.
flags.BoolVar(&B2D.Clobber, "clobber", (runtime.GOOS == "darwin"), "overwrite Docker client binary on boot2docker upgrade")
flags.BoolVar(&B2D.ForceUpgradeDownload, "force-upgrade-download", false, "always download on boot2docker upgrade, never skip")
// Sven disabled this, as it is broken - if I user with a fresh computer downloads
// just the boot2docker-cli, and then runs `boot2docker --init ip`, we create a vm
// which cannot run, because it fails to have have the boot2docker.iso and the ssh keys
B2D.Init = false
//flags.BoolVarP(&B2D.Init, "init", "i", false, "auto initialize vm instance.")
flags.BoolVarP(&B2D.Verbose, "verbose", "v", false, "display verbose command invocations.")
flags.StringVar(&B2D.Driver, "driver", "virtualbox", "hypervisor driver.")
flags.StringVar(&B2D.SSH, "ssh", "ssh", "path to SSH client utility.")
flags.StringVar(&B2D.SSHGen, "ssh-keygen", "ssh-keygen", "path to ssh-keygen utility.")
sshdir, _ := cfgDir(".ssh")
flags.StringVar(&B2D.SSHKey, "sshkey", filepath.Join(sshdir, "id_boot2docker"), "path to SSH key to use.")
flags.UintVarP(&B2D.DiskSize, "disksize", "s", 20000, "boot2docker disk image size (in MB).")
flags.UintVarP(&B2D.Memory, "memory", "m", 2048, "virtual machine memory size (in MB).")
flags.UintVarP(&B2D.CPUs, "cpus", "c", uint(runtime.NumCPU()), "number of CPUs for boot2docker.")
flags.Uint16Var(&B2D.SSHPort, "sshport", 2022, "host SSH port (forward to port 22 in VM).")
flags.Uint16Var(&B2D.DockerPort, "dockerport", 0, "host Docker port (forward to port 2376 in VM). (deprecated - use with care)")
flags.IPVar(&B2D.HostIP, "hostip", net.ParseIP("192.168.59.3"), "VirtualBox host-only network IP address.")
flags.IPMaskVar(&B2D.NetMask, "netmask", flag.ParseIPv4Mask("255.255.255.0"), "VirtualBox host-only network mask.")
flags.BoolVar(&B2D.DHCPEnabled, "dhcp", true, "enable VirtualBox host-only network DHCP.")
flags.IPVar(&B2D.DHCPIP, "dhcpip", net.ParseIP("192.168.59.99"), "VirtualBox host-only network DHCP server address.")
flags.IPVar(&B2D.LowerIP, "lowerip", net.ParseIP("192.168.59.103"), "VirtualBox host-only network DHCP lower bound.")
flags.IPVar(&B2D.UpperIP, "upperip", net.ParseIP("192.168.59.254"), "VirtualBox host-only network DHCP upper bound.")
flags.IntVar(&B2D.Waittime, "waittime", 300, "Time in milliseconds to wait between port knocking retries during 'start'")
flags.IntVar(&B2D.Retries, "retries", 75, "number of port knocking retries during 'start'")
if runtime.GOOS != "windows" {
//SerialFile ~~ filepath.Join(dir, B2D.vm+".sock")
flags.StringVar(&B2D.SerialFile, "serialfile", "", "path to the serial socket/pipe.")
flags.BoolVar(&B2D.Serial, "serial", false, "try serial console to get IP address (experimental)")
} else {
B2D.Serial = false
}
// Set the defaults
if err := flags.Parse([]string{}); err != nil {
return nil, err
}
// Over-ride from the profile file
filename := cfgFilename(B2D.Dir)
if _, err := os.Lstat(filename); err == nil {
if _, err := toml.DecodeFile(filename, &B2D); err != nil {
return nil, err
}
}
if B2D.SerialFile == "" {
if runtime.GOOS == "windows" {
//SerialFile ~~ filepath.Join(dir, B2D.vm+".sock")
B2D.SerialFile = `\\.\pipe\` + B2D.VM
} else {
B2D.SerialFile = filepath.Join(dir, B2D.VM+".sock")
}
}
// for cmd==ssh only:
// only pass the params up to and including the `ssh` command - after that,
// there might be other -flags that are destined for the ssh cmd
sshIdx := 1
for sshIdx < len(os.Args) && os.Args[sshIdx-1] != "ssh" {
sshIdx++
}
// Command-line overrides profile config.
if err := flags.Parse(os.Args[1:sshIdx]); err != nil {
return nil, err
}
leftovers := flags.Args()
if B2D.Verbose || (len(leftovers) > 0 && leftovers[0] == "version") {
fmt.Printf("Boot2Docker-cli version: %s\nGit commit: %s\n", Version, GitSHA)
}
return flags, nil
}
func usageShort() {
fmt.Fprintf(os.Stderr, "Usage: %s [<options>] {help|init|up|ssh|save|down|poweroff|reset|restart|config|status|info|ip|shellinit|delete|download|upgrade|version} [<args>]\n", os.Args[0])
}
func usageLong(flags *flag.FlagSet) {
// NOTE: the help message uses spaces, not tabs for indentation!
fmt.Fprintf(os.Stderr, `Usage: %s [<options>] <command> [<args>]
Boot2Docker management utility.
Commands:
init Create a new Boot2Docker VM.
up|start|boot Start VM from any states.
ssh [ssh-command] Login to VM via SSH.
save|suspend Suspend VM and save state to disk.
down|stop|halt Gracefully shutdown the VM.
restart Gracefully reboot the VM.
poweroff Forcefully power off the VM (may corrupt disk image).
reset Forcefully power cycle the VM (may corrupt disk image).
delete|destroy Delete Boot2Docker VM and its disk image.
config|cfg Show selected profile file settings.
info Display detailed information of VM.
ip Display the IP address of the VM's Host-only network.
shellinit Display the shell commands to set up the Docker client.
status Display current state of VM.
download Download Boot2Docker ISO image.
upgrade Upgrade the Boot2Docker ISO image (restart if running).
version Display version information.
Options:
`, os.Args[0])
flags.PrintDefaults()
}