3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
# File 'lib/moped/scrollable.rb', line 3
def scroll(cursor = nil, options = nil, &_block)
unless options
bson_type = Mongoid::Compatibility::Version.mongoid3? ? Moped::BSON::ObjectId : BSON::ObjectId
options = { field_type: bson_type }
end
query = Query.new(collection, operation.selector.dup)
query.operation.skip = operation.skip
query.operation.limit = operation.limit
if query.operation.selector['$orderby'] && query.operation.selector['$orderby'].keys.size != 1
raise Mongoid::Scroll::Errors::MultipleSortFieldsError.new(sort: query.operation.selector['$orderby'])
elsif !query.operation.selector.key?('$orderby') || query.operation.selector['$orderby'].empty?
query.sort(_id: 1)
end
scroll_field = query.operation.selector['$orderby'].keys.first
scroll_direction = query.operation.selector['$orderby'].values.first.to_i
cursor_options = { field_name: scroll_field, field_type: options[:field_type], direction: scroll_direction }
cursor = cursor.is_a?(Mongoid::Scroll::Cursor) ? cursor : Mongoid::Scroll::Cursor.new(cursor, cursor_options)
query.operation.selector['$query'] = query.operation.selector['$query'].merge(cursor.criteria)
query.operation.selector['$orderby'] = query.operation.selector['$orderby'].merge(_id: scroll_direction)
if block_given?
query.each do |record|
yield record, Mongoid::Scroll::Cursor.from_record(record, cursor_options)
end
else
query
end
end
|