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

io.tarantool.driver.core.space.RetryingTarantoolSpace Maven / Gradle / Ivy

package io.tarantool.driver.core.space;

import io.tarantool.driver.api.conditions.Conditions;
import io.tarantool.driver.api.cursor.TarantoolCursor;
import io.tarantool.driver.api.metadata.TarantoolSpaceMetadata;
import io.tarantool.driver.api.retry.RequestRetryPolicy;
import io.tarantool.driver.api.retry.RequestRetryPolicyFactory;
import io.tarantool.driver.api.space.TarantoolSpaceOperations;
import io.tarantool.driver.api.space.options.DeleteOptions;
import io.tarantool.driver.api.space.options.InsertManyOptions;
import io.tarantool.driver.api.space.options.InsertOptions;
import io.tarantool.driver.api.space.options.ReplaceManyOptions;
import io.tarantool.driver.api.space.options.ReplaceOptions;
import io.tarantool.driver.api.space.options.SelectOptions;
import io.tarantool.driver.api.space.options.UpdateOptions;
import io.tarantool.driver.api.space.options.UpsertOptions;
import io.tarantool.driver.api.tuple.operations.TupleOperations;
import io.tarantool.driver.exceptions.TarantoolClientException;
import io.tarantool.driver.protocol.Packable;

import java.util.Collection;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.Executor;
import java.util.function.Supplier;

/**
 * Wrapper for {@link TarantoolSpaceOperations} instances which adds request retry policy to each operation
 *
 * @param  target tuple type
 * @param  target tuple collection type
 * @author Alexey Kuzin
 */
public class RetryingTarantoolSpace>
    implements TarantoolSpaceOperations {

    private final TarantoolSpaceOperations spaceOperations;
    private final RequestRetryPolicyFactory retryPolicyFactory;
    private final Executor executor;

    /**
     * Basic constructor
     *
     * @param spaceOperations    {@link TarantoolSpaceOperations} instance which operations will be wrapped
     * @param retryPolicyFactory request retrying policy factory
     * @param executor           executor service for retry callbacks
     */
    public RetryingTarantoolSpace(
        TarantoolSpaceOperations spaceOperations,
        RequestRetryPolicyFactory retryPolicyFactory,
        Executor executor) {
        this.spaceOperations = spaceOperations;
        this.retryPolicyFactory = retryPolicyFactory;
        this.executor = executor;
    }

    @Override
    public CompletableFuture delete(Conditions conditions)
        throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.delete(conditions));
    }

    @Override
    public CompletableFuture delete(Conditions conditions, DeleteOptions options)
        throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.delete(conditions, options));
    }

    @Override
    public CompletableFuture insert(T tuple) throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.insert(tuple));
    }

    @Override
    public CompletableFuture insert(T tuple, InsertOptions options) throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.insert(tuple, options));
    }

    @Override
    public CompletableFuture insertMany(Collection tuples) throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.insertMany(tuples));
    }

    @Override
    public CompletableFuture insertMany(Collection tuples, InsertManyOptions options)
        throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.insertMany(tuples, options));
    }

    @Override
    public CompletableFuture replace(T tuple)
        throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.replace(tuple));
    }

    @Override
    public CompletableFuture replace(T tuple, ReplaceOptions options)
        throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.replace(tuple, options));
    }

    @Override
    public CompletableFuture replaceMany(Collection tuples)
        throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.replaceMany(tuples));
    }

    @Override
    public CompletableFuture replaceMany(Collection tuples, ReplaceManyOptions options)
        throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.replaceMany(tuples, options));
    }

    @Override
    public CompletableFuture select(Conditions conditions)
        throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.select(conditions));
    }

    @Override
    public CompletableFuture select(Conditions conditions, SelectOptions options)
        throws TarantoolClientException {
        return wrapOperation(() -> spaceOperations.select(conditions, options));
    }

    @Override
    public CompletableFuture update(Conditions conditions, T tuple) {
        return wrapOperation(() -> spaceOperations.update(conditions, tuple));
    }

    @Override
    public CompletableFuture update(Conditions conditions, T tuple, UpdateOptions options) {
        return wrapOperation(() -> spaceOperations.update(conditions, tuple, options));
    }

    @Override
    public CompletableFuture update(Conditions conditions, TupleOperations operations) {
        return wrapOperation(() -> spaceOperations.update(conditions, operations));
    }

    @Override
    public CompletableFuture update(Conditions conditions, TupleOperations operations, UpdateOptions options) {
        return wrapOperation(() -> spaceOperations.update(conditions, operations, options));
    }

    @Override
    public CompletableFuture upsert(Conditions conditions, T tuple, TupleOperations operations) {
        return wrapOperation(() -> spaceOperations.upsert(conditions, tuple, operations));
    }

    @Override
    public CompletableFuture upsert(
        Conditions conditions, T tuple, TupleOperations operations,
        UpsertOptions options) {
        return wrapOperation(() -> spaceOperations.upsert(conditions, tuple, operations, options));
    }

    @Override
    public CompletableFuture truncate() throws TarantoolClientException {
        return wrapVoidOperation(spaceOperations::truncate);
    }

    @Override
    public TarantoolSpaceMetadata getMetadata() {
        return spaceOperations.getMetadata();
    }

    @Override
    public TarantoolCursor cursor(Conditions conditions, int batchSize) {
        return spaceOperations.cursor(conditions, batchSize);
    }

    @Override
    public TarantoolCursor cursor(Conditions conditions) {
        return spaceOperations.cursor(conditions);
    }

    private CompletableFuture wrapOperation(Supplier> operation) {
        RequestRetryPolicy retryPolicy = retryPolicyFactory.create();
        return retryPolicy.wrapOperation(operation, executor);
    }

    private CompletableFuture wrapVoidOperation(Supplier> operation) {
        RequestRetryPolicy retryPolicy = retryPolicyFactory.create();
        return retryPolicy.wrapOperation(operation, executor);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy