summaryrefslogtreecommitdiff
path: root/src/mongo/db/s/shardsvr_collmod_participant_command.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/mongo/db/s/shardsvr_collmod_participant_command.cpp')
-rw-r--r--src/mongo/db/s/shardsvr_collmod_participant_command.cpp109
1 files changed, 0 insertions, 109 deletions
diff --git a/src/mongo/db/s/shardsvr_collmod_participant_command.cpp b/src/mongo/db/s/shardsvr_collmod_participant_command.cpp
deleted file mode 100644
index 155d298f751..00000000000
--- a/src/mongo/db/s/shardsvr_collmod_participant_command.cpp
+++ /dev/null
@@ -1,109 +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::kSharding
-
-#include "mongo/db/auth/authorization_session.h"
-#include "mongo/db/catalog_raii.h"
-#include "mongo/db/commands.h"
-#include "mongo/db/s/collmod_coordinator.h"
-#include "mongo/db/s/sharded_collmod_gen.h"
-#include "mongo/db/s/sharding_state.h"
-#include "mongo/db/timeseries/timeseries_collmod.h"
-#include "mongo/logv2/log.h"
-#include "mongo/s/catalog/sharding_catalog_client.h"
-#include "mongo/s/chunk_manager_targeter.h"
-
-namespace mongo {
-namespace {
-
-class ShardSvrCollModParticipantCommand final
- : public TypedCommand<ShardSvrCollModParticipantCommand> {
-public:
- using Request = ShardsvrCollModParticipant;
- using Response = CollModReply;
-
- std::string help() const override {
- return "Internal command, which is exported by the shards. Do not call "
- "directly. Blocks writes during collection mod.";
- }
-
- bool skipApiVersionCheck() const override {
- // Internal command (server to server).
- return true;
- }
-
- AllowedOnSecondary secondaryAllowed(ServiceContext*) const override {
- return Command::AllowedOnSecondary::kNever;
- }
-
- class Invocation final : public InvocationBase {
- public:
- using InvocationBase::InvocationBase;
-
- Response typedRun(OperationContext* opCtx) {
- uassertStatusOK(ShardingState::get(opCtx)->canAcceptShardedCommands());
-
- uassert(ErrorCodes::InvalidOptions,
- str::stream() << Request::kCommandName
- << " must be called with majority writeConcern, got "
- << opCtx->getWriteConcern().wMode,
- opCtx->getWriteConcern().wMode == WriteConcernOptions::kMajority);
-
- opCtx->setAlwaysInterruptAtStepDownOrUp();
-
- BSONObjBuilder builder;
- CollMod cmd(ns());
- cmd.setCollModRequest(request().getCollModRequest());
- uassertStatusOK(timeseries::processCollModCommandWithTimeSeriesTranslation(
- opCtx, ns(), cmd, &builder));
- return CollModReply::parse(IDLParserErrorContext("CollModReply"), builder.obj());
- }
-
- private:
- NamespaceString ns() const override {
- return request().getNamespace();
- }
-
- bool supportsWriteConcern() const override {
- return true;
- }
-
- void doCheckAuthorization(OperationContext* opCtx) const override {
- uassert(ErrorCodes::Unauthorized,
- "Unauthorized",
- AuthorizationSession::get(opCtx->getClient())
- ->isAuthorizedForActionsOnResource(ResourcePattern::forClusterResource(),
- ActionType::internal));
- }
- };
-} shardsvrCollModParticipantCommand;
-
-} // namespace
-} // namespace mongo