lib/vagrant-vcloud/action/destroy_vapp.rb
module VagrantPlugins
module VCloud
module Action
class DestroyVApp
def initialize(app, env)
@app = app
@logger = Log4r::Logger.new('vagrant_vcloud::action::destroy_vapp')
end
def call(env)
cfg = env[:machine].provider_config
cnx = cfg.vcloud_cnx.driver
vapp_id = env[:machine].get_vapp_id
cfg.org = cnx.get_organization_by_name(cfg.org_name)
cfg.vdc_id = cnx.get_vdc_id_by_name(cfg.org, cfg.vdc_name)
test_vapp = cnx.get_vapp(vapp_id)
@logger.debug(
"Number of VMs in the vApp: #{test_vapp[:vms_hash].count}"
)
if cfg.vdc_edge_gateway_ip && cfg.vdc_edge_gateway
env[:ui].info(
"Removing NAT rules on [#{cfg.vdc_edge_gateway}] " +
"for IP [#{cfg.vdc_edge_gateway_ip}]."
)
@logger.debug(
"Deleting Edge Gateway rules - vdc id: #{cfg.vdc_id}"
)
edge_remove = cnx.remove_edge_gateway_rules(
cfg.vdc_edge_gateway,
cfg.vdc_id,
cfg.vdc_edge_gateway_ip,
vapp_id
)
cnx.wait_task_completion(edge_remove)
end
env[:ui].info('Destroying vApp...')
vapp_delete_task = cnx.delete_vapp(vapp_id)
@logger.debug("vApp Delete task id #{vapp_delete_task}")
cnx.wait_task_completion(vapp_delete_task)
env[:machine].id = nil
env[:machine].vappid = nil
@app.call env
end
end
end
end
end