Sha256: a9e96ad160752226c37f2f2d95971c205aac45d610b47a349afd8144a0848463

Contents?: true

Size: 1.97 KB

Versions: 3

Compression:

Stored size: 1.97 KB

Contents

require 'log4r'
require 'vagrant/util/retryable'
require 'fog/arubacloud/error'
require 'optparse'

module VagrantPlugins
  module ArubaCloud
    module Action
      # This stop a server, if it exists
      class StartServer
        include Vagrant::Util::Retryable

        def initialize(app, env)
          @app    = app
          @env    = env
          @logger = Log4r::Logger.new('vagrant_arubacloud::action::start_server')
        end

        def call(env)
          if env[:machine].id
            config = env[:machine].provider_config
            arubacloud_dc = config.endpoint
            
            env[:ui].info(" [#{arubacloud_dc}] " + I18n.t('vagrant_arubacloud.starting_server'))
            server = env[:arubacloud_compute].servers.get(env[:machine].id)
            # Check if the vm is already powered on
            @logger.debug("VM ready?: #{server.ready?}")
            if server.ready?
              # continue the middleware
              @app.call(env)
            else
              # Try to power-on the VM.
              begin
                server.power_on 
                rescue Fog::ArubaCloud::Errors::VmStatus
                  env[:ui].warn(I18n.t('vagrant_arubacloud.bad_state'))
                  return
                rescue Fog::ArubaCloud::Errors::RequestError => e
                  if e.response['ResultCode'].eql? 17
                    env[:ui].warn(I18n.t('vagrant_arubacloud.operation_already_in_queue'))
                    return
                  end
              end

              # Wait for the server to be proper started and up
              env[:ui].info(" [#{arubacloud_dc}] " + I18n.t('vagrant_arubacloud.waiting_server_powered_on'))
              retryable(:tries => 40, :sleep => 2) do
                server.wait_for(1) { ready? }
              end
              env[:ui].info(" [#{arubacloud_dc}] " + I18n.t('vagrant_arubacloud.server_powered_on'))
            end
          end

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

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
vagrant-arubacloud-0.0.7 lib/vagrant-arubacloud/action/start_server.rb
vagrant-arubacloud-0.0.6 lib/vagrant-arubacloud/action/start_server.rb
vagrant-arubacloud-0.0.5 lib/vagrant-arubacloud/action/start_server.rb