MongoDB C++ Driver  mongocxx-3.6.2
All Classes Namespaces Functions Typedefs Enumerations Enumerator Friends Pages
find_one_and_replace.hpp
1 // Copyright 2014 MongoDB Inc.
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 #pragma once
16 
17 #include <chrono>
18 #include <cstdint>
19 
20 #include <bsoncxx/document/view_or_value.hpp>
21 #include <bsoncxx/stdx/optional.hpp>
22 #include <mongocxx/hint.hpp>
23 #include <mongocxx/options/find_one_common_options.hpp>
24 #include <mongocxx/stdx.hpp>
25 #include <mongocxx/write_concern.hpp>
26 
27 #include <mongocxx/config/prelude.hpp>
28 
29 namespace mongocxx {
30 MONGOCXX_INLINE_NAMESPACE_BEGIN
31 namespace options {
32 
36 class MONGOCXX_API find_one_and_replace {
37  public:
50 
59  const stdx::optional<bsoncxx::document::view_or_value>& collation() const;
60 
77  find_one_and_replace& bypass_document_validation(bool bypass_document_validation);
78 
86  const stdx::optional<bool>& bypass_document_validation() const;
87 
101  find_one_and_replace& hint(class hint index_hint);
102 
108  const stdx::optional<class hint>& hint() const;
109 
122  find_one_and_replace& max_time(std::chrono::milliseconds max_time);
123 
131  const stdx::optional<std::chrono::milliseconds>& max_time() const;
132 
146 
154  const stdx::optional<bsoncxx::document::view_or_value>& projection() const;
155 
170  find_one_and_replace& return_document(return_document return_document);
171 
180  const stdx::optional<mongocxx::options::return_document>& return_document() const;
181 
198 
206  const stdx::optional<bsoncxx::document::view_or_value>& sort() const;
207 
223 
231  const stdx::optional<bool>& upsert() const;
232 
247 
257  const stdx::optional<mongocxx::write_concern>& write_concern() const;
258 
259  private:
260  stdx::optional<bool> _bypass_document_validation;
261  stdx::optional<bsoncxx::document::view_or_value> _collation;
262  stdx::optional<class hint> _hint;
263  stdx::optional<std::chrono::milliseconds> _max_time;
264  stdx::optional<bsoncxx::document::view_or_value> _projection;
265  stdx::optional<mongocxx::options::return_document> _return_document;
266  stdx::optional<bsoncxx::document::view_or_value> _ordering;
267  stdx::optional<bool> _upsert;
268  stdx::optional<mongocxx::write_concern> _write_concern;
269 };
270 
271 } // namespace options
272 MONGOCXX_INLINE_NAMESPACE_END
273 } // namespace mongocxx
274 
275 #include <mongocxx/config/postlude.hpp>
mongocxx::options::find_one_and_replace::bypass_document_validation
find_one_and_replace & bypass_document_validation(bool bypass_document_validation)
Whether or not to bypass document validation for this operation.
mongocxx
Top level namespace for the MongoDB C++ driver.
Definition: bulk_write.hpp:24
mongocxx::options::find_one_and_replace::max_time
const stdx::optional< std::chrono::milliseconds > & max_time() const
The current max_time setting.
mongocxx::options::find_one_and_replace::write_concern
const stdx::optional< mongocxx::write_concern > & write_concern() const
Gets the current write concern.
bsoncxx::view_or_value
Class representing a view-or-value variant type.
Definition: view_or_value.hpp:30
mongocxx::options::find_one_and_replace::hint
const stdx::optional< class hint > & hint() const
Gets the current hint.
mongocxx::write_concern
Class representing the server-side requirement for reporting the success of a write operation.
Definition: write_concern.hpp:56
mongocxx::options::find_one_and_replace::hint
find_one_and_replace & hint(class hint index_hint)
Sets the index to use for this operation.
mongocxx::options::find_one_and_replace::sort
find_one_and_replace & sort(bsoncxx::document::view_or_value ordering)
Sets the order by which to search the collection for a matching document.
mongocxx::options::find_one_and_replace::sort
const stdx::optional< bsoncxx::document::view_or_value > & sort() const
Gets the current sort ordering.
mongocxx::options::find_one_and_replace::collation
find_one_and_replace & collation(bsoncxx::document::view_or_value collation)
Sets the collation for this operation.
mongocxx::options::find_one_and_replace::upsert
const stdx::optional< bool > & upsert() const
Gets the current upsert setting.
mongocxx::options::find_one_and_replace::return_document
find_one_and_replace & return_document(return_document return_document)
Set the desired version of the replaced document to return, either the original document,...
mongocxx::options::find_one_and_replace::projection
const stdx::optional< bsoncxx::document::view_or_value > & projection() const
Gets the current projection for this operation.
mongocxx::options::find_one_and_replace::upsert
find_one_and_replace & upsert(bool upsert)
Sets the upsert flag on the operation.
mongocxx::options::find_one_and_replace::write_concern
find_one_and_replace & write_concern(mongocxx::write_concern write_concern)
Sets the write concern for this operation.
mongocxx::options::find_one_and_replace::projection
find_one_and_replace & projection(bsoncxx::document::view_or_value projection)
Sets a projection, which limits the fields to return.
mongocxx::hint
Class representing a hint to be passed to a database operation.
Definition: hint.hpp:32
mongocxx::options::find_one_and_replace::bypass_document_validation
const stdx::optional< bool > & bypass_document_validation() const
The current setting for bypassing document validation.
mongocxx::options::find_one_and_replace
Class representing the optional arguments to a MongoDB find_and_modify replace operation.
Definition: find_one_and_replace.hpp:36
mongocxx::options::find_one_and_replace::return_document
const stdx::optional< mongocxx::options::return_document > & return_document() const
Which version of the replaced document to return.
mongocxx::options::find_one_and_replace::collation
const stdx::optional< bsoncxx::document::view_or_value > & collation() const
Retrieves the current collation for this operation.
mongocxx::options::find_one_and_replace::max_time
find_one_and_replace & max_time(std::chrono::milliseconds max_time)
Sets the maximum amount of time for this operation to run (server-side) in milliseconds.