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

io.quarkus.redis.datasource.ReactiveRedisDataSource Maven / Gradle / Ivy

There is a newer version: 3.18.0.CR1
Show newest version
package io.quarkus.redis.datasource;

import static io.quarkus.redis.runtime.datasource.Marshaller.STRING_TYPE_REFERENCE;

import java.util.function.BiFunction;
import java.util.function.Function;

import com.fasterxml.jackson.core.type.TypeReference;

import io.quarkus.redis.datasource.autosuggest.ReactiveAutoSuggestCommands;
import io.quarkus.redis.datasource.bitmap.ReactiveBitMapCommands;
import io.quarkus.redis.datasource.bloom.ReactiveBloomCommands;
import io.quarkus.redis.datasource.countmin.ReactiveCountMinCommands;
import io.quarkus.redis.datasource.cuckoo.ReactiveCuckooCommands;
import io.quarkus.redis.datasource.geo.ReactiveGeoCommands;
import io.quarkus.redis.datasource.graph.ReactiveGraphCommands;
import io.quarkus.redis.datasource.hash.ReactiveHashCommands;
import io.quarkus.redis.datasource.hyperloglog.ReactiveHyperLogLogCommands;
import io.quarkus.redis.datasource.json.ReactiveJsonCommands;
import io.quarkus.redis.datasource.keys.ReactiveKeyCommands;
import io.quarkus.redis.datasource.list.ReactiveListCommands;
import io.quarkus.redis.datasource.pubsub.ReactivePubSubCommands;
import io.quarkus.redis.datasource.search.ReactiveSearchCommands;
import io.quarkus.redis.datasource.set.ReactiveSetCommands;
import io.quarkus.redis.datasource.sortedset.ReactiveSortedSetCommands;
import io.quarkus.redis.datasource.stream.ReactiveStreamCommands;
import io.quarkus.redis.datasource.string.ReactiveStringCommands;
import io.quarkus.redis.datasource.timeseries.ReactiveTimeSeriesCommands;
import io.quarkus.redis.datasource.topk.ReactiveTopKCommands;
import io.quarkus.redis.datasource.transactions.OptimisticLockingTransactionResult;
import io.quarkus.redis.datasource.transactions.ReactiveTransactionalRedisDataSource;
import io.quarkus.redis.datasource.transactions.TransactionResult;
import io.quarkus.redis.datasource.transactions.TransactionalRedisDataSource;
import io.quarkus.redis.datasource.value.ReactiveValueCommands;
import io.smallrye.common.annotation.Experimental;
import io.smallrye.mutiny.Uni;
import io.vertx.mutiny.redis.client.Command;
import io.vertx.mutiny.redis.client.Redis;
import io.vertx.mutiny.redis.client.Response;

