require 'log4r'
require 'fog/arubacloud/error'

module VagrantPlugins
  module ArubaCloud
    module Action
      # This deletes the running server, if there is one.
      class DeleteServer
        def initialize(app, env)
          @app    = app
          @logger = Log4r::Logger.new('vagrant_arubacloud::action::delete_server')
        end

        def call(env)
          if env[:machine].id
            env[:ui].info(I18n.t('vagrant_arubacloud.deleting_server'))
            # On fog side, get will call get_service_details, I must be sure
            # that the returned object has the "id" parameters not nil
            server = env[:arubacloud_compute].servers.get(env[:machine].id)
            begin
              server.delete
            rescue Fog::ArubaCloud::Errors::VmStatus
              env[:ui].warn(I18n.t('vagrant_arubacloud.bad_state'))
            end
            env[:machine].id = nil
          end

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