diff options
author | Tommaso Tocci <tommaso.tocci@mongodb.com> | 2021-01-27 16:56:13 +0000 |
---|---|---|
committer | Evergreen Agent <no-reply@evergreen.mongodb.com> | 2021-01-29 10:46:28 +0000 |
commit | a1c14013a1bb88b32105f997c5035bf28597ac75 (patch) | |
tree | 158c5e730696bd32652bc0eb9aac0650da87fe00 /src/mongo/s/commands/cluster_drop_cmd.cpp | |
parent | d8fb94ae2b7b4dbd21c56c06a54ba908ac081694 (diff) | |
download | mongo-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.cpp | 129 |
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 |