This action reads the state of the machine and puts it in the `:machine_state_id` key in the environment.
# File lib/vagrant-libvirt/action/read_state.rb, line 9 def initialize(app, env) @app = app @logger = Log4r::Logger.new('vagrant_libvirt::action::read_state') end
# File lib/vagrant-libvirt/action/read_state.rb, line 14 def call(env) env[:machine_state_id] = read_state(env[:libvirt_compute], env[:machine]) @app.call(env) end
# File lib/vagrant-libvirt/action/read_state.rb, line 19 def read_state(libvirt, machine) return :not_created if machine.id.nil? begin server = libvirt.servers.get(machine.id) rescue Libvirt::RetrieveError => e server = nil @logger.debug('Machine not found #{e}.') end # Find the machine begin 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 shutting down or terminated, assuming it got destroyed.') machine.id = nil return :not_created end rescue Libvirt::RetrieveError => e if e.libvirt_code == ProviderLibvirt::Util::ErrorCodes::VIR_ERR_NO_DOMAIN @logger.info("Machine #{machine.id} not found.") machine.id = nil return :not_created else raise e end end # Return the state return server.state.to_sym end