Sha256: fedf48b38b49b1314f9af395ac2f14325548a70563a61d68d9c31eacbda2e52b

Contents?: true

Size: 1.13 KB

Versions: 9

Compression:

Stored size: 1.13 KB

Contents

require "log4r"

module VagrantPlugins
  module MCS
    module Action
      # This action reads the state of the machine and puts it in the
      # `:machine_state_id` key in the environment.
      class ReadState
        def initialize(app, env)
          @app    = app
          @logger = Log4r::Logger.new("vagrant_mcs::action::read_state")
        end

        def call(env)
          env[:machine_state_id] = read_state(env[:mcs_compute], env[:machine])

          @app.call(env)
        end

        def read_state(mcs, machine)
          return :not_created if machine.id.nil?

          # Find the machine
          #puts mcs
          #puts machine.id
          server = mcs.describe_instances(machine.id)
          #server = mcs.servers.get(machine.id)
          if server.nil? || [:"shutting-down", :terminated].include?(server["status"])
            # The machine can't be found
            @logger.info("Machine not found or terminated, assuming it got destroyed.")
            machine.id = nil
            return :not_created
          end

          # Return the state
          return server["status"]
        end
      end
    end
  end
end

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
vagrant-mcs-0.8.1 lib/vagrant-mcs/action/read_state.rb
vagrant-mcs-0.7.19 lib/vagrant-mcs/action/read_state.rb
vagrant-mcs-0.7.18 lib/vagrant-mcs/action/read_state.rb
vagrant-mcs-0.7.17 lib/vagrant-mcs/action/read_state.rb
vagrant-mcs-0.7.16 lib/vagrant-mcs/action/read_state.rb
vagrant-mcs-0.7.15 lib/vagrant-mcs/action/read_state.rb
vagrant-mcs-0.7.14 lib/vagrant-mcs/action/read_state.rb
vagrant-mcs-0.7.13 lib/vagrant-mcs/action/read_state.rb
vagrant-mcs-0.7.12 lib/vagrant-mcs/action/read_state.rb