Sha256: e6d8d89b8c1585ba30fe336ac817ec55debac4dcfea2847efa7f3d6126e50d9b
Contents?: true
Size: 1.66 KB
Versions: 4
Compression:
Stored size: 1.66 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 MapReduce # A MongoDB mapreduce 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::MapReduce::Result ] The operation result. # # @since 2.5.2 def execute(server) result = Result.new(dispatch_message(server)) process_result(result, server) result.validate! rescue Mongo::Error::SocketError => e e.send(:add_label, Mongo::Error::TRANSIENT_TRANSACTION_ERROR_LABEL) if session.in_transaction? raise e end private def message(server) Protocol::Msg.new(flags, options, command(server)) end end end end end
Version data entries
4 entries across 4 versions & 1 rubygems