summaryrefslogtreecommitdiff
path: root/src/mongo/db/ops
diff options
context:
space:
mode:
Diffstat (limited to 'src/mongo/db/ops')
-rw-r--r--src/mongo/db/ops/SConscript1
-rw-r--r--src/mongo/db/ops/parsed_update.cpp12
-rw-r--r--src/mongo/db/ops/parsed_update.h11
-rw-r--r--src/mongo/db/ops/update.cpp4
-rw-r--r--src/mongo/db/ops/write_ops_exec.cpp7
5 files changed, 22 insertions, 13 deletions
diff --git a/src/mongo/db/ops/SConscript b/src/mongo/db/ops/SConscript
index 9e679932d08..8f1df866c99 100644
--- a/src/mongo/db/ops/SConscript
+++ b/src/mongo/db/ops/SConscript
@@ -56,7 +56,6 @@ env.Library(
source='parsed_update.cpp',
LIBDEPS=[
'$BUILD_DIR/mongo/base',
- '$BUILD_DIR/mongo/db/matcher/expressions_mongod_only',
'$BUILD_DIR/mongo/db/update/update_driver',
],
)
diff --git a/src/mongo/db/ops/parsed_update.cpp b/src/mongo/db/ops/parsed_update.cpp
index 5e489071cf5..acedfc48d8a 100644
--- a/src/mongo/db/ops/parsed_update.cpp
+++ b/src/mongo/db/ops/parsed_update.cpp
@@ -31,7 +31,6 @@
#include "mongo/db/ops/parsed_update.h"
-#include "mongo/db/matcher/extensions_callback_real.h"
#include "mongo/db/ops/update_request.h"
#include "mongo/db/query/canonical_query.h"
#include "mongo/db/query/collation/collator_factory_interface.h"
@@ -40,11 +39,14 @@
namespace mongo {
-ParsedUpdate::ParsedUpdate(OperationContext* opCtx, const UpdateRequest* request)
+ParsedUpdate::ParsedUpdate(OperationContext* opCtx,
+ const UpdateRequest* request,
+ const ExtensionsCallback& extensionsCallback)
: _opCtx(opCtx),
_request(request),
_driver(new ExpressionContext(opCtx, nullptr)),
- _canonicalQuery() {}
+ _canonicalQuery(),
+ _extensionsCallback(extensionsCallback) {}
Status ParsedUpdate::parseRequest() {
// It is invalid to request that the UpdateStage return the prior or newly-updated version
@@ -95,8 +97,6 @@ Status ParsedUpdate::parseQuery() {
Status ParsedUpdate::parseQueryToCQ() {
dassert(!_canonicalQuery.get());
- const ExtensionsCallbackReal extensionsCallback(_opCtx, &_request->getNamespaceString());
-
// The projection needs to be applied after the update operation, so we do not specify a
// projection during canonicalization.
auto qr = stdx::make_unique<QueryRequest>(_request->getNamespaceString());
@@ -125,7 +125,7 @@ Status ParsedUpdate::parseQueryToCQ() {
boost::intrusive_ptr<ExpressionContext> expCtx;
auto statusWithCQ = CanonicalQuery::canonicalize(
- _opCtx, std::move(qr), std::move(expCtx), extensionsCallback, allowedMatcherFeatures);
+ _opCtx, std::move(qr), std::move(expCtx), _extensionsCallback, allowedMatcherFeatures);
if (statusWithCQ.isOK()) {
_canonicalQuery = std::move(statusWithCQ.getValue());
}
diff --git a/src/mongo/db/ops/parsed_update.h b/src/mongo/db/ops/parsed_update.h
index da983db9f1f..3764b5f85d2 100644
--- a/src/mongo/db/ops/parsed_update.h
+++ b/src/mongo/db/ops/parsed_update.h
@@ -71,10 +71,12 @@ public:
/**
* Constructs a parsed update.
*
- * The object pointed to by "request" must stay in scope for the life of the constructed
- * ParsedUpdate.
+ * The objects pointed to by "request" and "extensionsCallback" must stay in scope for the life
+ * of the constructed ParsedUpdate.
*/
- ParsedUpdate(OperationContext* opCtx, const UpdateRequest* request);
+ ParsedUpdate(OperationContext* opCtx,
+ const UpdateRequest* request,
+ const ExtensionsCallback& extensionsCallback);
/**
* Parses the update request to a canonical query and an update driver. On success, the
@@ -167,6 +169,9 @@ private:
// Parsed query object, or NULL if the query proves to be an id hack query.
std::unique_ptr<CanonicalQuery> _canonicalQuery;
+
+ // Reference to an extensions callback used when parsing to a canonical query.
+ const ExtensionsCallback& _extensionsCallback;
};
} // namespace mongo
diff --git a/src/mongo/db/ops/update.cpp b/src/mongo/db/ops/update.cpp
index e42c6786f2a..a506bb88c0c 100644
--- a/src/mongo/db/ops/update.cpp
+++ b/src/mongo/db/ops/update.cpp
@@ -41,6 +41,7 @@
#include "mongo/db/concurrency/d_concurrency.h"
#include "mongo/db/concurrency/write_conflict_exception.h"
#include "mongo/db/exec/update_stage.h"
+#include "mongo/db/matcher/extensions_callback_real.h"
#include "mongo/db/op_observer.h"
#include "mongo/db/query/explain.h"
#include "mongo/db/query/get_executor.h"
@@ -92,7 +93,8 @@ UpdateResult update(OperationContext* opCtx, Database* db, const UpdateRequest&
}
// Parse the update, get an executor for it, run the executor, get stats out.
- ParsedUpdate parsedUpdate(opCtx, &request);
+ const ExtensionsCallbackReal extensionsCallback(opCtx, &request.getNamespaceString());
+ ParsedUpdate parsedUpdate(opCtx, &request, extensionsCallback);
uassertStatusOK(parsedUpdate.parseRequest());
OpDebug* const nullOpDebug = nullptr;
diff --git a/src/mongo/db/ops/write_ops_exec.cpp b/src/mongo/db/ops/write_ops_exec.cpp
index 2f01873221a..3bab66af9ae 100644
--- a/src/mongo/db/ops/write_ops_exec.cpp
+++ b/src/mongo/db/ops/write_ops_exec.cpp
@@ -50,6 +50,7 @@
#include "mongo/db/exec/update_stage.h"
#include "mongo/db/introspect.h"
#include "mongo/db/lasterror.h"
+#include "mongo/db/matcher/extensions_callback_real.h"
#include "mongo/db/ops/delete_request.h"
#include "mongo/db/ops/insert.h"
#include "mongo/db/ops/parsed_delete.h"
@@ -590,7 +591,8 @@ static SingleWriteResult performSingleUpdateOp(OperationContext* opCtx,
const NamespaceString& ns,
StmtId stmtId,
const UpdateRequest& updateRequest) {
- ParsedUpdate parsedUpdate(opCtx, &updateRequest);
+ const ExtensionsCallbackReal extensionsCallback(opCtx, &updateRequest.getNamespaceString());
+ ParsedUpdate parsedUpdate(opCtx, &updateRequest, extensionsCallback);
uassertStatusOK(parsedUpdate.parseRequest());
CurOpFailpointHelpers::waitWhileFailPointEnabled(
@@ -724,7 +726,8 @@ static SingleWriteResult performSingleUpdateOpWithDupKeyRetry(OperationContext*
try {
return performSingleUpdateOp(opCtx, ns, stmtId, request);
} catch (ExceptionFor<ErrorCodes::DuplicateKey>& ex) {
- ParsedUpdate parsedUpdate(opCtx, &request);
+ const ExtensionsCallbackReal extensionsCallback(opCtx, &request.getNamespaceString());
+ ParsedUpdate parsedUpdate(opCtx, &request, extensionsCallback);
uassertStatusOK(parsedUpdate.parseRequest());
if (!parsedUpdate.hasParsedQuery()) {