/**
*Copyright [2009-2010] [dennis zhuang(killme2008@gmail.com)]
*Licensed under the Apache License, Version 2.0 (the "License");
*you may not use this file except in compliance with the License.
*You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
*Unless required by applicable law or agreed to in writing,
*software distributed under the License is distributed on an "AS IS" BASIS,
*WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
*either express or implied. See the License for the specific language governing permissions and limitations under the License
*/
/**
*Copyright [2009-2010] [dennis zhuang(killme2008@gmail.com)]
*Licensed under the Apache License, Version 2.0 (the "License");
*you may not use this file except in compliance with the License.
*You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
*Unless required by applicable law or agreed to in writing,
*software distributed under the License is distributed on an "AS IS" BASIS,
*WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
*either express or implied. See the License for the specific language governing permissions and limitations under the License
*/
package net.rubyeye.xmemcached.command.binary;
import java.nio.ByteBuffer;
import java.util.concurrent.CountDownLatch;
import net.rubyeye.xmemcached.command.CommandType;
import net.rubyeye.xmemcached.transcoders.CachedData;
import net.rubyeye.xmemcached.utils.ByteUtils;
/**
* AWS ElasticCache config command
*
* @author dennis
*
*/
public class BinaryAWSElasticCacheConfigCommand extends BaseBinaryCommand {
public BinaryAWSElasticCacheConfigCommand(final CountDownLatch latch,
String subCommand, String key) {
super(key, ByteUtils.getBytes(key), CommandType.AWS_CONFIG, latch, 0,
0, latch, false, null);
this.commandType = CommandType.AWS_CONFIG;
if (subCommand.equals("get")) {
this.opCode = OpCode.CONFIG_GET;
} else if (subCommand.equals("set")) {
this.opCode = OpCode.CONFIG_SET;
} else if (subCommand.equals("delete")) {
this.opCode = OpCode.CONFIG_DEL;
}
}
@Override
protected boolean readValue(ByteBuffer buffer, int bodyLength,
int keyLength, int extrasLength) {
int valueLength = bodyLength - keyLength - extrasLength;
if (buffer.remaining() < valueLength) {
return false;
}
byte[] bytes = new byte[valueLength];
buffer.get(bytes);
setResult(new String(bytes));
countDownLatch();
return true;
}
@Override
protected void fillExtras(CachedData data) {
// must not have extras
}
@Override
protected void fillValue(CachedData data) {
// must not have value
}
@Override
protected byte getExtrasLength() {
return 0;
}
@Override
protected int getValueLength(CachedData data) {
return 0;
}
}