Sha256: a6d2ea14ccb774bef7d294724b2959290ca0f056a72e7b2f4710dbd2f89cab15

Contents?: true

Size: 1.67 KB

Versions: 37

Compression:

Stored size: 1.67 KB

Contents

require "base64"
require "openssl"

require "vagrant/util/retryable"

module Vagrant
  module Util
    class Keypair
      extend Retryable

      # Creates an SSH keypair and returns it.
      #
      # @param [String] password Password for the key, or nil for no password.
      # @return [Array<String, String, String>] PEM-encoded public and private key,
      #   respectively. The final element is the OpenSSH encoded public
      #   key.
      def self.create(password=nil)
        # This sometimes fails with RSAError. It is inconsistent and strangely
        # sleeps seem to fix it. We just retry this a few times. See GH-5056
        rsa_key = nil
        retryable(on: OpenSSL::PKey::RSAError, sleep: 2, tries: 5) do
          rsa_key = OpenSSL::PKey::RSA.new(2048)
        end

        public_key  = rsa_key.public_key
        private_key = rsa_key.to_pem

        if password
          cipher      = OpenSSL::Cipher.new('des3')
          private_key = rsa_key.to_pem(cipher, password)
        end

        # Generate the binary necessary for the OpenSSH public key.
        binary = [7].pack("N")
        binary += "ssh-rsa"
        ["e", "n"].each do |m|
          val  = public_key.send(m)
          data = val.to_s(2)

          first_byte = data[0,1].unpack("c").first
          if val < 0
            data[0] = [0x80 & first_byte].pack("c")
          elsif first_byte < 0
            data = 0.chr + data
          end

          binary += [data.length].pack("N") + data
        end

        openssh_key = "ssh-rsa #{Base64.encode64(binary).gsub("\n", "")} vagrant"
        public_key  = public_key.to_pem
        return [public_key, private_key, openssh_key]
      end
    end
  end
end

Version data entries

37 entries across 33 versions & 5 rubygems

Version Path
vagrant-unbundled-2.3.6.0 lib/vagrant/util/keypair.rb
tamtam-vagrant-reload-1.2.1 vendor/cache/vagrant-2092df529ae7/lib/vagrant/util/keypair.rb
vagrant-unbundled-2.3.3.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.3.2.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.19.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.18.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.16.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.14.0 lib/vagrant/util/keypair.rb
vagrant-aws-mkubenka-0.7.2.pre.24 vendor/bundle/ruby/2.7.0/bundler/gems/vagrant-22795b161bf6/lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.10.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.9.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.8.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.7.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.6.2 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.6.1 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.6.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.5.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.4.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.3.0 lib/vagrant/util/keypair.rb
vagrant-unbundled-2.2.2.0 lib/vagrant/util/keypair.rb