Sha256: 57f667df8e53a18b82c6286c291e239d2db887dab10ced34ebc3c4e1588cf90e

Contents?: true

Size: 1.04 KB

Versions: 5

Compression:

Stored size: 1.04 KB

Contents

module VagrantPlugins
  module VCloud
    module Action
      class PowerOn
        def initialize(app, env)
          @app = app
          @logger = Log4r::Logger.new('vagrant_vcloud::action::power_on')
        end

        def call(env)
          @env = env

          cfg = env[:machine].provider_config
          cnx = cfg.vcloud_cnx.driver

          env[:ui].info('Setting VM hardware...')

          set_vm_hardware = cnx.set_vm_hardware(env[:machine].id, cfg)
          if set_vm_hardware
            cnx.wait_task_completion(set_vm_hardware)
          end

          env[:ui].info('Powering on VM...')

          if ! cfg.nested_hypervisor.nil?
            set_vm_nested_hypervisor = cnx.set_vm_nested_hypervisor(env[:machine].id, cfg.nested_hypervisor)
            if set_vm_nested_hypervisor
              cnx.wait_task_completion(set_vm_nested_hypervisor)
            end
          end

          poweron_vm = cnx.poweron_vm(env[:machine].id)
          cnx.wait_task_completion(poweron_vm)

          @app.call(env)
        end
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
vagrant-vcloud-0.4.4 lib/vagrant-vcloud/action/power_on.rb
vagrant-vcloud-0.4.3 lib/vagrant-vcloud/action/power_on.rb
vagrant-vcloud-0.4.2 lib/vagrant-vcloud/action/power_on.rb
vagrant-vcloud-0.4.1 lib/vagrant-vcloud/action/power_on.rb
vagrant-vcloud-0.4.0 lib/vagrant-vcloud/action/power_on.rb