1 2 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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
|
# Copyright (C) 2014-2017 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
module Commands
# A MongoDB map reduce operation.
#
# @note A map/reduce operation can behave like a read and
# return a result set, or can behave like a write operation and
# output results to a user-specified collection.
#
# @example Create the map/reduce operation.
# MapReduce.new({
# :selector => {
# :mapreduce => 'test_coll',
# :map => '',
# :reduce => ''
# },
# :db_name => 'test_db'
# })
#
# Initialization:
# param [ Hash ] spec The specifications for the operation.
#
# option spec :selector [ Hash ] The map reduce selector.
# option spec :db_name [ String ] The name of the database on which
# the operation should be executed.
# option spec :options [ Hash ] Options for the map reduce command.
#
# @since 2.0.0
class MapReduce < Command
include TakesWriteConcern
include CausallyConsistent
private
def message(server)
sel = update_selector_for_write_concern(selector, server)
if server.features.op_msg_enabled?
command_op_msg(server, sel, options)
else
sel = update_selector_for_read_pref(sel, server)
opts = update_options_for_slave_ok(options, server)
Protocol::Query.new(db_name, query_coll, sel, opts)
end
end
end
end
end
end
require 'mongo/operation/commands/map_reduce/result'
|