org.infinispan.client.hotrod.impl.operations.PutAllOperation Maven / Gradle / Ivy
package org.infinispan.client.hotrod.impl.operations;
import java.net.SocketAddress;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;
import org.infinispan.client.hotrod.configuration.ClientIntelligence;
import org.infinispan.client.hotrod.exceptions.InvalidResponseException;
import org.infinispan.client.hotrod.impl.protocol.Codec;
import org.infinispan.client.hotrod.impl.protocol.HeaderParams;
import org.infinispan.client.hotrod.impl.protocol.HotRodConstants;
import org.infinispan.client.hotrod.impl.transport.Transport;
import org.infinispan.client.hotrod.impl.transport.TransportFactory;
import net.jcip.annotations.Immutable;
/**
* Implements "putAll" as defined by Hot Rod protocol specification.
*
* @author William Burns
* @since 7.2
*/
@Immutable
public class PutAllOperation extends RetryOnFailureOperation {
public PutAllOperation(Codec codec, TransportFactory transportFactory,
Map map, byte[] cacheName, AtomicInteger topologyId,
int flags, ClientIntelligence clientIntelligence,
long lifespan, TimeUnit lifespanTimeUnit, long maxIdle, TimeUnit maxIdleTimeUnit) {
super(codec, transportFactory, cacheName, topologyId, flags, clientIntelligence);
this.map = map;
this.lifespan = lifespan;
this.lifespanTimeUnit = lifespanTimeUnit;
this.maxIdle = maxIdle;
this.maxIdleTimeUnit = maxIdleTimeUnit;
}
protected final Map map;
protected final long lifespan;
private final TimeUnit lifespanTimeUnit;
protected final long maxIdle;
private final TimeUnit maxIdleTimeUnit;
@Override
protected Void executeOperation(Transport transport) {
HeaderParams params = writeHeader(transport, PUT_ALL_REQUEST);
codec.writeExpirationParams(transport, lifespan, lifespanTimeUnit, maxIdle, maxIdleTimeUnit);
transport.writeVInt(map.size());
for (Entry entry : map.entrySet()) {
transport.writeArray(entry.getKey());
transport.writeArray(entry.getValue());
}
transport.flush();
short status = readHeaderAndValidate(transport, params);
if (!HotRodConstants.isSuccess(status)) {
throw new InvalidResponseException("Unexpected response status: " + Integer.toHexString(status));
}
return null;
}
@Override
protected Transport getTransport(int retryCount, Set failedServers) {
return transportFactory.getTransport(map.keySet().iterator().next(), failedServers, cacheName);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy