org.infinispan.client.hotrod.counter.operation.GetCounterNamesOperation Maven / Gradle / Ivy
package org.infinispan.client.hotrod.counter.operation;
import java.util.ArrayList;
import java.util.Collection;
import java.util.concurrent.atomic.AtomicReference;
import io.netty.buffer.ByteBuf;
import io.netty.channel.Channel;
import org.infinispan.client.hotrod.configuration.Configuration;
import org.infinispan.client.hotrod.impl.ClientTopology;
import org.infinispan.client.hotrod.impl.transport.netty.ByteBufUtil;
import org.infinispan.client.hotrod.impl.transport.netty.ChannelFactory;
import org.infinispan.client.hotrod.impl.transport.netty.HeaderDecoder;
import org.infinispan.counter.api.CounterManager;
/**
* A counter operation for {@link CounterManager#getCounterNames()}.
*
* @author Pedro Ruivo
* @since 9.2
*/
public class GetCounterNamesOperation extends BaseCounterOperation> {
private int size;
private Collection names;
public GetCounterNamesOperation(ChannelFactory transportFactory, AtomicReference topologyId,
Configuration cfg) {
super(COUNTER_GET_NAMES_REQUEST, COUNTER_GET_NAMES_RESPONSE, transportFactory, topologyId, cfg, "", false);
}
@Override
protected void executeOperation(Channel channel) {
scheduleRead(channel);
sendHeader(channel);
setCacheName();
}
@Override
protected void reset() {
super.reset();
names = null;
}
@Override
public void acceptResponse(ByteBuf buf, short status, HeaderDecoder decoder) {
assert status == NO_ERROR_STATUS;
if (names == null) {
size = ByteBufUtil.readVInt(buf);
names = new ArrayList<>(size);
decoder.checkpoint();
}
while (names.size() < size) {
names.add(ByteBufUtil.readString(buf));
decoder.checkpoint();
}
complete(names);
}
}