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

io.quarkus.redis.datasource.search.ReactiveSearchCommands Maven / Gradle / Ivy

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

import java.util.List;
import java.util.Set;

import io.quarkus.redis.datasource.ReactiveRedisCommands;
import io.smallrye.common.annotation.Experimental;
import io.smallrye.mutiny.Uni;

/**
 * Allows executing commands from the {@code search} group (requires the Redis Search module from Redis stack).
 * See the search command list for further information about these
 * commands.
 * 

* allows querying, secondary indexing, and full-text * search for Redis. *

* * @param the type of the key */ @Experimental("The commands from the search group are experimental") public interface ReactiveSearchCommands extends ReactiveRedisCommands { /** * Execute the command FT._LIST. * Summary: Returns a list of all existing indexes. * Group: search *

* This is a temporary command. * * @return A uni emitting the list of the keys **/ Uni> ft_list(); /** * Execute the command FT.AGGREGATE. * Summary: Run a search query on an index, and perform aggregate transformations on the results, extracting * statistics from them * Group: search * * @param indexName the index against which the query is executed. * @param query the filtering query that retrieves the documents. It follows the exact same syntax as the search * query, including filters, unions, not, optional, and so on. * @param args the extra parameters * @return A uni emitting the response to the aggregate **/ Uni ftAggregate(String indexName, String query, AggregateArgs args); /** * Execute the command FT.AGGREGATE. * Summary: Run a search query on an index, and perform aggregate transformations on the results, extracting * statistics from them * Group: search * * @param indexName the index against which the query is executed. * @param query the filtering query that retrieves the documents. It follows the exact same syntax as the search * query, including filters, unions, not, optional, and so on. * @return A uni emitting the response to the query **/ Uni ftAggregate(String indexName, String query); /** * Execute the command FT.ALIASADD. * Summary: Add an alias to an index * Group: search * * @param alias the alias to be added to an index. * @param index the index * @return A uni emitting {@code null} when the operation completes **/ Uni ftAliasAdd(String alias, String index); /** * Execute the command FT.ALIASDEL. * Summary: Remove an alias from an index * Group: search * * @param alias the alias to be removed * @return A uni emitting {@code null} when the operation completes **/ Uni ftAliasDel(String alias); /** * Execute the command FT.ALIASUPDATE. * Summary: Add an alias to an index. If the alias is already associated with another index, FT.ALIASUPDATE removes * the alias association with the previous index. * Group: search * * @param alias the alias to be added to an index. * @param index the index * @return A uni emitting {@code null} when the operation completes **/ Uni ftAliasUpdate(String alias, String index); /** * Execute the command FT.ALTER. * Summary: Add a new attribute to the index. Adding an attribute to the index causes any future document updates * to use the new attribute when indexing and reindexing existing documents. * Group: search * * @param index the index * @param field the indexed field to add * @param skipInitialScan whether to skip the initial scan, if set to {@code true}, does not scan and index. * @return A uni emitting {@code null} when the operation completes **/ Uni ftAlter(String index, IndexedField field, boolean skipInitialScan); /** * Execute the command FT.ALTER. * Summary: Add a new attribute to the index. Adding an attribute to the index causes any future document updates * to use the new attribute when indexing and reindexing existing documents. * Group: search * * @param index the index * @param field the indexed field to add * @return A uni emitting {@code null} when the operation completes **/ default Uni ftAlter(String index, IndexedField field) { return ftAlter(index, field, false); } /** * Execute the command FT.CREATE. * Summary: Create an index with the given specification. * Group: search * * @param index the index * @param args the creation arguments. * @return A uni emitting {@code null} when the operation completes **/ Uni ftCreate(String index, CreateArgs args); /** * Execute the command FT.CURSOR DEL. * Summary: Delete a cursor * Group: search * * @param index the index * @param cursor the cursor id * @return A uni emitting {@code null} when the operation completes **/ Uni ftCursorDel(String index, long cursor); /** * Execute the command FT.CURSOR READ. * Summary: Read next results from an existing cursor * Group: search * * @param index the index * @param cursor the cursor id * @return A uni emitting the aggregate response **/ Uni ftCursorRead(String index, long cursor); /** * Execute the command FT.CURSOR READ. * Summary: Read next results from an existing cursor * Group: search * * @param index the index * @param cursor the cursor id * @param count the number of results to read * @return A uni emitting the aggregate response. This parameter overrides {@code COUNT} specified in * {@code FT.AGGREGATE}. **/ Uni ftCursorRead(String index, long cursor, int count); /** * Execute the command FT.DROPINDEX. * Summary: Delete an index * Group: search * * @param index the index * @return A uni emitting {@code null} when the operation completes **/ Uni ftDropIndex(String index); /** * Execute the command FT.DROPINDEX. * Summary: Delete an index * Group: search * * @param index the index * @param dd drop operation that, if set, deletes the actual document hashes. * @return A uni emitting {@code null} when the operation completes **/ Uni ftDropIndex(String index, boolean dd); /** * Execute the command FT.DICTADD. * Summary: Add terms to a dictionary * Group: search * * @param dict the dictionary name * @param words the terms to add to the dictionary * @return A uni emitting {@code null} when the operation completes **/ Uni ftDictAdd(String dict, String... words); /** * Execute the command FT.DICTDEL. * Summary: Remove terms from a dictionary * Group: search * * @param dict the dictionary name * @param words the terms to remove to the dictionary * @return A uni emitting {@code null} when the operation completes **/ Uni ftDictDel(String dict, String... words); /** * Execute the command FT.DICTDUMP. * Summary: Dump all terms in the given dictionary * Group: search * * @param dict the dictionary name * @return A uni emitting the list of words (terms) included in the dictionary **/ Uni> ftDictDump(String dict); /** * Execute the command FT.SEARCH. * Summary: Search the index with a textual query, returning either documents or just ids * Group: search * * @param index the index name. You must first create the index using {@code FT.CREATE}. * @param query the text query to search. * @param args the extra parameters * @return A uni emitting the {@link SearchQueryResponse} **/ Uni ftSearch(String index, String query, QueryArgs args); /** * Execute the command FT.SEARCH. * Summary: Search the index with a textual query, returning either documents or just ids * Group: search * * @param index the index name. You must first create the index using {@code FT.CREATE}. * @param query the text query to search. * @return A uni emitting the {@link SearchQueryResponse} **/ Uni ftSearch(String index, String query); /** * Execute the command FT.SPELLCHECK. * Summary: Perform spelling correction on a query, returning suggestions for misspelled terms * Group: search * * @param index the index name. You must first create the index using {@code FT.CREATE}. * @param query the text query to search. * @return A uni emitting the {@link SpellCheckResponse} **/ Uni ftSpellCheck(String index, String query); /** * Execute the command FT.SPELLCHECK. * Summary: Perform spelling correction on a query, returning suggestions for misspelled terms * Group: search * * @param index the index name. You must first create the index using {@code FT.CREATE}. * @param query the text query to search. * @param args the extra parameters * @return A uni emitting the {@link SpellCheckResponse} **/ Uni ftSpellCheck(String index, String query, SpellCheckArgs args); /** * Execute the command FT.SYNDUMP. * Summary: Dump the contents of a synonym group * Group: search * * @param index the index name. * @return A uni emitting the {@link SynDumpResponse} **/ Uni ftSynDump(String index); /** * Execute the command FT.SYNUPDATE. * Summary: Update a synonym group * Group: search * * @param index the index name. * @param groupId the synonym group * @param words the synonyms * @return A uni emitting {@code null} when the operation completes **/ Uni ftSynUpdate(String index, String groupId, String... words); /** * Execute the command FT.SYNUPDATE. * Summary: Update a synonym group * Group: search * * @param index the index name. * @param groupId the synonym group * @param skipInitialScan if set to {@code true}, does not scan and index, and only documents that are indexed * after the update are affected. * @param words the synonyms * @return A uni emitting {@code null} when the operation completes **/ Uni ftSynUpdate(String index, String groupId, boolean skipInitialScan, String... words); /** * Execute the command FT.TAGVALS. * Summary: return a distinct set of values indexed in a Tag field * Group: search * * @param index the index name. * @param field the name of a tag file defined in the schema. * @return A uni emitting the set of values indexed in a Tag field **/ Uni> ftTagVals(String index, String field); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy