Sha256: fe12a258226500b8f7e14649bb2c1fe56cb5e4b1bde0cb817ea45d1d9aae7f18
Contents?: true
Size: 1.06 KB
Versions: 4
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
4 entries across 4 versions & 1 rubygems