org.infinispan.hotrod.impl.operations.PingOperation Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of infinispan-hotrod-jakarta Show documentation
Show all versions of infinispan-hotrod-jakarta Show documentation
Infinispan Hot Rod Client Jakarta EE
package org.infinispan.hotrod.impl.operations;
import java.net.SocketAddress;
import java.util.concurrent.CompletableFuture;
import org.infinispan.api.common.CacheOptions;
import org.infinispan.hotrod.configuration.ProtocolVersion;
import org.infinispan.hotrod.exceptions.InvalidResponseException;
import org.infinispan.hotrod.impl.logging.Log;
import org.infinispan.hotrod.impl.logging.LogFactory;
import org.infinispan.hotrod.impl.protocol.Codec;
import org.infinispan.hotrod.impl.protocol.HotRodConstants;
import org.infinispan.hotrod.impl.transport.netty.ChannelOperation;
import org.infinispan.hotrod.impl.transport.netty.HeaderDecoder;
import io.netty.buffer.ByteBuf;
import io.netty.channel.Channel;
import io.netty.handler.codec.DecoderException;
/**
* Corresponds to the "ping" operation as defined in Hot Rod
* protocol specification.
*
* @since 14.0
*/
public class PingOperation extends HotRodOperation implements ChannelOperation {
private static final Log log = LogFactory.getLog(PingOperation.class);
private final boolean releaseChannel;
private final PingResponse.Decoder responseBuilder;
public PingOperation(OperationContext operationContext, boolean releaseChannel) {
this(operationContext, PING_REQUEST, PING_RESPONSE, releaseChannel);
}
protected PingOperation(OperationContext operationContext, short requestCode, short responseCode, boolean releaseChannel) {
super(operationContext, requestCode, responseCode, CacheOptions.DEFAULT);
this.releaseChannel = releaseChannel;
this.responseBuilder = new PingResponse.Decoder(operationContext.getConfiguration().version());
}
@Override
public void invoke(Channel channel) {
sendHeaderAndRead(channel);
if (releaseChannel) {
releaseChannel(channel);
}
}
@Override
public void cancel(SocketAddress address, Throwable cause) {
completeExceptionally(cause);
}
@Override
public CompletableFuture execute() {
throw new UnsupportedOperationException("Cannot execute directly");
}
@Override
public void acceptResponse(ByteBuf buf, short status, HeaderDecoder decoder) {
responseBuilder.processResponse(operationContext.getCodec(), buf, decoder);
if (HotRodConstants.isSuccess(status)) {
PingResponse pingResponse = responseBuilder.build(status);
if (pingResponse.getVersion() != null && operationContext.getConfiguration().version() == ProtocolVersion.PROTOCOL_VERSION_AUTO) {
operationContext.setCodec(Codec.forProtocol(pingResponse.getVersion()));
}
complete(pingResponse);
} else {
String hexStatus = Integer.toHexString(status);
if (log.isTraceEnabled())
log.tracef("Unknown response status: %s", hexStatus);
throw new InvalidResponseException("Unexpected response status: " + hexStatus);
}
}
@Override
public void exceptionCaught(Channel channel, Throwable cause) {
while (cause instanceof DecoderException && cause.getCause() != null) {
cause = cause.getCause();
}
PingResponse pingResponse = new PingResponse(cause);
if (pingResponse.isCacheNotFound()) {
complete(pingResponse);
} else {
super.exceptionCaught(channel, cause);
}
}
}