summaryrefslogtreecommitdiff
path: root/src/mongo/s/commands/cluster_drop_cmd.cpp
diff options
context:
space:
mode:
authorTommaso Tocci <tommaso.tocci@mongodb.com>2021-01-27 16:56:13 +0000
committerEvergreen Agent <no-reply@evergreen.mongodb.com>2021-01-29 10:46:28 +0000
commita1c14013a1bb88b32105f997c5035bf28597ac75 (patch)
tree158c5e730696bd32652bc0eb9aac0650da87fe00 /src/mongo/s/commands/cluster_drop_cmd.cpp
parentd8fb94ae2b7b4dbd21c56c06a54ba908ac081694 (diff)
downloadmongo-a1c14013a1bb88b32105f997c5035bf28597ac75.tar.gz
SERVER-52811 Implement the new drop database path in _shardsvrDropDatabase
Diffstat (limited to 'src/mongo/s/commands/cluster_drop_cmd.cpp')
-rw-r--r--src/mongo/s/commands/cluster_drop_cmd.cpp129
1 files changed, 0 insertions, 129 deletions
diff --git a/src/mongo/s/commands/cluster_drop_cmd.cpp b/src/mongo/s/commands/cluster_drop_cmd.cpp
deleted file mode 100644
index 2892b9c67c2..00000000000
--- a/src/mongo/s/commands/cluster_drop_cmd.cpp
+++ /dev/null
@@ -1,129 +0,0 @@
-/**
- * Copyright (C) 2018-present MongoDB, Inc.
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the Server Side Public License, version 1,
- * as published by MongoDB, Inc.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * Server Side Public License for more details.
- *
- * You should have received a copy of the Server Side Public License
- * along with this program. If not, see
- * <http://www.mongodb.com/licensing/server-side-public-license>.
- *
- * As a special exception, the copyright holders give permission to link the
- * code of portions of this program with the OpenSSL library under certain
- * conditions as described in each individual source file and distribute
- * linked combinations including the program with the OpenSSL library. You
- * must comply with the Server Side Public License in all respects for
- * all of the code used other than as permitted herein. If you modify file(s)
- * with this exception, you may extend this exception to your version of the
- * file(s), but you are not obligated to do so. If you do not wish to do so,
- * delete this exception statement from your version. If you delete this
- * exception statement from all source files in the program, then also delete
- * it in the license file.
- */
-
-#define MONGO_LOGV2_DEFAULT_COMPONENT ::mongo::logv2::LogComponent::kCommand
-
-#include "mongo/platform/basic.h"
-
-#include "mongo/base/status.h"
-#include "mongo/db/auth/authorization_session.h"
-#include "mongo/db/commands.h"
-#include "mongo/db/drop_gen.h"
-#include "mongo/db/operation_context.h"
-#include "mongo/rpc/get_status_from_command_result.h"
-#include "mongo/s/catalog_cache.h"
-#include "mongo/s/client/shard_registry.h"
-#include "mongo/s/cluster_commands_helpers.h"
-#include "mongo/s/grid.h"
-#include "mongo/s/request_types/sharded_ddl_commands_gen.h"
-#include "mongo/util/scopeguard.h"
-
-namespace mongo {
-namespace {
-
-class DropCmd : public DropCmdVersion1Gen<DropCmd> {
-public:
- AllowedOnSecondary secondaryAllowed(ServiceContext*) const final {
- return AllowedOnSecondary::kAlways;
- }
-
- bool adminOnly() const final {
- return false;
- }
-
- class Invocation final : public InvocationBaseGen {
- public:
- using InvocationBaseGen::InvocationBaseGen;
- bool supportsWriteConcern() const final {
- return true;
- }
- NamespaceString ns() const final {
- return request().getNamespace();
- }
- void doCheckAuthorization(OperationContext* opCtx) const final {
- auto ns = request().getNamespace();
- uassert(ErrorCodes::Unauthorized,
- str::stream() << "Not authorized to drop collection '" << ns << "'",
- AuthorizationSession::get(opCtx->getClient())
- ->isAuthorizedForActionsOnNamespace(ns, ActionType::dropCollection));
- }
- Reply typedRun(OperationContext* opCtx) final {
- auto nss = request().getNamespace();
- uassert(ErrorCodes::IllegalOperation,
- "Cannot drop collection in config database",
- nss.db() != NamespaceString::kConfigDb);
-
- uassert(ErrorCodes::IllegalOperation,
- "Cannot drop collection in admin database",
- nss.db() != NamespaceString::kAdminDb);
-
- try {
- // Invalidate the routing table cache entry for this collection so that we reload it
- // the next time it is accessed, even if sending the command to the config server
- // fails due to e.g. a NetworkError.
- ON_BLOCK_EXIT([opCtx, nss] {
- Grid::get(opCtx)->catalogCache()->invalidateCollectionEntry_LINEARIZABLE(nss);
- });
-
- const auto dbInfo =
- uassertStatusOK(Grid::get(opCtx)->catalogCache()->getDatabase(opCtx, nss.db()));
-
- // Send it to the primary shard
- ShardsvrDropCollection dropCollectionCommand(nss);
- dropCollectionCommand.setDbName(nss.db());
-
- auto cmdResponse = executeCommandAgainstDatabasePrimary(
- opCtx,
- nss.db(),
- dbInfo,
- CommandHelpers::appendMajorityWriteConcern(dropCollectionCommand.toBSON({}),
- opCtx->getWriteConcern()),
- ReadPreferenceSetting(ReadPreference::PrimaryOnly),
- Shard::RetryPolicy::kIdempotent);
-
- const auto remoteResponse = uassertStatusOK(cmdResponse.swResponse);
- BSONObjBuilder result;
- CommandHelpers::filterCommandReplyForPassthrough(remoteResponse.data, &result);
- auto resultObj = result.obj();
- uassertStatusOK(getStatusFromCommandResult(resultObj));
- // Ensure our reply conforms to the IDL-defined reply structure.
- return DropReply::parse({"drop"}, resultObj);
- } catch (const ExceptionFor<ErrorCodes::NamespaceNotFound>&) {
- // If the namespace isn't found, treat the drop as a success but inform about the
- // failure.
- DropReply reply;
- reply.setInfo("database does not exist"_sd);
- return reply;
- }
- }
- };
-} clusterDropCmd;
-
-} // namespace
-} // namespace mongo