32 lines
1004 B
Java
32 lines
1004 B
Java
package it.cavallium.dbengine.client;
|
|
|
|
import it.cavallium.dbengine.database.LLDocument;
|
|
import it.cavallium.dbengine.database.LLTerm;
|
|
import it.cavallium.dbengine.lucene.analyzer.TextFieldsAnalyzer;
|
|
import java.util.Map;
|
|
import java.util.Set;
|
|
import org.apache.lucene.analysis.miscellaneous.PerFieldAnalyzerWrapper;
|
|
import org.jetbrains.annotations.NotNull;
|
|
import reactor.core.publisher.Flux;
|
|
import reactor.core.publisher.Mono;
|
|
import reactor.util.function.Tuple2;
|
|
|
|
public abstract class Indicizer<T, U> {
|
|
|
|
public abstract @NotNull Mono<LLDocument> toDocument(@NotNull T key, @NotNull U value);
|
|
|
|
public abstract @NotNull LLTerm toIndex(@NotNull T key);
|
|
|
|
public abstract @NotNull String getKeyFieldName();
|
|
|
|
public abstract @NotNull T getKey(String key);
|
|
|
|
public abstract IndicizerAnalyzers getPerFieldAnalyzer();
|
|
|
|
public abstract IndicizerSimilarities getPerFieldSimilarity();
|
|
|
|
public Flux<Tuple2<String, Set<String>>> getMoreLikeThisDocumentFields(T key, U value) {
|
|
return Flux.empty();
|
|
}
|
|
}
|