# frozen_string_literal: true # encoding: utf-8 # Copyright (C) 2018-2020 MongoDB Inc. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. module Mongo module Operation class ParallelScan # A MongoDB parallelscan operation sent as a command message. # # @api private # # @since 2.5.2 class Command include Specifiable include Executable include Limited include ReadPreferenceSupported include PolymorphicResult private def selector(connection) sel = { :parallelCollectionScan => coll_name, :numCursors => cursor_count } if read_concern sel[:readConcern] = Options::Mapper.transform_values_to_strings( read_concern) end sel[:maxTimeMS] = max_time_ms if max_time_ms add_read_preference_legacy(sel, connection) end def message(connection) Protocol::Query.new(db_name, Database::COMMAND, command(connection), options(connection)) end end end end end