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

org.infinispan.client.hotrod.impl.operations.IterationStartOperation Maven / Gradle / Ivy

There is a newer version: 9.3.1.Final
Show newest version
package org.infinispan.client.hotrod.impl.operations;

import org.infinispan.client.hotrod.impl.InternalRemoteCache;
import org.infinispan.client.hotrod.impl.consistenthash.SegmentConsistentHash;
import org.infinispan.client.hotrod.impl.protocol.Codec;
import org.infinispan.client.hotrod.impl.topology.CacheInfo;
import org.infinispan.client.hotrod.impl.transport.netty.ByteBufUtil;
import org.infinispan.client.hotrod.impl.transport.netty.ChannelRecord;
import org.infinispan.client.hotrod.impl.transport.netty.HeaderDecoder;
import org.infinispan.client.hotrod.impl.transport.netty.OperationDispatcher;
import org.infinispan.commons.util.IntSet;

import io.netty.buffer.ByteBuf;
import io.netty.channel.Channel;

/**
 * @author gustavonalle
 * @since 8.0
 */
public class IterationStartOperation extends AbstractCacheOperation {

   private final String filterConverterFactory;
   private final byte[][] filterParameters;
   private final IntSet segments;
   private final int batchSize;
   private final boolean metadata;

   IterationStartOperation(InternalRemoteCache cache, String filterConverterFactory, byte[][] filterParameters, IntSet segments,
                           int batchSize, boolean metadata) {
      super(cache);
      this.filterConverterFactory = filterConverterFactory;
      this.filterParameters = filterParameters;
      this.segments = segments;
      this.batchSize = batchSize;
      this.metadata = metadata;
   }

   @Override
   public void writeOperationRequest(Channel channel, ByteBuf buf, Codec codec) {
      codec.writeIteratorStartOperation(buf, segments, filterConverterFactory, batchSize, metadata, filterParameters);
   }

   @Override
   public IterationStartResponse createResponse(ByteBuf buf, short status, HeaderDecoder decoder, Codec codec, CacheUnmarshaller unmarshaller) {
      OperationDispatcher dispatcher = internalRemoteCache.getDispatcher();
      CacheInfo cacheInfo = dispatcher.getCacheInfo(getCacheName());
      return new IterationStartResponse(ByteBufUtil.readArray(buf), (SegmentConsistentHash) cacheInfo.getConsistentHash(),
            cacheInfo.getTopologyId(), ChannelRecord.of(decoder.getChannel()));
   }

   @Override
   public short requestOpCode() {
      return ITERATION_START_REQUEST;
   }

   @Override
   public short responseOpCode() {
      return ITERATION_START_RESPONSE;
   }

   @Override
   public boolean supportRetry() {
      return false;
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy