Sha256: c18cf8e87176b9b1d15b1002d8e4a8b5f5aadf6fee18144ba398e1897d7a2172
Contents?: true
Size: 1.75 KB
Versions: 2
Compression:
Stored size: 1.75 KB
Contents
# Copyright (C) 2018 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 an op message. # # @api private # # @since 2.5.2 class OpMsg include Specifiable include Executable include SessionsSupported include CausalConsistencySupported # Execute the operation. # # @example # operation.execute(server) # # @param [ Mongo::Server ] server The server to send the operation to. # # @return [ Mongo::Operation::ParallelScan::Result ] The operation result. # # @since 2.5.2 def execute(server) result = Result.new(dispatch_message(server)) process_result(result, server) result.validate! end private def selector(server) sel = { :parallelCollectionScan => coll_name, :numCursors => cursor_count } sel[:maxTimeMS] = max_time_ms if max_time_ms sel[:readConcern] = read_concern if read_concern sel end def message(server) Protocol::Msg.new(flags, options, command(server)) end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
mongo-2.5.3 | lib/mongo/operation/parallel_scan/op_msg.rb |
mongo-2.5.2 | lib/mongo/operation/parallel_scan/op_msg.rb |