frapposelli/vagrant-vcloud

View on GitHub
lib/vagrant-vcloud/action/destroy_vapp.rb

Summary

Maintainability
A
1 hr
Test Coverage
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