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

io.tarantool.driver.core.ClusterTarantoolTupleClient Maven / Gradle / Ivy

package io.tarantool.driver.core;

import io.tarantool.driver.api.TarantoolClientConfig;
import io.tarantool.driver.api.TarantoolClusterAddressProvider;
import io.tarantool.driver.api.TarantoolResult;
import io.tarantool.driver.api.TarantoolServerAddress;
import io.tarantool.driver.api.connection.TarantoolConnectionSelectionStrategies.ParallelRoundRobinStrategyFactory;
import io.tarantool.driver.api.metadata.TarantoolMetadataOperations;
import io.tarantool.driver.api.metadata.TarantoolSpaceMetadata;
import io.tarantool.driver.api.space.TarantoolSpaceOperations;
import io.tarantool.driver.api.tuple.TarantoolTuple;
import io.tarantool.driver.auth.SimpleTarantoolCredentials;
import io.tarantool.driver.auth.TarantoolCredentials;
import io.tarantool.driver.core.connection.TarantoolConnectionManager;
import io.tarantool.driver.core.space.TarantoolTupleSpace;

import java.util.Collection;
import java.util.Collections;

/**
 * {@link ClusterTarantoolClient} implementation for working with default tuples
 *
 * @author Alexey Kuzin
 */
public class ClusterTarantoolTupleClient
    extends ClusterTarantoolClient> {

    /**
     * Create a client. Default guest credentials will be used. Connects to a Tarantool server on localhost using the
     * default port (3301)
     */
    public ClusterTarantoolTupleClient() {
        this(new SimpleTarantoolCredentials());
    }

    /**
     * Create a client using provided credentials information. Connects to a Tarantool server on localhost using
     * the default port (3301)
     *
     * @param credentials Tarantool user credentials holder
     * @see TarantoolCredentials
     */
    public ClusterTarantoolTupleClient(TarantoolCredentials credentials) {
        this(credentials, Collections.singletonList(new TarantoolServerAddress()));
    }

    /**
     * Create a client using provided credentials information. Connects to a Tarantool server using the specified
     * host and port.
     *
     * @param credentials Tarantool user credentials holder
     * @param host        valid host name or IP address
     * @param port        valid port number
     * @see TarantoolCredentials
     */
    public ClusterTarantoolTupleClient(TarantoolCredentials credentials, String host, int port) {
        this(credentials, Collections.singletonList(new TarantoolServerAddress(host, port)));
    }

    /**
     * Create a client. Connects to a Tarantool server using the specified host and port.
     *
     * @param config client configuration
     * @param host   valid host name or IP address
     * @param port   valid port number
     * @see TarantoolCredentials
     */
    public ClusterTarantoolTupleClient(TarantoolClientConfig config, String host, int port) {
        this(config, Collections.singletonList(new TarantoolServerAddress(host, port)));
    }

    /**
     * Create a client using provided credentials information. Connects to a Tarantool server using the specified
     * server address.
     *
     * @param credentials Tarantool user credentials holder
     * @param address     single Tarantool server address
     * @see TarantoolCredentials
     * @see TarantoolServerAddress
     */
    public ClusterTarantoolTupleClient(TarantoolCredentials credentials, TarantoolServerAddress address) {
        this(TarantoolClientConfig.builder()
                .withCredentials(credentials)
                .build(),
            address);
    }

    /**
     * Create a client. Connects to a Tarantool server using the specified
     * server address.
     *
     * @param config  client configuration
     * @param address single Tarantool server address
     * @see TarantoolCredentials
     * @see TarantoolServerAddress
     */
    public ClusterTarantoolTupleClient(TarantoolClientConfig config, TarantoolServerAddress address) {
        this(config, () -> Collections.singletonList(address));
    }

    /**
     * Create a client using provided credentials information. Connects to a list of Tarantool servers using the
     * specified set of server addresses.
     *
     * @param credentials Tarantool user credentials holder
     * @param addresses   Tarantool server addresses
     * @see TarantoolCredentials
     * @see TarantoolServerAddress
     */
    public ClusterTarantoolTupleClient(TarantoolCredentials credentials, Collection addresses) {
        this(TarantoolClientConfig.builder()
                .withCredentials(credentials)
                .withConnectionSelectionStrategyFactory(ParallelRoundRobinStrategyFactory.INSTANCE)
                .build(),
            () -> addresses);
    }

    /**
     * Create a client. Connects to a list of Tarantool servers using the specified set of server addresses.
     *
     * @param config    client configuration
     * @param addresses Tarantool server addresses
     * @see TarantoolCredentials
     * @see TarantoolServerAddress
     */
    public ClusterTarantoolTupleClient(TarantoolClientConfig config, Collection addresses) {
        this(config, () -> addresses);
    }

    /**
     * Create a client. Connect using the list of Tarantool servers returned by the specified server address provider.
     *
     * @param config          client configuration
     * @param addressProvider provides Tarantool server address for connection
     * @see TarantoolClientConfig
     */
    public ClusterTarantoolTupleClient(TarantoolClientConfig config, TarantoolClusterAddressProvider addressProvider) {
        super(config, addressProvider);
    }

    @Override
    protected TarantoolSpaceOperations>
    spaceOperations(
        TarantoolClientConfig config, TarantoolConnectionManager connectionManager,
        TarantoolMetadataOperations metadata, TarantoolSpaceMetadata spaceMetadata) {
        return new TarantoolTupleSpace(this, config, connectionManager, metadata, spaceMetadata);
    }

    protected TarantoolClusterAddressProvider getAddressProvider() {
        return super.getAddressProvider();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy