# frozen_string_literal: true

class ClusterProvisionWorker # rubocop:disable Scalability/IdempotentWorker
  include ApplicationWorker

  data_consistency :always

  sidekiq_options retry: 3
  include ClusterQueue

  worker_has_external_dependencies!

  def perform(cluster_id)
    Clusters::Cluster.find_by_id(cluster_id).try do |cluster|
      cluster.provider.try do |provider|
        if cluster.gcp?
          Clusters::Gcp::ProvisionService.new.execute(provider)
        elsif cluster.aws?
          Clusters::Aws::ProvisionService.new.execute(provider)
        end
      end
    end
  end
end