Sha256: df3613da474d27826ae5a8eb20c64b16d11e27868666d0d99d38cb940856a244

Contents?: true

Size: 1.08 KB

Versions: 5

Compression:

Stored size: 1.08 KB

Contents

module Searchkick
  class ProcessBatchJob < ActiveJob::Base
    queue_as { Searchkick.queue_name }

    def perform(class_name:, record_ids:)
      # separate routing from id
      routing = Hash[record_ids.map { |r| r.split(/(?<!\|)\|(?!\|)/, 2).map { |v| v.gsub("||", "|") } }]
      record_ids = routing.keys

      klass = class_name.constantize
      scope = Searchkick.load_records(klass, record_ids)
      scope = scope.search_import if scope.respond_to?(:search_import)
      records = scope.select(&:should_index?)

      # determine which records to delete
      delete_ids = record_ids - records.map { |r| r.id.to_s }
      delete_records = delete_ids.map do |id|
        m = klass.new
        m.id = id
        if routing[id]
          m.define_singleton_method(:search_routing) do
            routing[id]
          end
        end
        m
      end

      # bulk reindex
      index = klass.searchkick_index
      Searchkick.callbacks(:bulk) do
        index.bulk_index(records) if records.any?
        index.bulk_delete(delete_records) if delete_records.any?
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
searchkick-4.0.2 lib/searchkick/process_batch_job.rb
searchkick-4.0.1 lib/searchkick/process_batch_job.rb
searchkick-4.0.0 lib/searchkick/process_batch_job.rb
searchkick-3.1.3 lib/searchkick/process_batch_job.rb
searchkick-3.1.2 lib/searchkick/process_batch_job.rb