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

io.tarantool.driver.handlers.TarantoolResponseHandler Maven / Gradle / Ivy

package io.tarantool.driver.handlers;

import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.SimpleChannelInboundHandler;
import io.netty.handler.codec.DecoderException;
import io.tarantool.driver.core.RequestFutureManager;
import io.tarantool.driver.core.TarantoolRequestMetadata;
import io.tarantool.driver.exceptions.TarantoolDecoderException;
import io.tarantool.driver.exceptions.errors.TarantoolErrors;
import io.tarantool.driver.protocol.TarantoolErrorResult;
import io.tarantool.driver.protocol.TarantoolOkResult;
import io.tarantool.driver.protocol.TarantoolResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.concurrent.CompletableFuture;

/**
 * Basic Tarantool server response handler. Dispatches incoming message either to an error or a normal result handler.
 *
 * @author Alexey Kuzin
 */
public class TarantoolResponseHandler extends SimpleChannelInboundHandler {

    private final Logger log = LoggerFactory.getLogger(TarantoolResponseHandler.class);
    private final TarantoolErrors.TarantoolBoxErrorFactory boxErrorFactory
        = new TarantoolErrors.TarantoolBoxErrorFactory();
    private final RequestFutureManager futureManager;

    public TarantoolResponseHandler(RequestFutureManager futureManager) {
        super();
        this.futureManager = futureManager;
    }

    @Override
    protected void channelRead0(ChannelHandlerContext ctx, TarantoolResponse tarantoolResponse) throws Exception {
        TarantoolRequestMetadata requestMeta = futureManager.getRequest(tarantoolResponse.getSyncId());
        if (requestMeta != null) {
            CompletableFuture requestFuture = requestMeta.getFuture();
            if (!requestFuture.isDone()) {
                switch (tarantoolResponse.getResponseType()) {
                    case IPROTO_NOT_OK:
                        TarantoolErrorResult errorResult = new TarantoolErrorResult(tarantoolResponse.getSyncId(),
                            tarantoolResponse.getResponseCode(), tarantoolResponse.getBody().getData());
                        requestFuture.completeExceptionally(boxErrorFactory.create(errorResult));
                        break;
                    case IPROTO_OK:
                        try {
                            TarantoolOkResult okResult = new TarantoolOkResult(tarantoolResponse.getSyncId(),
                                tarantoolResponse.getBody().getData());
                            requestFuture.complete(requestMeta.getMapper().fromValue(okResult.getData()));
                        } catch (Throwable e) {
                            requestFuture.completeExceptionally(e);
                        }
                }
            }
        } else {
            log.info("Request {} is not registered in this client instance", tarantoolResponse.getSyncId());
        }
    }

    @Override
    public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
        if (cause instanceof DecoderException && cause.getCause() instanceof TarantoolDecoderException) {
            TarantoolDecoderException ex = (TarantoolDecoderException) cause.getCause();
            TarantoolRequestMetadata requestMeta = futureManager.getRequest(ex.getHeader().getSync());
            if (requestMeta != null) {
                CompletableFuture requestFuture = requestMeta.getFuture();
                if (!requestFuture.isDone()) {
                    requestFuture.completeExceptionally(cause);
                    return;
                }
            }
        }
        super.exceptionCaught(ctx, cause);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy