All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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