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

io.tarantool.driver.protocol.TarantoolRequest Maven / Gradle / Ivy

package io.tarantool.driver.protocol;

import io.tarantool.driver.exceptions.TarantoolDecoderException;
import io.tarantool.driver.mappers.MessagePackObjectMapper;
import org.msgpack.core.MessagePackException;
import org.msgpack.core.MessagePacker;

import java.io.IOException;
import java.util.concurrent.atomic.AtomicLong;
import java.util.function.Supplier;

/**
 * Base class for all kinds of requests to Tarantool server.
 * See 
 * https://www.tarantool.io/en/doc/2.3/dev_guide/internals/box_protocol/#binary-protocol-requests
 *
 * @author Alexey Kuzin
 */
public class TarantoolRequest {

    private static final AtomicLong syncId = new AtomicLong(0);
    private static final Supplier syncIdSupplier =
        () -> syncId.updateAndGet(n -> (n >= Long.MAX_VALUE) ? 1 : n + 1);

    private final TarantoolHeader header;
    private final TarantoolRequestBody body;

    /**
     * Basic constructor. Sets an auto-incremented request ID into the Tarantool packet header.
     *
     * @param type request type code supported by Tarantool
     * @param body request body, may be empty
     * @see TarantoolRequestType
     */
    public TarantoolRequest(TarantoolRequestType type, TarantoolRequestBody body) {
        this.header = new TarantoolHeader(syncIdSupplier.get(), type.getCode());
        this.body = body;
    }

    /**
     * Get header
     *
     * @return header instance
     */
    public TarantoolHeader getHeader() {
        return header;
    }

    /**
     * Get body
     *
     * @return instance of a {@link Packable}
     */
    public Packable getBody() {
        return body;
    }

    /**
     * Encode incapsulated data using {@link MessagePacker}
     *
     * @param packer configured {@link MessagePacker}
     * @param mapper object-to-entity mapper
     * @throws TarantoolDecoderException if encoding failed
     */
    public void toMessagePack(MessagePacker packer, MessagePackObjectMapper mapper)
        throws TarantoolDecoderException {
        try {
            packer.packValue(header.toMessagePackValue(mapper));
            packer.packValue(body.toMessagePackValue(mapper));
        } catch (IOException | MessagePackException e) {
            throw new TarantoolDecoderException(header, e);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy