/*
* Copyright 2011 Couchbase, Inc..
*
* 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.
* under the License.
*/
package org.couchbase.mock.memcached;
import java.security.AccessControlException;
import org.couchbase.mock.memcached.protocol.*;
/**
* @author Trond Norbye <trond.norbye@gmail.com>
*/
public class GetCommandExecutor implements CommandExecutor {
@Override
public void execute(BinaryCommand command, MemcachedServer server, MemcachedConnection client) {
BinaryGetCommand cmd = (BinaryGetCommand) command;
VBucketStore cache;
CommandCode cc = cmd.getComCode();
if (cc == CommandCode.GET_REPLICA) {
cache = server.getStorage().getCache(cmd.getVBucketId());
if (!server.getStorage().getVBucketInfo(cmd.getVBucketId()).hasAccess(server)) {
throw new AccessControlException("we're not a master or replica");
}
} else {
cache = server.getStorage().getCache(server, cmd.getVBucketId());
}
Item item = cache.get(cmd.getKeySpec());
if (item == null) {
if (cc != CommandCode.GETKQ && cc != CommandCode.GETQ && cc != CommandCode.GATQ) {
client.sendResponse(new BinaryGetResponse(cmd, ErrorCode.KEY_ENOENT));
}
return;
}
if (cc == CommandCode.GETL) {
ErrorCode ec = cache.lock(item, cmd.getExpiration());
if (ec != ErrorCode.SUCCESS) {
client.sendResponse(new BinaryResponse(cmd, ec));
return;
}
} else if (cc == CommandCode.TOUCH || cc == CommandCode.GAT || cc == CommandCode.GATQ) {
ErrorCode ec = cache.touch(item, cmd.getExpiration());
if (ec != ErrorCode.SUCCESS) {
client.sendResponse(new BinaryResponse(cmd, ec));
return;
}
}
if (cc == CommandCode.TOUCH) {
client.sendResponse(new BinaryGetResponse(cmd, ErrorCode.SUCCESS));
} else {
client.sendResponse(new BinaryGetResponse(cmd, item));
}
}
}