Sha256: 76c72a655499101a95f1b289503d6e663c1621981ab995f428af2c32997e5fc9

Contents?: true

Size: 1.06 KB

Versions: 5

Compression:

Stored size: 1.06 KB

Contents

require 'log4r'

module VagrantPlugins
  module ProviderLibvirt
    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_libvirt::action::read_state')
        end

        def call(env)
          env[:machine_state_id] = read_state(env[:libvirt_compute], env[:machine])
          @app.call(env)
        end

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

          # Find the machine
          server = libvirt.servers.get(machine.id)
          if server.nil? || [:'shutting-down', :terminated].include?(server.state.to_sym)
            # 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.state.to_sym
        end
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
vagrant-libvirt-0.0.15 lib/vagrant-libvirt/action/read_state.rb
vagrant-libvirt-0.0.14 lib/vagrant-libvirt/action/read_state.rb
vagrant-libvirt-0.0.13 lib/vagrant-libvirt/action/read_state.rb
vagrant-libvirt-0.0.12 lib/vagrant-libvirt/action/read_state.rb
vagrant-libvirt-0.0.11 lib/vagrant-libvirt/action/read_state.rb