From 9240ea30b64532f6f82c237edbbb6e80b8009d42 Mon Sep 17 00:00:00 2001 From: Marc Abramowitz Date: Wed, 1 Jul 2015 23:33:13 -0700 Subject: [PATCH] Add setting config.ssh.ssh_command Lets the user specify what ssh to use or even direct Vagrant to use an ssh wrapper like sshrc (https://github.com/Russell91/sshrc). --- lib/vagrant/machine.rb | 2 ++ lib/vagrant/util/ssh.rb | 11 +++++++---- plugins/commands/ssh_config/command.rb | 3 ++- plugins/kernel_v2/config/ssh.rb | 3 +++ 4 files changed, 14 insertions(+), 5 deletions(-) diff --git a/lib/vagrant/machine.rb b/lib/vagrant/machine.rb index 03ca19f07..0e1756f01 100644 --- a/lib/vagrant/machine.rb +++ b/lib/vagrant/machine.rb @@ -429,6 +429,8 @@ module Vagrant info[:forward_agent] = @config.ssh.forward_agent info[:forward_x11] = @config.ssh.forward_x11 + info[:ssh_command] = @config.ssh.ssh_command if @config.ssh.ssh_command + # Add in provided proxy command config info[:proxy_command] = @config.ssh.proxy_command if @config.ssh.proxy_command diff --git a/lib/vagrant/util/ssh.rb b/lib/vagrant/util/ssh.rb index 586c66c6d..8dd614534 100644 --- a/lib/vagrant/util/ssh.rb +++ b/lib/vagrant/util/ssh.rb @@ -158,17 +158,20 @@ module Vagrant # we really don't care since both work. ENV["nodosfilewarning"] = "1" if Platform.cygwin? + ssh = ssh_info[:ssh_command] || 'ssh' + # Invoke SSH with all our options if !opts[:subprocess] - LOGGER.info("Invoking SSH: #{command_options.inspect}") - SafeExec.exec("ssh", *command_options) + LOGGER.info("Invoking SSH: #{ssh} #{command_options.inspect}") + # msabramo + SafeExec.exec(ssh, *command_options) return end # If we're still here, it means we're supposed to subprocess # out to ssh rather than exec it. - LOGGER.info("Executing SSH in subprocess: #{command_options.inspect}") - process = ChildProcess.build("ssh", *command_options) + LOGGER.info("Executing SSH in subprocess: #{ssh} #{command_options.inspect}") + process = ChildProcess.build(ssh, *command_options) process.io.inherit! process.start process.wait diff --git a/plugins/commands/ssh_config/command.rb b/plugins/commands/ssh_config/command.rb index e534b7182..6013a90b7 100644 --- a/plugins/commands/ssh_config/command.rb +++ b/plugins/commands/ssh_config/command.rb @@ -40,7 +40,8 @@ module VagrantPlugins private_key_path: ssh_info[:private_key_path], forward_agent: ssh_info[:forward_agent], forward_x11: ssh_info[:forward_x11], - proxy_command: ssh_info[:proxy_command] + proxy_command: ssh_info[:proxy_command], + ssh_command: ssh_info[:ssh_command] } # Render the template and output directly to STDOUT diff --git a/plugins/kernel_v2/config/ssh.rb b/plugins/kernel_v2/config/ssh.rb index 4040e228b..60b9924b4 100644 --- a/plugins/kernel_v2/config/ssh.rb +++ b/plugins/kernel_v2/config/ssh.rb @@ -11,6 +11,7 @@ module VagrantPlugins attr_accessor :keep_alive attr_accessor :shell attr_accessor :proxy_command + attr_accessor :ssh_command attr_accessor :pty attr_reader :default @@ -23,6 +24,7 @@ module VagrantPlugins @guest_port = UNSET_VALUE @keep_alive = UNSET_VALUE @proxy_command = UNSET_VALUE + @ssh_command = UNSET_VALUE @pty = UNSET_VALUE @shell = UNSET_VALUE @@ -44,6 +46,7 @@ module VagrantPlugins @guest_port = 22 if @guest_port == UNSET_VALUE @keep_alive = true if @keep_alive == UNSET_VALUE @proxy_command = nil if @proxy_command == UNSET_VALUE + @ssh_command = nil if @ssh_command == UNSET_VALUE @pty = false if @pty == UNSET_VALUE @shell = "bash -l" if @shell == UNSET_VALUE