require "log4r" module VagrantPlugins module OpenStack module Action # This deletes the running server, if there is one. class DeleteServer def initialize(app, env) @app = app @logger = Log4r::Logger.new("vagrant_openstack::action::delete_server") end def call(env) machine = env[:machine] id = machine.id || env[:openstack_compute].servers.all( :name => machine.name ).first.id if id volumes = env[:openstack_compute].servers.get(id).volume_attachments env[:ui].info(I18n.t("vagrant_openstack.deleting_server")) # TODO: Validate the fact that we get a server back from the API. server = env[:openstack_compute].servers.get(id) if server ip = server.floating_ip_address server.destroy if machine.provider_config.floating_ip_pool address = env[:openstack_compute].list_all_addresses.body["floating_ips"].find{|i| i["ip"] == ip} if address env[:openstack_compute].release_address(address["id"]) end end env[:ui].info(I18n.t("vagrant_openstack.deleting_volumes")) volumes.each do |compute_volume| volume = env[:openstack_volume].volumes.get(compute_volume["id"]) if volume env[:ui].info("Deleting volume: #{volume.display_name}") begin volume.destroy rescue Excon::Errors::Error => e raise Errors::VolumeBadState, :volume => volume.display_name, :state => e.message end end end end end @app.call(env) end end end end end