/* * Copyright (c) 2008-2012, Hazel Bilisim Ltd. All Rights Reserved. * * 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 com.hazelcast.impl.ascii.memcache; import com.hazelcast.impl.ascii.AbstractTextCommandProcessor; import com.hazelcast.impl.ascii.TextCommandService; import com.hazelcast.logging.ILogger; import com.hazelcast.nio.IOUtil; import java.io.UnsupportedEncodingException; import java.net.URLDecoder; import java.util.logging.Level; public class GetCommandProcessor extends AbstractTextCommandProcessor<GetCommand> { final boolean single; private final ILogger logger; public GetCommandProcessor(TextCommandService textCommandService, boolean single) { super(textCommandService); this.single = single; logger = textCommandService.getNode().getLogger(this.getClass().getName()); } public void handle(GetCommand getCommand) { String key = null; try { key = URLDecoder.decode(getCommand.getKey(), "UTF-8"); } catch (UnsupportedEncodingException e) { logger.log(Level.WARNING, e.getMessage(), e); } String mapName = "default"; int index = key.indexOf(':'); if (index != -1) { mapName = key.substring(0, index); key = key.substring(index + 1); } Object value = textCommandService.get(mapName, key); MemcacheEntry entry = null; if (value != null) { if (value instanceof MemcacheEntry) { entry = (MemcacheEntry) value; } else if (value instanceof byte[]) { entry = new MemcacheEntry(getCommand.getKey(), ((byte[]) value), 0); } else if (value instanceof String) { entry = new MemcacheEntry(getCommand.getKey(), ((String) value).getBytes(), 0); } else { try { entry = new MemcacheEntry(getCommand.getKey(), IOUtil.serializeToBytes(value), 0); } catch (Exception e) { logger.log(Level.WARNING, e.getMessage(), e); } } } textCommandService.incrementGetCount(); if (entry != null) { textCommandService.incrementHitCount(); } getCommand.setValue(entry, single); textCommandService.sendResponse(getCommand); } public void handleRejection(GetCommand getCommand) { getCommand.setValue(null, single); textCommandService.sendResponse(getCommand); } }