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 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 end end @app.call(env) end end end end end