Sha256: c664b27f4a90827dc9f0655a3f217af3fabe425d3b23e05fa8f12c694971a3a1
Contents?: true
Size: 1.57 KB
Versions: 12
Compression:
Stored size: 1.57 KB
Contents
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
Version data entries
12 entries across 12 versions & 1 rubygems