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

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

package io.tarantool.driver.api;

import io.tarantool.driver.api.tuple.TarantoolTuple;
import io.tarantool.driver.core.TarantoolClientBuilderImpl;
import io.tarantool.driver.core.TarantoolClientConfiguratorImpl;

/**
 * Tarantool client factory interface.
 * 

* It provides a builder interface helping to create the basic Tarantool client types while hiding the internal client * implementation details from the user. * *

* Here are some examples of using this client factory: *

 * 
 *
 * // Create a client instance with default settings. This client can connect to a local Tarantool process listening the
 * default port 3301 (do not forget enabling it by executing this command in console: `box.cfg{ listen = 3301 }`).
 * TarantoolClientFactory.createClient().build();
 *
 * // Create a client instance for a single server with custom credentials
 * TarantoolClientFactory.createClient()
 *             .withAddress(new TarantoolServerAddress("123.123.123.123", 3333))
 *             .withCredentials(new SimpleTarantoolCredentials("root", "passwd"))
 *             .build();
 *
 * // Create a client instance with custom proxy operations mapping
 * TarantoolClientFactory.createClient()
 *             .withAddress(new TarantoolServerAddress("123.123.123.123", 3333))
 *             .withCredentials(new SimpleTarantoolCredentials("root", "passwd"))
 *             .withProxyMethodMapping(builder -> builder.withDeleteFunctionName("custom_delete"))
 *             .build();
 *
 * // Create a client instance with request retry policy
 * TarantoolClientFactory.createClient()
 *            .withAddress(new TarantoolServerAddress("123.123.123.123", 3333))
 *            .withCredentials(new SimpleTarantoolCredentials("root", "passwd"))
 *            .withRetryingByNumberOfAttempts(5, throwable -> throwable.getMessage().equals("Some error"),
 *                   policy -> policy.withDelay(500)
 *                           .withRequestTimeout(1000)
 *            .withConnectionSelectionStrategy(PARALLEL_ROUND_ROBIN)
 *            .build();
 *
 * // Create a client instance with proxy operations mapping and request retry policy
 * TarantoolClientFactory.createClient()
 *           .withAddress(new TarantoolServerAddress("123.123.123.123", 3333))
 *           .withCredentials(new SimpleTarantoolCredentials("root", "passwd"))
 *           .withConnectionSelectionStrategy(PARALLEL_ROUND_ROBIN)
 *           .withProxyMethodMapping(builder -> builder.withReplaceFunctionName("custom_replace")
 *                   .withTruncateFunctionName("create"))
 *           .withRetryingByNumberOfAttempts(5, throwable -> throwable.getMessage().equals("Some error"),
 *                   policy -> policy.withDelay(500)
 *                           .withRequestTimeout(1000)
 *           ).build();
 *
 * // Create a client instance with request retry policy from an existing configured client
 * TarantoolClientFactory.configureClient(client)
 *           .withRetryingByNumberOfAttempts(5, throwable -> throwable.getMessage().equals("Some error"),
 *                   policy -> policy.withDelay(500)
 *                           .withRequestTimeout(1000)
 *           ).build();
 *
 * // Create a client instance with proxy operations mapping from an existing configured client
 * TarantoolClientFactory.configureClient(client)
 *          .withProxyMethodMapping(mapping -> mapping.withDeleteFunctionName("custom_delete"))
 *          .build();
 *
 * 
 * 
* * @author Oleg Kuznetsov */ public interface TarantoolClientFactory { /** * Create a new client instance. Provides a builder interface. * * @return Tarantool client builder {@link TarantoolClientBuilder} */ static TarantoolClientBuilder createClient() { return new TarantoolClientBuilderImpl(); } /** * Configure an existing client instance and return a copy of it. Provides a builder interface. * * @param client client instance * @param configurator builder type * @return Tarantool client configurator {@link TarantoolClientConfigurator} */ @SuppressWarnings("unchecked") static > T configureClient( TarantoolClient> client) { return (T) new TarantoolClientConfiguratorImpl<>(client); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy