diff options
Diffstat (limited to 'src/mongo/db/s/shardsvr_collmod_participant_command.cpp')
-rw-r--r-- | src/mongo/db/s/shardsvr_collmod_participant_command.cpp | 109 |
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 |