Sha256: bbc818fbb8f3120ab8cccc65600909d4d5e1c7f4da7a7b3a100eae0a14859c6e

Contents?: true

Size: 1.98 KB

Versions: 1

Compression:

Stored size: 1.98 KB

Contents

require "log4r"

module VagrantPlugins
  module MCS
    module Action
      # This action reads the SSH info for the machine and puts it into the
      # `:machine_ssh_info` key in the environment.
      class ReadSSHInfo
        def initialize(app, env)
          @app = app
          @logger = Log4r::Logger.new("vagrant_mcs::action::read_ssh_info")
        end

        def call(env)
          env[:machine_ssh_info] = read_ssh_info(env[:mcs_compute], env[:machine])

          @app.call(env)
        end

        def read_ssh_info(mcs, machine)
          return nil if machine.id.nil?

          # Find the machine
          puts "machine id: #{machine.id}"
          server = mcs.describe_instances(machine.id)
          #server = mcs.servers.get(machine.id)
          if server.nil?
            # The machine can't be found
            @logger.info("Machine couldn't be found, assuming it got destroyed.")
            machine.id = nil
            return nil
          end

          # read attribute override
          ssh_host_attribute = machine.provider_config.
              get_region_config(machine.provider_config.region).ssh_host_attribute
          # default host attributes to try. NOTE: Order matters!
          ssh_attrs = [:public_ip_address, :dns_name, :private_ip_address]
          ssh_attrs = (Array(ssh_host_attribute) + ssh_attrs).uniq if ssh_host_attribute
          # try each attribute, get out on first value
          host_value = nil
          puts server
          while !host_value and attr_name = ssh_attrs.shift
            begin
              host_value = server.send(attr_name)
            rescue NoMethodError
              @logger.info("SSH host attribute not found #{attr_name}")
            end
          end
          #puts 2

          if !host_value
            host_value = server["ipAddresses"]
          end
          #puts server["ipAddresses"]
          #puts host_value
          #puts 3
          return {:host => host_value, :port => 22}
        end
      end
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
vagrant-mcs-0.8.5 lib/vagrant-mcs/action/read_ssh_info.rb