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

org.infinispan.hotrod.impl.multimap.operations.GetKeyMultimapOperation Maven / Gradle / Ivy

package org.infinispan.hotrod.impl.multimap.operations;

import static org.infinispan.hotrod.impl.multimap.protocol.MultimapHotRodConstants.GET_MULTIMAP_REQUEST;
import static org.infinispan.hotrod.impl.multimap.protocol.MultimapHotRodConstants.GET_MULTIMAP_RESPONSE;
import static org.infinispan.hotrod.marshall.MarshallerUtil.bytes2obj;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashSet;

import org.infinispan.api.common.CacheOptions;
import org.infinispan.hotrod.impl.DataFormat;
import org.infinispan.hotrod.impl.operations.OperationContext;
import org.infinispan.hotrod.impl.protocol.HotRodConstants;
import org.infinispan.hotrod.impl.transport.netty.ByteBufUtil;
import org.infinispan.hotrod.impl.transport.netty.HeaderDecoder;

import io.netty.buffer.ByteBuf;
import net.jcip.annotations.Immutable;

/**
 * Implements "get" for multimap as defined by  Hot Rod
 * protocol specification.
 *
 * @since 14.0
 */
@Immutable
public class GetKeyMultimapOperation extends AbstractMultimapKeyOperation> {
   private int size;
   private Collection result;

   public GetKeyMultimapOperation(OperationContext operationContext,
                                  K key, byte[] keyBytes, CacheOptions options,
                                  DataFormat dataFormat, boolean supportsDuplicates) {
      super(operationContext, GET_MULTIMAP_REQUEST, GET_MULTIMAP_RESPONSE, key, keyBytes, options, dataFormat, supportsDuplicates);
   }

   @Override
   protected void reset() {
      super.reset();
      result = null;
   }

   @Override
   public void acceptResponse(ByteBuf buf, short status, HeaderDecoder decoder) {
      if (HotRodConstants.isNotExist(status)) {
         complete(Collections.emptySet());
         return;
      } else if (result == null) {
         size = ByteBufUtil.readVInt(buf);
         result = supportsDuplicates ? new ArrayList<>(size) : new HashSet<>(size);
         decoder.checkpoint();
      }
      while (result.size() < size) {
         V value = bytes2obj(operationContext.getChannelFactory().getMarshaller(), ByteBufUtil.readArray(buf), dataFormat().isObjectStorage(), operationContext.getConfiguration().getClassAllowList());
         result.add(value);
         decoder.checkpoint();
      }
      complete(result);
   }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy