Ansible: Support multiple private keys

Note that this feature requires to force `--connection=ssh`. This is not
a big deal as `paramiko` mode is deprecated and in most cases `smart`
mode enables `ssh` mode.
This commit is contained in:
Gilles Cornu 2014-02-10 10:23:10 +01:00
parent a62d28fd7f
commit ca1e30d405
1 changed files with 30 additions and 12 deletions

View File

@ -5,11 +5,10 @@ module VagrantPlugins
@logger = Log4r::Logger.new("vagrant::provisioners::ansible") @logger = Log4r::Logger.new("vagrant::provisioners::ansible")
ssh = @machine.ssh_info ssh = @machine.ssh_info
# Connect with Vagrant user (unless --user or --private-key are # Connect with Vagrant SSH identity, forcing 'ssh' ansible connection mode
# overidden by 'raw_arguments'). # as 'paramiko' mode cannot support multiple keys.
# # These default settings can be overridden by 'raw_arguments' option.
# TODO: multiple private key support options = %W[--connection=ssh --private-key=#{ssh[:private_key_path][0]} --user=#{ssh[:username]}]
options = %W[--private-key=#{ssh[:private_key_path][0]} --user=#{ssh[:username]}]
# By default we limit by the current machine. # By default we limit by the current machine.
# This can be overridden by the limit config option. # This can be overridden by the limit config option.
@ -33,15 +32,22 @@ module VagrantPlugins
# Assemble the full ansible-playbook command # Assemble the full ansible-playbook command
command = (%w(ansible-playbook) << options << config.playbook).flatten command = (%w(ansible-playbook) << options << config.playbook).flatten
# Write stdout and stderr data, since it's the regular Ansible output # Some Ansible options must be passed as environment variables
command << { env = {
:env => {
"ANSIBLE_FORCE_COLOR" => "true", "ANSIBLE_FORCE_COLOR" => "true",
"ANSIBLE_HOST_KEY_CHECKING" => "#{config.host_key_checking}", "ANSIBLE_HOST_KEY_CHECKING" => "#{config.host_key_checking}",
# Ensure Ansible output isn't buffered so that we receive ouput # Ensure Ansible output isn't buffered so that we receive ouput
# on a task-by-task basis. # on a task-by-task basis.
"PYTHONUNBUFFERED" => 1 "PYTHONUNBUFFERED" => 1
}, }
# Support Multiple SSH keys:
ansible_ssh_args = get_ansible_ssh_args
env["ANSIBLE_SSH_ARGS"] = ansible_ssh_args if !ansible_ssh_args.empty?
# Write stdout and stderr data, since it's the regular Ansible output
command << {
:env => env,
:notify => [:stdout, :stderr], :notify => [:stdout, :stderr],
:workdir => @machine.env.root_path.to_s :workdir => @machine.env.root_path.to_s
} }
@ -149,6 +155,18 @@ module VagrantPlugins
end end
end end
def get_ansible_ssh_args
ssh = @machine.ssh_info
ssh_options = []
# Multiple Private Keys
ssh[:private_key_path].drop(1).each do |key|
ssh_options << "-o IdentityFile=#{key}"
end
return ssh_options.join(' ')
end
def as_list_argument(v) def as_list_argument(v)
v.kind_of?(Array) ? v.join(',') : v v.kind_of?(Array) ? v.join(',') : v
end end