require "log4r" module VagrantPlugins module OVirtProvider 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_ovirt3::action::read_state") end def call(env) env[:machine_state_id] = read_state(env[:ovirt_compute], env[:machine]) @app.call(env) end # Possible states include (but may not be limited to): # :not_created, :up, :down, :saving_state, :suspended def read_state(ovirt, machine) return :not_created if machine.id.nil? # Find the machine server = ovirt.servers.get(machine.id) if server.nil? machine.id = nil return :not_created end # Return the state return server.status.to_sym end end end end end