Sha256: 5326a2880e795da5f051e874185c76ee2fc8d14b20fcbc4ee2ccfc43c09ae0f2
Contents?: true
Size: 1.63 KB
Versions: 1
Compression:
Stored size: 1.63 KB
Contents
module Moped module Scrollable def scroll(cursor = nil, options = { field_type: Moped::BSON::ObjectId }, &block) query = Query.new(collection, operation.selector.dup) query.operation.skip = operation.skip query.operation.limit = operation.limit # we don't support scrolling over a criteria with multiple fields 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.has_key?("$orderby") || query.operation.selector["$orderby"].empty? # introduce a default sort order if there's none query.sort(_id: 1) end # scroll field and direction scroll_field = query.operation.selector["$orderby"].keys.first scroll_direction = query.operation.selector["$orderby"].values.first.to_i # scroll cursor from the parameter, with value and tiebreak_id 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) # scroll if block_given? query.each do |record| yield record, Mongoid::Scroll::Cursor.from_record(record, cursor_options) end else query end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
mongoid-scroll-0.2.1 | lib/moped/scrollable.rb |