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

io.tarantool.driver.api.MessagePackMapperBuilder Maven / Gradle / Ivy

package io.tarantool.driver.api;

import io.tarantool.driver.mappers.DefaultMessagePackMapper;
import io.tarantool.driver.mappers.MessagePackMapper;
import io.tarantool.driver.mappers.converters.ObjectConverter;
import io.tarantool.driver.mappers.converters.ValueConverter;
import org.msgpack.value.Value;
import org.msgpack.value.ValueType;

import java.util.List;
import java.util.Map;

/**
 * Builder for {@link MessagePackMapper}
 */
public interface MessagePackMapperBuilder {
    /**
     * Configure the mapper with default {@code MP_MAP} entity to {@link Map} converter
     *
     * @return builder
     */
    MessagePackMapperBuilder withDefaultMapValueConverter();

    /**
     * Configure the mapper with default {@link Map} to {@code MP_MAP} entity converter
     *
     * @return builder
     */
    MessagePackMapperBuilder withDefaultMapObjectConverter();

    /**
     * Configure the mapper with default {@code MP_ARRAY} entity to {@link List} converter
     *
     * @return builder
     */
    MessagePackMapperBuilder withDefaultArrayValueConverter();

    /**
     * Configure the mapper with default {@link List} to {@code MP_ARRAY} entity converter
     *
     * @return builder
     */
    MessagePackMapperBuilder withDefaultListObjectConverter();

    /**
     * Configure the mapper with a specified MessagePack entity-to-object converter
     *
     * @param valueType MessagePack source type
     * @param converter MessagePack entity-to-object and object-to-entity converter
     * @param        MessagePack's entity type that the converter accepts and/or returns
     * @param        java object's type that the converter accepts and/or returns
     * @return builder
     * @see io.tarantool.driver.mappers.DefaultMessagePackMapper#registerValueConverter(ValueType, ValueConverter)
     */
     MessagePackMapperBuilder
    withValueConverter(ValueType valueType, ValueConverter converter);

    /**
     * Configure the mapper with a specified MessagePack entity-to-object converter
     *
     * @param valueType   MessagePack source type
     * @param objectClass target object class
     * @param converter   MessagePack entity-to-object and object-to-entity converter
     * @param          MessagePack's entity type that the converter accepts and/or returns
     * @param          java object's type that the converter accepts and/or returns
     * @return builder
     * @see DefaultMessagePackMapper#registerValueConverter(ValueType, Class, ValueConverter)
     */
     MessagePackMapperBuilder withValueConverter(
        ValueType valueType,
        Class objectClass,
        ValueConverter converter);

    /**
     * Configure the mapper with a specified MessagePack object-to-entity converter
     *
     * @param converter MessagePack entity-to-object and object-to-entity converter
     * @param        MessagePack's entity type that the converter accepts and/or returns
     * @param        java object's type that the converter accepts and/or returns
     * @return builder
     */
     MessagePackMapperBuilder withObjectConverter(ObjectConverter converter);

    /**
     * Configure the mapper with a specified MessagePack object-to-entity converter
     *
     * @param objectClass source object class
     * @param converter   MessagePack entity-to-object and object-to-entity converter
     * @param          MessagePack's entity type that the converter accepts and/or returns
     * @param          java object's type that the converter accepts and/or returns
     * @return builder
     */
     MessagePackMapperBuilder withObjectConverter(
        Class objectClass,
        ObjectConverter converter);

    /**
     * Configure the mapper with a specified MessagePack object-to-entity converter
     *
     * @param objectClass source object class
     * @param valueClass  target object class
     * @param converter   MessagePack entity-to-object and object-to-entity converter
     * @param          MessagePack entity type
     * @param          object type
     * @return builder
     */
     MessagePackMapperBuilder withObjectConverter(
        Class objectClass, Class valueClass,
        ObjectConverter converter);

    /**
     * Build the mapper instance
     *
     * @return a new mapper instance
     */
    MessagePackMapper build();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy