io.quarkus.redis.datasource.bloom.ReactiveBloomCommands Maven / Gradle / Ivy
Show all versions of quarkus-redis-client Show documentation
package io.quarkus.redis.datasource.bloom;
import java.util.List;
import io.quarkus.redis.datasource.ReactiveRedisCommands;
import io.smallrye.mutiny.Uni;
/**
* Allows executing commands from the {@code bloom} group.
* These commands require the Redis Bloom module to be installed in the Redis
* server.
*
* See the bloom command list for further information about
* these commands.
*
*
* @param the type of the key
* @param the type of the value stored in the filter
*/
public interface ReactiveBloomCommands extends ReactiveRedisCommands {
/**
* Execute the command BF.ADD.
* Summary: Adds the specified element to the specified Bloom filter.
* Group: bloom
*
* If the bloom filter does not exist, it creates a new one.
*
* @param key the key
* @param value the value, must not be {@code null}
* @return a uni producing {@code true} if the value did not exist in the filter, {@code false} otherwise.
**/
Uni bfadd(K key, V value);
/**
* Execute the command BF.EXISTS.
* Summary: Determines whether an item may exist in the Bloom Filter or not.
* Group: bloom
*
* @param key the key
* @param value the value, must not be {@code null}
* @return a uni producing {@code true} if the value may exist in the filter, {@code false} means it does not exist
* in the filter.
**/
Uni bfexists(K key, V value);
/**
* Execute the command BF.MADD.
* Summary: Adds one or more items to the Bloom Filter and creates the filter if it does not exist yet.
* This command operates identically to BF.ADD except that it allows multiple inputs and returns multiple values.
* Group: bloom
*
*
* @param key the key
* @param values the values, must not be {@code null}, must not contain {@code null}, must not be empty.
* @return a uni producing a list of booleans. {@code true} if the corresponding value did not exist in the filter,
* {@code false} otherwise.
**/
Uni> bfmadd(K key, V... values);
/**
* Execute the command BF.MEXISTS.
* Summary: Determines if one or more items may exist in the filter or not.
* Group: bloom
*
* @param key the key
* @param values the values, must not be {@code null}, must not contain {@code null}, must not be empty.
* @return a uni producing a list of booleans. {@code true} if the corresponding value may exist in the filter,
* {@code false} does not exist in the filter.
**/
Uni> bfmexists(K key, V... values);
/**
* Execute the command BF.RESERVE.
* Summary: Creates an empty Bloom Filter with a single sub-filter for the initial capacity requested and with an
* upper bound {@code error_rate}.
* Group: bloom
*
* @param key the key
* @param errorRate The desired probability for false positives. The rate is a decimal value between 0 and 1.
* @param capacity The number of entries intended to be added to the filter.
* @return a uni producing {@code null} when the operation completes
**/
Uni bfreserve(K key, double errorRate, long capacity);
/**
* Execute the command BF.RESERVE.
* Summary: Creates an empty Bloom Filter with a single sub-filter for the initial capacity requested and with an
* upper bound {@code error_rate}.
* Group: bloom
*
* @param key the key
* @param errorRate The desired probability for false positives. The rate is a decimal value between 0 and 1.
* @param capacity The number of entries intended to be added to the filter.
* @param args the extra parameters
* @return a uni producing {@code null} when the operation completes
**/
Uni bfreserve(K key, double errorRate, long capacity, BfReserveArgs args);
/**
* Execute the command BF.INSERT.
* Summary: BF.INSERT is a sugarcoated combination of {@code BF.RESERVE} and {@code BF.ADD}. It creates a new filter
* if the key does not exist using the relevant arguments. Next, all {@code ITEMS} are inserted.
* Group: bloom
*
*
* @param key the key
* @param args the creation parameters
* @param values the value to add, must not contain {@code null}, must not be {@code null}, must not be empty
* @return a uni producing a list of booleans. {@code true} if the corresponding value may exist in the filter,
* {@code false} does not exist in the filter.
**/
Uni> bfinsert(K key, BfInsertArgs args, V... values);
}