org.infinispan.client.hotrod.impl.operations.ExecuteOperation Maven / Gradle / Ivy
The newest version!
package org.infinispan.client.hotrod.impl.operations;
import static org.infinispan.client.hotrod.marshall.MarshallerUtil.bytes2obj;
import java.net.SocketAddress;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import java.util.concurrent.atomic.AtomicReference;
import org.infinispan.client.hotrod.DataFormat;
import org.infinispan.client.hotrod.configuration.Configuration;
import org.infinispan.client.hotrod.impl.ClientTopology;
import org.infinispan.client.hotrod.impl.protocol.Codec;
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.commons.util.Util;
import io.netty.buffer.ByteBuf;
import io.netty.channel.Channel;
/**
* ExecuteOperation.
*
* @author Tristan Tarrant
* @since 7.1
*/
public class ExecuteOperation extends RetryOnFailureOperation {
private final String taskName;
private final Map marshalledParams;
private final Object key;
protected ExecuteOperation(Codec codec, ChannelFactory channelFactory, byte[] cacheName,
AtomicReference clientTopology, int flags, Configuration cfg,
String taskName, Map marshalledParams, Object key, DataFormat dataFormat) {
super(EXEC_REQUEST, EXEC_RESPONSE, codec, channelFactory, cacheName == null ? DEFAULT_CACHE_NAME_BYTES : cacheName,
clientTopology, flags, cfg, dataFormat, null);
this.taskName = taskName;
this.marshalledParams = marshalledParams;
this.key = key;
}
@Override
protected void fetchChannelAndInvoke(int retryCount, Set failedServers) {
if (key != null) {
channelFactory.fetchChannelAndInvoke(key, failedServers, cacheName(), this);
} else {
channelFactory.fetchChannelAndInvoke(failedServers, cacheName(), this);
}
}
@Override
protected void executeOperation(Channel channel) {
scheduleRead(channel);
ByteBuf buf = channel.alloc().buffer(); // estimation too complex
codec.writeHeader(buf, header);
ByteBufUtil.writeString(buf, taskName);
ByteBufUtil.writeVInt(buf, marshalledParams.size());
for (Entry entry : marshalledParams.entrySet()) {
ByteBufUtil.writeString(buf, entry.getKey());
ByteBufUtil.writeArray(buf, entry.getValue());
}
channel.writeAndFlush(buf);
}
@Override
public void acceptResponse(ByteBuf buf, short status, HeaderDecoder decoder) {
complete(bytes2obj(channelFactory.getMarshaller(), ByteBufUtil.readArray(buf), dataFormat().isObjectStorage(), cfg.getClassAllowList()));
}
@Override
protected void addParams(StringBuilder sb) {
sb.append(", taskName=").append(taskName);
sb.append(", params=[");
for (Iterator> iterator = marshalledParams.entrySet().iterator(); iterator.hasNext(); ) {
Entry entry = iterator.next();
String name = entry.getKey();
byte[] value = entry.getValue();
sb.append(name).append("=").append(Util.toStr(value));
if (iterator.hasNext()) {
sb.append(", ");
}
}
sb.append("]");
}
}