2020-09-29 11:10:08 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class BulkCreateIntegrationService
|
2022-05-30 05:09:35 -04:00
|
|
|
include Integrations::BulkOperationHashes
|
|
|
|
|
2020-09-29 11:10:08 -04:00
|
|
|
def initialize(integration, batch, association)
|
|
|
|
@integration = integration
|
|
|
|
@batch = batch
|
|
|
|
@association = association
|
|
|
|
end
|
|
|
|
|
|
|
|
def execute
|
2022-05-30 05:09:35 -04:00
|
|
|
service_list = ServiceList.new(batch, integration_hash(:create), association).to_array
|
2020-09-29 11:10:08 -04:00
|
|
|
|
2021-05-12 08:10:24 -04:00
|
|
|
Integration.transaction do
|
2020-09-29 11:10:08 -04:00
|
|
|
results = bulk_insert(*service_list)
|
|
|
|
|
|
|
|
if integration.data_fields_present?
|
2022-05-30 05:09:35 -04:00
|
|
|
data_list = DataList.new(results, data_fields_hash(:create), integration.data_fields.class).to_array
|
2020-09-29 11:10:08 -04:00
|
|
|
|
|
|
|
bulk_insert(*data_list)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
attr_reader :integration, :batch, :association
|
|
|
|
|
|
|
|
def bulk_insert(klass, columns, values_array)
|
|
|
|
items_to_insert = values_array.map { |array| Hash[columns.zip(array)] }
|
|
|
|
|
|
|
|
klass.insert_all(items_to_insert, returning: [:id])
|
|
|
|
end
|
|
|
|
end
|