Module: Elasticsearch::Model::Adapter::ActiveRecord::Importing

Defined in:
lib/elasticsearch/model/adapters/active_record.rb

Instance Method Summary collapse

Instance Method Details

#__find_in_batches(options = {}, &block) ⇒ Object

Fetch batches of records from the database (used by the import method)



92
93
94
95
96
97
98
99
100
101
102
103
104
105
# File 'lib/elasticsearch/model/adapters/active_record.rb', line 92

def __find_in_batches(options={}, &block)
  query = options.delete(:query)
  named_scope = options.delete(:scope)
  preprocess = options.delete(:preprocess)

  scope = self
  scope = scope.__send__(named_scope) if named_scope
  scope = scope.instance_exec(&query) if query

  scope.find_in_batches(**options) do |batch|
    batch = self.__send__(preprocess, batch) if preprocess
    yield(batch) if batch.present?
  end
end

#__transformObject



107
108
109
# File 'lib/elasticsearch/model/adapters/active_record.rb', line 107

def __transform
  lambda { |model|  { index: { _id: model.id, data: model.__elasticsearch__.as_indexed_json } } }
end