Skip to content

Instantly share code, notes, and snippets.

@jschoolcraft
Forked from maxim/key_authorization.rb
Last active August 29, 2015 14:19
Show Gist options
  • Save jschoolcraft/f6eba5a2310cf516654e to your computer and use it in GitHub Desktop.
Save jschoolcraft/f6eba5a2310cf516654e to your computer and use it in GitHub Desktop.
def authorize_key_for_root(config, *key_paths)
[*key_paths, nil].each do |key_path|
if key_path.nil?
fail "Public key not found at following paths: #{key_paths.join(', ')}"
end
full_key_path = File.expand_path(key_path)
if File.exists?(full_key_path)
config.vm.provision 'file',
run: 'once',
source: full_key_path,
destination: '/home/vagrant/root_pubkey'
config.vm.provision 'shell',
privileged: true,
run: 'once',
inline:
"echo \"Creating /root/.ssh/authorized_keys with #{key_path}\" && " +
'rm -f /root/.ssh/authorized_keys && ' +
'mv /home/vagrant/root_pubkey /root/.ssh/authorized_keys && ' +
'chown root:root /root/.ssh/authorized_keys && ' +
'chmod 600 /root/.ssh/authorized_keys && ' +
'rm -f /home/vagrant/root_pubkey && ' +
'echo "Done!"'
break
end
end
end
@jschoolcraft
Copy link
Author

From: http://hakunin.com/six-ansible-practices

Then used like:

require_relative './vagrant/key_authorization'

Vagrant.configure('2') do |config|
  config.vm.box = 'ubuntu/trusty64'
  authorize_key_for_root config, '~/.ssh/id_dsa.pub', '~/.ssh/id_rsa.pub'

This sets up root with your authorized_key so you can ssh and then ansible ansible-playbook normally

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment