Skip to content
This repository was archived by the owner on May 28, 2023. It is now read-only.
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions dockermachine.go
Original file line number Diff line number Diff line change
Expand Up @@ -60,20 +60,20 @@ func RunSSHCommand(machineName, command string, verbose bool) (out []byte, err e
return Exec("docker-machine", "ssh", machineName, command).CombinedOutput()
}

func GetSSHCredentials(machineName string) (creds SSHCredentials, err error) {
func GetSSHCredentials(machineName string, guestport uint) (creds SSHCredentials, err error) {
out, err := Exec("docker-machine", "inspect", "--format='{{json .Driver}}'", machineName).CombinedOutput()
if err != nil {
return SSHCredentials{}, err
}

return CredentialsFromMachineJSON(out)
return CredentialsFromMachineJSON(out, guestport)
}

func CredentialsFromMachineJSON(jsonData []byte) (creds SSHCredentials, err error) {
func CredentialsFromMachineJSON(jsonData []byte, guestport uint) (creds SSHCredentials, err error) {
var v SSHCredentials
if err := json.Unmarshal(jsonData, &v); err != nil {
return SSHCredentials{}, err
}
v.SSHGuestPort = uint(22) // assume that this is the default SSH port
v.SSHGuestPort = uint(guestport)
return v, nil
}
3 changes: 2 additions & 1 deletion main.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ func main() {
var verbose = flag.Bool("verbose", false, "Verbose output")
var srcpath = flag.String("src", pwd, "Source directory")
var dstpath = flag.String("dst", pathpkg.Join("/rsync", pwd), "Destination directory")
var guestport = flag.Uint("guestport", 22, "SSH Guest Port for docker-machine")

flag.Parse()

Expand Down Expand Up @@ -75,7 +76,7 @@ func main() {
// use rsync via ssh
machineName := via

c, err := GetSSHCredentials(machineName)
c, err := GetSSHCredentials(machineName, *guestport)
if err != nil {
fmt.Printf("error: unable to get port for machine '%v': %v\n", machineName, err)
os.Exit(1)
Expand Down