/**
 * Non-Blocking and Reactive Redis Data Source.
 * 

* This class provides access to various groups of methods. Each method execute a Redis {@code command}. * Groups and methods are type-safe. The decomposition follows the Redis API group. *

* NOTE: Not all commands are exposed from this API. This is done on purpose. You can always use the low-level Redis * client to execute others commands. */ public interface ReactiveRedisDataSource { /** * Retrieves a {@link ReactiveRedisDataSource} using a single connection with the Redis Server. * The connection is acquired from the pool and released when the {@code Uni} returned by {@code function} produces * a {@code null} item or a failure. * * @param function the function receiving the single-connection data source and producing {@code null} when the * connection can be released. */ Uni withConnection(Function> function); /** * Retrieves a {@link RedisDataSource} enqueuing commands in a Redis Transaction ({@code MULTI}). * Note that transaction acquires a single connection, and all the commands are enqueued in this connection. * The commands are only executed when the passed block emits the {@code null} item. *

* The results of the commands are retrieved using the produced {@link TransactionResult}. *

* The user can discard a transaction using the {@link TransactionalRedisDataSource#discard()} method. * In this case, the produced {@link TransactionResult} will be empty. * * @param tx the consumer receiving the transactional redis data source. The enqueued commands are only executed * at the end of the block. */ Uni withTransaction(Function> tx); /** * Retrieves a {@link RedisDataSource} enqueuing commands in a Redis Transaction ({@code MULTI}). * Note that transaction acquires a single connection, and all the commands are enqueued in this connection. * The commands are only executed when the passed block emits the {@code null} item. *

* The results of the commands are retrieved using the produced {@link TransactionResult}. *

* The user can discard a transaction using the {@link TransactionalRedisDataSource#discard()} method. * In this case, the produced {@link TransactionResult} will be empty. * * @param tx the consumer receiving the transactional redis data source. The enqueued commands are only executed * at the end of the block. * @param watchedKeys the keys to watch during the execution of the transaction. If one of these key is modified before * the completion of the transaction, the transaction is discarded. */ Uni withTransaction(Function> tx, String... watchedKeys); /** * Retrieves a {@link RedisDataSource} enqueuing commands in a Redis Transaction ({@code MULTI}). * Note that transaction acquires a single connection, and all the commands are enqueued in this connection. * The commands are only executed when the passed block emits the {@code null} item. *

* This variant also allows executing code before the transaction gets started but after the key being watched: * *

     *     WATCH key
     *     // preTxBlock
     *     element = ZRANGE k 0 0
     *     // TxBlock
     *     MULTI
     *        ZREM k element
     *     EXEC
     * 
*

* The {@code preTxBlock} returns a {@link Uni Uni<I>}. The produced value is received by the {@code tx} block, * which can use that value to execute the appropriate operation in the transaction. The produced value can also be * retrieved from the produced {@link OptimisticLockingTransactionResult}. Commands issued in the {@code preTxBlock } * must used the passed (single-connection) {@link ReactiveRedisDataSource} instance. *

* If the {@code preTxBlock} throws an exception or emits a failure, the transaction is not executed, and the returned * {@link OptimisticLockingTransactionResult} is empty. *

* This construct allows implementing operation relying on optimistic locking. * The results of the commands are retrieved using the produced {@link OptimisticLockingTransactionResult}. *

* The user can discard a transaction using the {@link TransactionalRedisDataSource#discard()} method. * In this case, the produced {@link OptimisticLockingTransactionResult} will be empty. * * @param tx the consumer receiving the transactional redis data source. The enqueued commands are only executed * at the end of the block. * @param watchedKeys the keys to watch during the execution of the transaction. If one of these key is modified before * the completion of the transaction, the transaction is discarded. */ Uni> withTransaction(Function> preTxBlock, BiFunction> tx, String... watchedKeys); /** * Execute the command SELECT. * Summary: Change the selected database for the current connection * Group: connection * Requires Redis 1.0.0 *

* This method is expected to be used inside a {@link #withConnection(Function)} block. * * @param index the database index. **/ Uni select(long index); /** * Execute the command FLUSHALL. * Summary: Remove all keys from all databases * Group: server * Requires Redis 1.0.0 **/ Uni flushall(); /** * Gets the object to execute commands manipulating hashes (a.k.a. {@code Map<F, V>}). *

* If you want to use a hash of {@code <String -> Person>} stored using String identifier, you would use: * {@code hash(String.class, String.class, Person.class)}. * If you want to use a hash of {@code <String -> Person>} stored using UUID identifier, you would use: * {@code hash(UUID.class, String.class, Person.class)}. * * @param redisKeyType the class of the keys * @param fieldType the class of the fields * @param valueType the class of the values * @param the type of the redis key * @param the type of the fields (map's keys) * @param the type of the value * @return the object to execute commands manipulating hashes (a.k.a. {@code Map<K, V>}). */ ReactiveHashCommands hash(Class redisKeyType, Class fieldType, Class valueType); /** * Gets the object to execute commands manipulating hashes (a.k.a. {@code Map<F, V>}). *

* If you want to use a hash of {@code <String -> Person>} stored using String identifier, you would use: * {@code hash(String.class, String.class, Person.class)}. * If you want to use a hash of {@code <String -> Person>} stored using UUID identifier, you would use: * {@code hash(UUID.class, String.class, Person.class)}. * * @param redisKeyType the class of the keys * @param fieldType the class of the fields * @param valueType the class of the values * @param the type of the redis key * @param the type of the fields (map's keys) * @param the type of the value * @return the object to execute commands manipulating hashes (a.k.a. {@code Map<K, V>}). */ ReactiveHashCommands hash(TypeReference redisKeyType, TypeReference fieldType, TypeReference valueType); /** * Gets the object to execute commands manipulating hashes (a.k.a. {@code Map<String, V>}). *

* This is a shortcut on {@code hash(String.class, String.class, V)} * * @param typeOfValue the class of the values * @param the type of the value * @return the object to execute commands manipulating hashes (a.k.a. {@code Map<String, V>}). */ default ReactiveHashCommands hash(Class typeOfValue) { return hash(String.class, String.class, typeOfValue); } /** * Gets the object to execute commands manipulating hashes (a.k.a. {@code Map<String, V>}). *

* This is a shortcut on {@code hash(String.class, String.class, V)} * * @param typeOfValue the class of the values * @param the type of the value * @return the object to execute commands manipulating hashes (a.k.a. {@code Map<String, V>}). */ default ReactiveHashCommands hash(TypeReference typeOfValue) { return hash(STRING_TYPE_REFERENCE, STRING_TYPE_REFERENCE, typeOfValue); } /** * Gets the object to execute commands manipulating geo items (a.k.a. {@code {longitude, latitude, member}}). *

* {@code V} represents the type of the member, i.e. the localized thing. * * @param redisKeyType the class of the keys * @param memberType the class of the members * @param the type of the redis key * @param the type of the member * @return the object to execute geo commands. */ ReactiveGeoCommands geo(Class redisKeyType, Class memberType); /** * Gets the object to execute commands manipulating geo items (a.k.a. {@code {longitude, latitude, member}}). *

* {@code V} represents the type of the member, i.e. the localized thing. * * @param redisKeyType the class of the keys * @param memberType the class of the members * @param the type of the redis key * @param the type of the member * @return the object to execute geo commands. */ ReactiveGeoCommands geo(TypeReference redisKeyType, TypeReference memberType); /** * Gets the object to execute commands manipulating geo items (a.k.a. {@code {longitude, latitude, member}}). *

* {@code V} represents the type of the member, i.e. the localized thing. * * @param memberType the class of the members * @param the type of the member * @return the object to execute geo commands. */ default ReactiveGeoCommands geo(Class memberType) { return geo(String.class, memberType); } /** * Gets the object to execute commands manipulating geo items (a.k.a. {@code {longitude, latitude, member}}). *

* {@code V} represents the type of the member, i.e. the localized thing. * * @param memberType the class of the members * @param the type of the member * @return the object to execute geo commands. */ default ReactiveGeoCommands geo(TypeReference memberType) { return geo(STRING_TYPE_REFERENCE, memberType); } /** * Gets the object to execute commands manipulating keys and expiration times. * * @param redisKeyType the type of the keys * @param the type of the key * @return the object to execute commands manipulating keys. */ ReactiveKeyCommands key(Class redisKeyType); /** * Gets the object to execute commands manipulating keys and expiration times. * * @param redisKeyType the type of the keys * @param the type of the key * @return the object to execute commands manipulating keys. */ ReactiveKeyCommands key(TypeReference redisKeyType); /** * Gets the object to execute commands manipulating keys and expiration times. * * @return the object to execute commands manipulating keys. */ default ReactiveKeyCommands key() { return key(String.class); } /** * Gets the object to execute commands manipulating sorted sets. * * @param redisKeyType the type of the keys * @param valueType the type of the value sorted in the sorted sets * @param the type of the key * @param the type of the value * @return the object to manipulate sorted sets. */ ReactiveSortedSetCommands sortedSet(Class redisKeyType, Class valueType); /** * Gets the object to execute commands manipulating sorted sets. * * @param redisKeyType the type of the keys * @param valueType the type of the value sorted in the sorted sets * @param the type of the key * @param the type of the value * @return the object to manipulate sorted sets. */ ReactiveSortedSetCommands sortedSet(TypeReference redisKeyType, TypeReference valueType); /** * Gets the object to execute commands manipulating sorted sets. * * @param valueType the type of the value sorted in the sorted sets * @param the type of the value * @return the object to manipulate sorted sets. */ default ReactiveSortedSetCommands sortedSet(Class valueType) { return sortedSet(String.class, valueType); } /** * Gets the object to execute commands manipulating sorted sets. * * @param valueType the type of the value sorted in the sorted sets * @param the type of the value * @return the object to manipulate sorted sets. */ default ReactiveSortedSetCommands sortedSet(TypeReference valueType) { return sortedSet(STRING_TYPE_REFERENCE, valueType); } /** * Gets the object to execute commands manipulating stored strings. *

* NOTE: Instead of {@code string}, this group is named {@code value} to avoid the confusion with the * Java String type. Indeed, Redis strings can be strings, numbers, byte arrays... * * @param redisKeyType the type of the keys * @param valueType the type of the value, often String, or the value are encoded/decoded using codecs. * @param the type of the key * @param the type of the value * @return the object to manipulate stored strings. */ ReactiveValueCommands value(Class redisKeyType, Class valueType); /** * Gets the object to execute commands manipulating stored strings. *

* NOTE: Instead of {@code string}, this group is named {@code value} to avoid the confusion with the * Java String type. Indeed, Redis strings can be strings, numbers, byte arrays... * * @param redisKeyType the type of the keys * @param valueType the type of the value, often String, or the value are encoded/decoded using codecs. * @param the type of the key * @param the type of the value * @return the object to manipulate stored strings. */ ReactiveValueCommands value(TypeReference redisKeyType, TypeReference valueType); /** * Gets the object to execute commands manipulating stored strings. *

* NOTE: Instead of {@code string}, this group is named {@code value} to avoid the confusion with the * Java String type. Indeed, Redis strings can be strings, numbers, byte arrays... * * @param valueType the type of the value, often String, or the value are encoded/decoded using codecs. * @param the type of the value * @return the object to manipulate stored strings. */ default ReactiveValueCommands value(Class valueType) { return value(String.class, valueType); } /** * Gets the object to execute commands manipulating stored strings. *

* NOTE: Instead of {@code string}, this group is named {@code value} to avoid the confusion with the * Java String type. Indeed, Redis strings can be strings, numbers, byte arrays... * * @param valueType the type of the value, often String, or the value are encoded/decoded using codecs. * @param the type of the value * @return the object to manipulate stored strings. */ default ReactiveValueCommands value(TypeReference valueType) { return value(STRING_TYPE_REFERENCE, valueType); } /** * Gets the object to execute commands manipulating stored strings. * * @param redisKeyType the type of the keys * @param valueType the type of the value, often String, or the value are encoded/decoded using codecs. * @param the type of the key * @param the type of the value * @return the object to manipulate stored strings. * @deprecated Use {@link #value(Class, Class)} instead */ @Deprecated ReactiveStringCommands string(Class redisKeyType, Class valueType); /** * Gets the object to execute commands manipulating stored strings. * * @param valueType the type of the value, often String, or the value are encoded/decoded using codecs. * @param the type of the value * @return the object to manipulate stored strings. * @deprecated Use {@link #value(Class)} instead */ @Deprecated default ReactiveStringCommands string(Class valueType) { return string(String.class, valueType); } /** * Gets the object to execute commands manipulating sets. * * @param redisKeyType the type of the keys * @param memberType the type of the member stored in each set * @param the type of the key * @param the type of the member * @return the object to manipulate sets. */ ReactiveSetCommands set(Class redisKeyType, Class memberType); /** * Gets the object to execute commands manipulating sets. * * @param redisKeyType the type of the keys * @param memberType the type of the member stored in each set * @param the type of the key * @param the type of the member * @return the object to manipulate sets. */ ReactiveSetCommands set(TypeReference redisKeyType, TypeReference memberType); /** * Gets the object to execute commands manipulating sets. * * @param memberType the type of the member stored in each set * @param the type of the member * @return the object to manipulate sets. */ default ReactiveSetCommands set(Class memberType) { return set(String.class, memberType); } /** * Gets the object to execute commands manipulating sets. * * @param memberType the type of the member stored in each set * @param the type of the member * @return the object to manipulate sets. */ default ReactiveSetCommands set(TypeReference memberType) { return set(STRING_TYPE_REFERENCE, memberType); } /** * Gets the object to execute commands manipulating lists. * * @param redisKeyType the type of the keys * @param memberType the type of the member stored in each list * @param the type of the key * @param the type of the member * @return the object to manipulate sets. */ ReactiveListCommands list(Class redisKeyType, Class memberType); /** * Gets the object to execute commands manipulating lists. * * @param memberType the type of the member stored in each list * @param the type of the member * @return the object to manipulate sets. */ default ReactiveListCommands list(Class memberType) { return list(String.class, memberType); } /** * Gets the object to execute commands manipulating lists. * * @param redisKeyType the type of the keys * @param memberType the type of the member stored in each list * @param the type of the key * @param the type of the member * @return the object to manipulate sets. */ ReactiveListCommands list(TypeReference redisKeyType, TypeReference memberType); /** * Gets the object to execute commands manipulating lists. * * @param memberType the type of the member stored in each list * @param the type of the member * @return the object to manipulate sets. */ default ReactiveListCommands list(TypeReference memberType) { return list(STRING_TYPE_REFERENCE, memberType); } /** * Gets the object to execute commands manipulating hyperloglog data structures. * * @param redisKeyType the type of the keys * @param memberType the type of the member stored in the data structure * @param the type of the key * @param the type of the member * @return the object to manipulate hyper log log data structures. */ ReactiveHyperLogLogCommands hyperloglog(Class redisKeyType, Class memberType); /** * Gets the object to execute commands manipulating hyperloglog data structures. * * @param redisKeyType the type of the keys * @param memberType the type of the member stored in the data structure * @param the type of the key * @param the type of the member * @return the object to manipulate hyper log log data structures. */ ReactiveHyperLogLogCommands hyperloglog(TypeReference redisKeyType, TypeReference memberType); /** * Gets the object to execute commands manipulating hyperloglog data structures. * * @param memberType the type of the member stored in the data structure * @param the type of the member * @return the object to manipulate hyper log log data structures. */ default ReactiveHyperLogLogCommands hyperloglog(Class memberType) { return hyperloglog(String.class, memberType); } /** * Gets the object to execute commands manipulating hyperloglog data structures. * * @param memberType the type of the member stored in the data structure * @param the type of the member * @return the object to manipulate hyper log log data structures. */ default ReactiveHyperLogLogCommands hyperloglog(TypeReference memberType) { return hyperloglog(STRING_TYPE_REFERENCE, memberType); } /** * Gets the object to execute commands manipulating bitmap data structures. * * @param redisKeyType the type of the keys * @param the type of the key * @return the object to manipulate bitmap data structures. */ ReactiveBitMapCommands bitmap(Class redisKeyType); /** * Gets the object to execute commands manipulating bitmap data structures. * * @param redisKeyType the type of the keys * @param the type of the key * @return the object to manipulate bitmap data structures. */ ReactiveBitMapCommands bitmap(TypeReference redisKeyType); /** * Gets the object to execute commands manipulating bitmap data structures. * * @return the object to manipulate bitmap data structures. */ default ReactiveBitMapCommands bitmap() { return bitmap(String.class); } /** * Gets the object to execute commands manipulating streams. * * @param redisKeyType the class of the keys * @param fieldType the class of the fields included in the message exchanged on the streams * @param valueType the class of the values included in the message exchanged on the streams * @param the type of the redis key * @param the type of the fields (map's keys) * @param the type of the value * @return the object to execute commands manipulating streams. */ ReactiveStreamCommands stream(Class redisKeyType, Class fieldType, Class valueType); /** * Gets the object to execute commands manipulating streams. * * @param redisKeyType the class of the keys * @param fieldType the class of the fields included in the message exchanged on the streams * @param valueType the class of the values included in the message exchanged on the streams * @param the type of the redis key * @param the type of the fields (map's keys) * @param the type of the value * @return the object to execute commands manipulating streams. */ ReactiveStreamCommands stream(TypeReference redisKeyType, TypeReference fieldType, TypeReference valueType); /** * Gets the object to execute commands manipulating streams, using a string key, and string fields. * * @param the type of the value * @return the object to execute commands manipulating streams. */ default ReactiveStreamCommands stream(Class typeOfValue) { return stream(String.class, String.class, typeOfValue); } /** * Gets the object to execute commands manipulating streams, using a string key, and string fields. * * @param the type of the value * @return the object to execute commands manipulating streams. */ default ReactiveStreamCommands stream(TypeReference typeOfValue) { return stream(STRING_TYPE_REFERENCE, STRING_TYPE_REFERENCE, typeOfValue); } /** * Gets the object to publish and receive messages. * * @param messageType the type of message * @param the type of message * @return the object to publish and subscribe to Redis channels */ ReactivePubSubCommands pubsub(Class messageType); /** * Gets the object to publish and receive messages. * * @param messageType the type of message * @param the type of message * @return the object to publish and subscribe to Redis channels */ ReactivePubSubCommands pubsub(TypeReference messageType); /** * Gets the object to manipulate JSON values. * This group requires the RedisJSON module. * * @return the object to manipulate JSON values. */ default ReactiveJsonCommands json() { return json(String.class); } /** * Gets the object to manipulate JSON values. * This group requires the RedisJSON module. * * @param the type of keys * @return the object to manipulate JSON values. */ ReactiveJsonCommands json(Class redisKeyType); /** * Gets the object to manipulate JSON values. * This group requires the RedisJSON module. * * @param the type of keys * @return the object to manipulate JSON values. */ ReactiveJsonCommands json(TypeReference redisKeyType); /** * Gets the object to manipulate Bloom filters. * This group requires the RedisBloom module. * * @param the type of the values added into the Bloom filter * @return the object to manipulate bloom values. */ default ReactiveBloomCommands bloom(Class valueType) { return bloom(String.class, valueType); } /** * Gets the object to manipulate Bloom filters. * This group requires the RedisBloom module. * * @param the type of the values added into the Bloom filter * @return the object to manipulate bloom values. */ default ReactiveBloomCommands bloom(TypeReference valueType) { return bloom(STRING_TYPE_REFERENCE, valueType); } /** * Gets the object to manipulate Bloom filters. * This group requires the RedisBloom module. * * @param the type of keys * @param the type of the values added into the Bloom filter * @return the object to manipulate bloom values. */ ReactiveBloomCommands bloom(Class redisKeyType, Class valueType); /** * Gets the object to manipulate Bloom filters. * This group requires the RedisBloom module. * * @param the type of keys * @param the type of the values added into the Bloom filter * @return the object to manipulate bloom values. */ ReactiveBloomCommands bloom(TypeReference redisKeyType, TypeReference valueType); /** * Gets the object to manipulate Cuckoo filters. * This group requires the RedisBloom module (including the Cuckoo * filter support). * * @param the type of the values added into the Cuckoo filter * @return the object to manipulate Cuckoo values. */ default ReactiveCuckooCommands cuckoo(Class valueType) { return cuckoo(String.class, valueType); } /** * Gets the object to manipulate Cuckoo filters. * This group requires the RedisBloom module (including the Cuckoo * filter support). * * @param the type of the values added into the Cuckoo filter * @return the object to manipulate Cuckoo values. */ default ReactiveCuckooCommands cuckoo(TypeReference valueType) { return cuckoo(STRING_TYPE_REFERENCE, valueType); } /** * Gets the object to manipulate Cuckoo filters. * This group requires the RedisBloom module (including the Cuckoo * filter support). * * @param the type of keys * @param the type of the values added into the Cuckoo filter * @return the object to manipulate Cuckoo values. */ ReactiveCuckooCommands cuckoo(Class redisKeyType, Class valueType); /** * Gets the object to manipulate Cuckoo filters. * This group requires the RedisBloom module (including the Cuckoo * filter support). * * @param the type of keys * @param the type of the values added into the Cuckoo filter * @return the object to manipulate Cuckoo values. */ ReactiveCuckooCommands cuckoo(TypeReference redisKeyType, TypeReference valueType); /** * Gets the object to manipulate Count-Min sketches. * This group requires the RedisBloom module (including the count-min * sketches support). * * @param the type of the values added into the count-min sketches * @return the object to manipulate count-min sketches. */ default ReactiveCountMinCommands countmin(Class valueType) { return countmin(String.class, valueType); } /** * Gets the object to manipulate Count-Min sketches. * This group requires the RedisBloom module (including the count-min * sketches support). * * @param the type of the values added into the count-min sketches * @return the object to manipulate count-min sketches. */ default ReactiveCountMinCommands countmin(TypeReference valueType) { return countmin(STRING_TYPE_REFERENCE, valueType); } /** * Gets the object to manipulate Count-Min sketches. * This group requires the RedisBloom module (including the count-min * sketches support). * * @param the type of keys * @param the type of the values added into the count-min sketches * @return the object to manipulate count-min sketches. */ ReactiveCountMinCommands countmin(Class redisKeyType, Class valueType); /** * Gets the object to manipulate Count-Min sketches. * This group requires the RedisBloom module (including the count-min * sketches support). * * @param the type of keys * @param the type of the values added into the count-min sketches * @return the object to manipulate count-min sketches. */ ReactiveCountMinCommands countmin(TypeReference redisKeyType, TypeReference valueType); /** * Gets the object to manipulate Top-K list. * This group requires the RedisBloom module (including the top-k * list support). * * @param the type of the values added into the top-k lists * @return the object to manipulate top-k lists. */ default ReactiveTopKCommands topk(Class valueType) { return topk(String.class, valueType); } /** * Gets the object to manipulate Top-K list. * This group requires the RedisBloom module (including the top-k * list support). * * @param the type of the values added into the top-k lists * @return the object to manipulate top-k lists. */ default ReactiveTopKCommands topk(TypeReference valueType) { return topk(STRING_TYPE_REFERENCE, valueType); } /** * Gets the object to manipulate Top-K list. * This group requires the RedisBloom module (including the top-k * list support). * * @param the type of keys * @param the type of the values added into the top-k lists * @return the object to manipulate top-k lists. */ ReactiveTopKCommands topk(Class redisKeyType, Class valueType); /** * Gets the object to manipulate Top-K list. * This group requires the RedisBloom module (including the top-k * list support). * * @param the type of keys * @param the type of the values added into the top-k lists * @return the object to manipulate top-k lists. */ ReactiveTopKCommands topk(TypeReference redisKeyType, TypeReference valueType); /** * Gets the object to manipulate graphs. * This group requires the RedisGraph module. * * @return the object to manipulate graphs lists. */ @Experimental("The Redis graph support is experimental") default ReactiveGraphCommands graph() { return graph(String.class); } /** * Gets the object to manipulate graphs. * This group requires the RedisGraph module. * * @param the type of keys * @return the object to manipulate graphs lists. */ @Experimental("The Redis graph support is experimental") ReactiveGraphCommands graph(Class redisKeyType); /** * Gets the object to emit commands from the {@code search} group. * This group requires the RedisSearch module. * * @param the type of keys * @return the object to search documents * @deprecated Use the variant without parameter, as the index name must be a string. */ @Experimental("The Redis search support is experimental") @Deprecated ReactiveSearchCommands search(Class redisKeyType); /** * Gets the object to emit commands from the {@code search} group. * This group requires the RedisSearch module. * * @return the object to search documents */ @Experimental("The Redis Search support is experimental") default ReactiveSearchCommands search() { return search(String.class); } /** * Gets the object to emit commands from the {@code auto-suggest} group. * This group requires the RedisSearch module. * * @param the type of keys * @return the object to get suggestions */ @Experimental("The Redis auto-suggest support is experimental") ReactiveAutoSuggestCommands autosuggest(Class redisKeyType); /** * Gets the object to emit commands from the {@code auto-suggest} group. * This group requires the RedisSearch module. * * @param the type of keys * @return the object to get suggestions */ @Experimental("The Redis auto-suggest support is experimental") ReactiveAutoSuggestCommands autosuggest(TypeReference redisKeyType); /** * Gets the object to emit commands from the {@code auto-suggest} group. * This group requires the RedisSearch module. * * @return the object to get suggestions */ @Experimental("The Redis auto-suggest support is experimental") default ReactiveAutoSuggestCommands autosuggest() { return autosuggest(String.class); } /** * Gets the object to emit commands from the {@code time series} group. * This group requires the Redis Time Series module. * * @param the type of keys * @return the object to manipulate time series */ @Experimental("The Redis time series support is experimental") ReactiveTimeSeriesCommands timeseries(Class redisKeyType); /** * Gets the object to emit commands from the {@code time series} group. * This group requires the Redis Time Series module. * * @param the type of keys * @return the object to manipulate time series */ @Experimental("The Redis time series support is experimental") ReactiveTimeSeriesCommands timeseries(TypeReference redisKeyType); /** * Gets the object to emit commands from the {@code time series} group. * This group requires the Redis Time Series module. * * @return the object to manipulate time series */ @Experimental("The Redis time series support is experimental") default ReactiveTimeSeriesCommands timeseries() { return timeseries(String.class); } /** * Executes a command. * This method is used to execute commands not offered by the API. * * @param command the command name * @param args the parameters, encoded as String. * @return the response */ Uni execute(String command, String... args); /** * Executes a command. * This method is used to execute commands not offered by the API. * * @param command the command * @param args the parameters, encoded as String. * @return the response */ Uni execute(Command command, String... args); /** * Executes a command. * This method is used to execute commands not offered by the API. * * @param command the command * @param args the parameters, encoded as String. * @return the response */ Uni execute(io.vertx.redis.client.Command command, String... args); /** * @return the underlying Redis client. */ Redis getRedis(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy