com.eightkdata.mongowp.mongoserver.api.commands.ShardingQueryCommand Maven / Gradle / Ivy
/*
* This file is part of mongowp.
*
* mongowp is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* mongowp 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
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with mongowp. If not, see .
*
* Copyright (c) 2014, 8Kdata Technology
*
*/
package com.eightkdata.mongowp.mongoserver.api.commands;
import com.eightkdata.mongowp.messages.request.RequestBaseMessage;
import com.eightkdata.mongowp.mongoserver.api.QueryCommandProcessor;
import com.google.common.base.Preconditions;
import javax.annotation.Nonnull;
import org.bson.BsonDocument;
/**
*
* matteom
*/
public enum ShardingQueryCommand implements QueryCommandProcessor.QueryCommand {
//addShard,
checkShardingIndex,
cleanupOrphaned,
//enableSharding,
//flushRouterConfig,
getShardMap,
getShardVersion,
//isdbgrid,
//listShards,
medianKey,
mergeChunks,
moveChunk,
//movePrimary,
//removeShard,
//setShardVersion,
//shardCollection,
shardingState,
splitChunk,
splitVector,
//split,
unsetSharding
;
private final String key;
private ShardingQueryCommand() {
this.key = name();
}
private ShardingQueryCommand(String key) {
this.key = key;
}
@Override
public String getKey() {
return key;
}
@Override
public boolean isAdminOnly() {
return false;
}
public void doCall(@Nonnull RequestBaseMessage queryMessage, @Nonnull BsonDocument query, @Nonnull QueryCommandProcessor.ProcessorCaller caller) throws Exception {
caller.unimplemented(this);
}
@Override
public void call(@Nonnull RequestBaseMessage requestBaseMessage, @Nonnull BsonDocument query, @Nonnull QueryCommandProcessor.ProcessorCaller caller) throws Exception {
Preconditions.checkNotNull(query);
Preconditions.checkNotNull(caller);
doCall(requestBaseMessage, query, caller);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy