
io.github.honhimw.ms.api.reactive.ReactiveSingleIndex Maven / Gradle / Ivy
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.github.honhimw.ms.api.reactive;
import io.github.honhimw.ms.json.TypeRef;
import io.github.honhimw.ms.model.Index;
import io.github.honhimw.ms.model.IndexStats;
import io.github.honhimw.ms.model.TaskInfo;
import io.swagger.v3.oas.annotations.Operation;
import jakarta.annotation.Nullable;
import reactor.core.publisher.Mono;
import java.util.function.Function;
/**
* Single Index operator.
*
* @author hon_him
* @since 2024-03-08
*/
public interface ReactiveSingleIndex {
/**
* Get information about current index.
*/
@Operation(method = "GET", tags = "/indexes/{index_uid}")
Mono get();
/**
* Create an index.
*
* @param primaryKey Primary key of current index
* @return create task
*/
@Operation(method = "POST", tags = "/indexes")
Mono create(@Nullable String primaryKey);
/**
* Update current index. Specify a primaryKey if it doesn't already exists yet.
*
* @return update task
*/
@Operation(method = "PATCH", tags = "/indexes/{index_uid}")
Mono update(String primaryKey);
/**
* Delete current index.
*
* @return delete task
*/
@Operation(method = "DELETE", tags = "/indexes/{index_uid}")
Mono delete();
/**
* Documents are objects composed of fields that can store any type of data.
* Each field contains an attribute and its associated value.
* Documents are stored inside indexes.
* Learn more about documents.
*
* @return {@link ReactiveDocuments} operator
*/
@Operation(tags = "/indexes/{index_uid}/documents")
ReactiveDocuments documents();
default R documents(Function operation) {
return operation.apply(documents());
}
ReactiveTypedDocuments documents(TypeRef typeRef);
default ReactiveTypedDocuments documents(Class type) {
return documents(TypeRef.of(type));
}
default R documents(TypeRef typeRef, Function, R> operation) {
return operation.apply(documents(typeRef));
}
default R documents(Class type, Function, R> operation) {
return operation.apply(documents(type));
}
/**
* Meilisearch exposes 3 routes to perform document searches:
*
* - A POST route: this is the preferred route when using API authentication, as it allows preflight request caching and better performances.
* - A GET route: the usage of this route is discouraged, unless you have good reason to do otherwise (specific caching abilities for example). Other than the differences mentioned above, the two routes are strictly equivalent.
* - A POST multi-search route allowing to perform multiple search queries in a single HTTP request. Meilisearch exposes 1 route to perform facet searches:
* - A POST facet-search route allowing to perform a facet search query on a facet in a single HTTP request.
*
*
* @return {@link ReactiveSearch} operator
*/
@Operation(tags = "/indexes/{index_uid}/search")
ReactiveSearch search();
default R search(Function operation) {
return operation.apply(search());
}
ReactiveTypedSearch search(TypeRef typeRef);
default ReactiveTypedSearch search(Class type) {
return search(TypeRef.of(type));
}
default R search(TypeRef typeRef, Function, R> operation) {
return operation.apply(search(typeRef));
}
default R search(Class type, Function, R> operation) {
return operation.apply(search(type));
}
ReactiveTypedDetailsSearch searchWithDetails(TypeRef typeRef);
default ReactiveTypedDetailsSearch searchWithDetails(Class type) {
return searchWithDetails(TypeRef.of(type));
}
default R searchWithDetails(TypeRef typeRef, Function, R> operation) {
return operation.apply(searchWithDetails(typeRef));
}
default R searchWithDetails(Class type, Function, R> operation) {
return operation.apply(searchWithDetails(type));
}
@Operation(tags = "/indexes/{indexUid}/settings")
ReactiveSettings settings();
default R settings(Function operation) {
return operation.apply(settings());
}
/**
* Get stats of current index.
*
* @return stats of current index.
*/
@Operation(method = "GET", tags = "/indexes/{index_uid}/stats")
Mono stats();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy