com.algolia.search.SearchIndex Maven / Gradle / Ivy
package com.algolia.search;
import static java.util.stream.Collectors.toList;
import com.algolia.search.exceptions.AlgoliaApiException;
import com.algolia.search.exceptions.AlgoliaRetryException;
import com.algolia.search.exceptions.AlgoliaRuntimeException;
import com.algolia.search.exceptions.LaunderThrowable;
import com.algolia.search.iterators.IndexIterable;
import com.algolia.search.models.HttpMethod;
import com.algolia.search.models.RequestOptions;
import com.algolia.search.models.WaitableResponse;
import com.algolia.search.models.common.CallType;
import com.algolia.search.models.common.TaskStatusResponse;
import com.algolia.search.models.indexing.*;
import com.algolia.search.util.AlgoliaUtils;
import com.algolia.search.util.QueryStringUtils;
import java.util.*;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;
import javax.annotation.Nonnull;
/**
* This class holds all endpoints for an Index.
*
* @see Algolia.com
*/
@SuppressWarnings("WeakerAccess")
public final class SearchIndex
implements SearchIndexRules,
SearchIndexSynonyms,
SearchIndexSettings,
SearchIndexSearching {
private final HttpTransport transport;
private final SearchConfig config;
private final String urlEncodedIndexName;
private final String indexName;
private final Class clazz;
/**
* Create an instance of {@link SearchIndex}. It doesn't perform an API call.
*
* @param transport The transport layer.
* @param config The related client's configuration.
* @param indexName The non-encoded index name.
* @param clazz The class held by the index. Could be your business object or {@link Object}
*/
SearchIndex(HttpTransport transport, ConfigBase config, String indexName, Class clazz) {
this.transport = transport;
this.config = (SearchConfig) config;
this.indexName = indexName;
this.urlEncodedIndexName = QueryStringUtils.urlEncodeUTF8(indexName);
this.clazz = clazz;
}
public SearchConfig getConfig() {
return config;
}
@Override
public Class getClazz() {
return clazz;
}
@Override
public HttpTransport getTransport() {
return transport;
}
@Override
public String getUrlEncodedIndexName() {
return urlEncodedIndexName;
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectID ID of the object within that index
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public T getObject(@Nonnull String objectID) {
return LaunderThrowable.await(getObjectAsync(objectID));
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectID ID of the object within that index
* @param attributesToRetrieve List of attributes to retrieve. By default, all retrievable
* attributes are returned.
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public T getObject(
@Nonnull String objectID,
@Nonnull List attributesToRetrieve,
RequestOptions requestOptions) {
return LaunderThrowable.await(getObjectAsync(objectID, attributesToRetrieve, requestOptions));
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectID ID of the object within that index
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public T getObject(@Nonnull String objectID, RequestOptions requestOptions) {
return LaunderThrowable.await(getObjectAsync(objectID, requestOptions));
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectID ID of the object within that index
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public CompletableFuture getObjectAsync(@Nonnull String objectID) {
return getObjectAsync(objectID, null);
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectID ID of the object within that index
* @param attributesToRetrieve List of attributes to retrieve. By default, all retrievable
* attributes are returned.
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture getObjectAsync(
@Nonnull String objectID,
@Nonnull List attributesToRetrieve,
RequestOptions requestOptions) {
Objects.requireNonNull(attributesToRetrieve, "AttributesToRetrieve are required.");
Objects.requireNonNull(objectID, "objectID is required.");
if (AlgoliaUtils.isEmptyWhiteSpace(objectID)) {
throw new AlgoliaRuntimeException("objectID must not be empty.");
}
if (requestOptions == null) {
requestOptions = new RequestOptions();
}
requestOptions.addExtraQueryParameters(
"attributesToRetrieve",
QueryStringUtils.urlEncodeUTF8(String.join(",", attributesToRetrieve)));
return getObjectAsync(objectID, requestOptions);
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectID ID of the object within that index
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization)
*/
public CompletableFuture getObjectAsync(
@Nonnull String objectID, RequestOptions requestOptions) {
Objects.requireNonNull(objectID, "objectID is required.");
if (AlgoliaUtils.isEmptyWhiteSpace(objectID)) {
throw new AlgoliaRuntimeException("objectID must not be empty.");
}
return transport.executeRequestAsync(
HttpMethod.GET,
"/1/indexes/" + urlEncodedIndexName + "/" + QueryStringUtils.urlEncodeUTF8(objectID),
CallType.READ,
clazz,
requestOptions);
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectIDs ID of the object within that index
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public List getObjects(@Nonnull List objectIDs) {
return LaunderThrowable.await(getObjectsAsync(objectIDs));
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectIDs ID of the object within that index
* @param attributesToRetrieve List of attributes to retrieve. By default, all retrievable
* attributes are returned.
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public List getObjects(@Nonnull List objectIDs, List attributesToRetrieve) {
return LaunderThrowable.await(getObjectsAsync(objectIDs, attributesToRetrieve));
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectIDs ID of the object within that index
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public List getObjects(@Nonnull List objectIDs, RequestOptions requestOptions) {
return LaunderThrowable.await(getObjectsAsync(objectIDs, requestOptions));
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectIDs ID of the object within that index
* @param attributesToRetrieve List of attributes to retrieve. By default, all retrievable
* attributes are returned.
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public List getObjects(
@Nonnull List objectIDs,
List attributesToRetrieve,
RequestOptions requestOptions) {
return LaunderThrowable.await(getObjectsAsync(objectIDs, attributesToRetrieve, requestOptions));
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectIDs ID of the object within that index
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture> getObjectsAsync(@Nonnull List objectIDs) {
return getObjectsAsync(objectIDs, null, null);
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectIDs ID of the object within that index
* @param attributesToRetrieve List of attributes to retrieve. By default, all retrievable
* attributes are returned.
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture> getObjectsAsync(
@Nonnull List objectIDs, List attributesToRetrieve) {
return getObjectsAsync(objectIDs, attributesToRetrieve, null);
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectIDs ID of the object within that index
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture> getObjectsAsync(
@Nonnull List objectIDs, RequestOptions requestOptions) {
return getObjectsAsync(objectIDs, null, requestOptions);
}
/**
* Retrieve one or more objects, potentially from the index, in a single API call.
*
* @param objectIDs ID of the object within that index
* @param attributesToRetrieve List of attributes to retrieve. By default, all retrievable
* attributes are returned.
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
@SuppressWarnings("unchecked")
public CompletableFuture> getObjectsAsync(
@Nonnull List objectIDs,
List attributesToRetrieve,
RequestOptions requestOptions) {
Objects.requireNonNull(objectIDs, "Object IDs are required.");
if (objectIDs.isEmpty()) {
throw new IllegalArgumentException("objectIDs can't be empty.");
}
List queries = new ArrayList<>();
for (String objectId : objectIDs) {
queries.add(new MultipleGetObject(this.indexName, objectId, attributesToRetrieve));
}
MultipleGetObjectsRequest request = new MultipleGetObjectsRequest(queries);
return transport
.executeRequestAsync(
HttpMethod.POST,
"/1/indexes/*/objects",
CallType.READ,
request,
MultipleGetObjectsResponse.class,
clazz,
requestOptions)
.thenComposeAsync(
resp -> {
CompletableFuture> r = new CompletableFuture<>();
r.complete(resp.getResults());
return r;
},
config.getExecutor());
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data Data to update
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public UpdateObjectResponse partialUpdateObject(@Nonnull T data) {
return LaunderThrowable.await(partialUpdateObjectAsync(data));
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data Data to update
* @param requestOptions Options to pass to this request
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a Jackson
* annotation @JsonProperty(\"objectID\"")
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
*/
public UpdateObjectResponse partialUpdateObject(@Nonnull T data, RequestOptions requestOptions) {
return LaunderThrowable.await(partialUpdateObjectAsync(data, requestOptions));
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data Data to update
* @param createIfNotExists When true, a partial update on a nonexistent object will create the
* object (generating the objectID and using the attributes as defined in the object). WHen
* false, a partial update on a nonexistent object will be ignored (but no error will be sent
* back).
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a Jackson
* annotation @JsonProperty(\"objectID\"")
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
*/
public UpdateObjectResponse partialUpdateObject(
@Nonnull T data, @Nonnull Boolean createIfNotExists) {
return LaunderThrowable.await(partialUpdateObjectAsync(data, createIfNotExists));
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data Data to update
* @param createIfNotExists When true, a partial update on a nonexistent object will create the
* object (generating the objectID and using the attributes as defined in the object). WHen
* false, a partial update on a nonexistent object will be ignored (but no error will be sent
* back).
* @param requestOptions Options to pass to this request
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a Jackson
* annotation @JsonProperty(\"objectID\"")
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
*/
public UpdateObjectResponse partialUpdateObject(
@Nonnull T data, @Nonnull Boolean createIfNotExists, RequestOptions requestOptions) {
return LaunderThrowable.await(
partialUpdateObjectAsync(data, createIfNotExists, requestOptions));
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data Data to update
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture partialUpdateObjectAsync(@Nonnull T data) {
return partialUpdateObjectAsync(data, false, null);
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data Data to update
* @param requestOptions Options to pass to this request
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a Jackson
* annotation @JsonProperty(\"objectID\"")
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
*/
public CompletableFuture partialUpdateObjectAsync(
@Nonnull T data, RequestOptions requestOptions) {
return partialUpdateObjectAsync(data, false, requestOptions);
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data Data to update
* @param createIfNotExists When true, a partial update on a nonexistent object will create the
* object (generating the objectID and using the attributes as defined in the object). WHen
* false, a partial update on a nonexistent object will be ignored (but no error will be sent
* back).
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a Jackson
* annotation @JsonProperty(\"objectID\"")
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
*/
public CompletableFuture partialUpdateObjectAsync(
@Nonnull T data, @Nonnull Boolean createIfNotExists) {
return partialUpdateObjectAsync(data, createIfNotExists, null);
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data Data to update
* @param createIfNotExists When true, a partial update on a nonexistent object will create the
* object (generating the objectID and using the attributes as defined in the object). WHen
* false, a partial update on a nonexistent object will be ignored (but no error will be sent
* back).
* @param requestOptions Options to pass to this request
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a Jackson
* annotation @JsonProperty(\"objectID\"")
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
*/
public CompletableFuture partialUpdateObjectAsync(
@Nonnull T data, @Nonnull Boolean createIfNotExists, RequestOptions requestOptions) {
Objects.requireNonNull(data, "Data is required.");
Objects.requireNonNull(createIfNotExists, "createIfNotExists is required.");
String objectID = AlgoliaUtils.getObjectID(data, clazz);
if (requestOptions == null) {
requestOptions = new RequestOptions();
}
requestOptions.addExtraQueryParameters("createIfNotExists", createIfNotExists.toString());
return transport
.executeRequestAsync(
HttpMethod.POST,
"/1/indexes/" + urlEncodedIndexName + "/" + objectID + "/" + "partial",
CallType.WRITE,
data,
UpdateObjectResponse.class,
requestOptions)
.thenApplyAsync(
resp -> {
resp.setWaitConsumer(this::waitTask);
return resp;
},
config.getExecutor());
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data The data to send to the API
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public BatchIndexingResponse partialUpdateObjects(@Nonnull Iterable data) {
return LaunderThrowable.await(partialUpdateObjectsAsync(data));
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data The data to send to the API
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public BatchIndexingResponse partialUpdateObjects(
@Nonnull Iterable data, RequestOptions requestOptions) {
return LaunderThrowable.await(partialUpdateObjectsAsync(data, requestOptions));
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data The data to send to the API
* @param createIfNotExists When true, a partial update on a nonexistent object will create the
* object (generating the objectID and using the attributes as defined in the object). WHen
* false, a partial update on a nonexistent object will be ignored (but no error will be sent
* back).
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public BatchIndexingResponse partialUpdateObjects(
@Nonnull Iterable data, boolean createIfNotExists) {
return LaunderThrowable.await(partialUpdateObjectsAsync(data, createIfNotExists));
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data The data to send to the API
* @param createIfNotExists When true, a partial update on a nonexistent object will create the
* object (generating the objectID and using the attributes as defined in the object). WHen
* false, a partial update on a nonexistent object will be ignored (but no error will be sent
* back).
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public BatchIndexingResponse partialUpdateObjects(
@Nonnull Iterable data, boolean createIfNotExists, RequestOptions requestOptions) {
return LaunderThrowable.await(
partialUpdateObjectsAsync(data, createIfNotExists, requestOptions));
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data The data to send to the API
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public CompletableFuture partialUpdateObjectsAsync(
@Nonnull Iterable data) {
return partialUpdateObjectsAsync(data, false, null);
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data The data to send to the API
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public CompletableFuture partialUpdateObjectsAsync(
@Nonnull Iterable data, RequestOptions requestOptions) {
return partialUpdateObjectsAsync(data, false, requestOptions);
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data The data to send to the API
* @param createIfNotExists When true, a partial update on a nonexistent object will create the
* object (generating the objectID and using the attributes as defined in the object). WHen
* false, a partial update on a nonexistent object will be ignored (but no error will be sent
* back).
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public CompletableFuture partialUpdateObjectsAsync(
@Nonnull Iterable data, boolean createIfNotExists) {
return partialUpdateObjectsAsync(data, createIfNotExists, null);
}
/**
* Update one or more attributes of an existing object. This method enables you to update only a
* part of an object by singling out one or more attributes of an existing object and performing
* the following actions:
*
* @param data The data to send to the API
* @param createIfNotExists When true, a partial update on a nonexistent object will create the
* object (generating the objectID and using the attributes as defined in the object). WHen
* false, a partial update on a nonexistent object will be ignored (but no error will be sent
* back).
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public CompletableFuture partialUpdateObjectsAsync(
@Nonnull Iterable data, boolean createIfNotExists, RequestOptions requestOptions) {
Objects.requireNonNull(data, "Data are required.");
String action =
createIfNotExists
? ActionEnum.PARTIAL_UPDATE_OBJECT
: ActionEnum.PARTIAL_UPDATE_OBJECT_NO_CREATE;
return splitIntoBatchesAsync(data, action, requestOptions);
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public BatchIndexingResponse saveObject(@Nonnull T data) {
return LaunderThrowable.await(saveObjectAsync(data));
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param autoGenerateObjectID If set to true, the method will perform "ADD_OBJECT", otherwise
* will perform an "UpdateObject"
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"") and autoGenerateObjectID = false
*/
public BatchIndexingResponse saveObject(@Nonnull T data, boolean autoGenerateObjectID) {
return LaunderThrowable.await(saveObjectAsync(data, autoGenerateObjectID));
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public BatchIndexingResponse saveObject(@Nonnull T data, RequestOptions requestOptions) {
return LaunderThrowable.await(saveObjectAsync(data, requestOptions));
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param autoGenerateObjectID If set to true, the method will perform "ADD_OBJECT", otherwise
* will perform an "UpdateObject"
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"") and autoGenerateObjectID = false
*/
public BatchIndexingResponse saveObject(
@Nonnull T data, boolean autoGenerateObjectID, RequestOptions requestOptions) {
return LaunderThrowable.await(saveObjectAsync(data, autoGenerateObjectID, requestOptions));
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public CompletableFuture saveObjectAsync(@Nonnull T data) {
return saveObjectAsync(data, false, null);
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param autoGenerateObjectID If set to true, the method will perform "ADD_OBJECT", otherwise
* will perform an "UpdateObject"
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"") and autoGenerateObjectID = false
*/
public CompletableFuture saveObjectAsync(
@Nonnull T data, boolean autoGenerateObjectID) {
return saveObjectAsync(data, autoGenerateObjectID, null);
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public CompletableFuture saveObjectAsync(
@Nonnull T data, RequestOptions requestOptions) {
return saveObjectAsync(data, false, requestOptions);
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param autoGenerateObjectID If set to true, the method will perform "ADD_OBJECT", otherwise
* will perform an "UpdateObject"
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"") and autoGenerateObjectID = false
*/
public CompletableFuture saveObjectAsync(
@Nonnull T data, boolean autoGenerateObjectID, RequestOptions requestOptions) {
Objects.requireNonNull(data, "Data are required.");
return saveObjectsAsync(Collections.singletonList(data), autoGenerateObjectID, requestOptions);
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public BatchIndexingResponse saveObjects(@Nonnull Iterable data) {
return LaunderThrowable.await(saveObjectsAsync(data));
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param autoGenerateObjectID If set to true, the method will perform "ADD_OBJECT", otherwise
* will perform an "UpdateObject"
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"") and autoGenerateObjectID = false
*/
public BatchIndexingResponse saveObjects(
@Nonnull Iterable data, boolean autoGenerateObjectID) {
return LaunderThrowable.await(saveObjectsAsync(data, autoGenerateObjectID));
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public BatchIndexingResponse saveObjects(
@Nonnull Iterable data, RequestOptions requestOptions) {
return LaunderThrowable.await(saveObjectsAsync(data, requestOptions));
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param autoGenerateObjectID If set to true, the method will perform "ADD_OBJECT", otherwise
* will perform an "UpdateObject"
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"") and autoGenerateObjectID = false
*/
public BatchIndexingResponse saveObjects(
@Nonnull Iterable data, boolean autoGenerateObjectID, RequestOptions requestOptions) {
return LaunderThrowable.await(saveObjectsAsync(data, autoGenerateObjectID, requestOptions));
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public CompletableFuture saveObjectsAsync(@Nonnull Iterable data) {
return saveObjectsAsync(data, false, null);
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param autoGenerateObjectID If set to true, the method will perform "ADD_OBJECT", otherwise
* will perform an "UpdateObject"
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"") and autoGenerateObjectID = false
*/
public CompletableFuture saveObjectsAsync(
@Nonnull Iterable data, boolean autoGenerateObjectID) {
return saveObjectsAsync(data, autoGenerateObjectID, null);
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"")
*/
public CompletableFuture saveObjectsAsync(
@Nonnull Iterable data, RequestOptions requestOptions) {
return saveObjectsAsync(data, false, requestOptions);
}
/**
* This method allows you to create records on your index by sending one or more objects Each
* object contains a set of attributes and values, which represents a full record on an index.
*
* @param data The data to send
* @param autoGenerateObjectID If set to true, the method will perform "ADD_OBJECT", otherwise
* will perform an "UpdateObject"
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When the class doesn't have an objectID field or a
* Jacksonannotation @JsonProperty(\"objectID\"") and autoGenerateObjectID = false
*/
public CompletableFuture saveObjectsAsync(
@Nonnull Iterable data, boolean autoGenerateObjectID, RequestOptions requestOptions) {
Objects.requireNonNull(data, "Data are required.");
if (autoGenerateObjectID) {
return splitIntoBatchesAsync(data, ActionEnum.ADD_OBJECT, requestOptions);
}
// If we are not auto generating objectIDS we must make sure clazz has an objectID or Jackson
// annotation with objectID
AlgoliaUtils.ensureObjectID(clazz);
return splitIntoBatchesAsync(data, ActionEnum.UPDATE_OBJECT, requestOptions);
}
/**
* Split records into smaller chunks before sending them to the API asynchronously
*
* @param data The data to send and chunk
* @param actionType The action type of the batch
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
CompletableFuture splitIntoBatchesAsync(
@Nonnull Iterable data, @Nonnull String actionType) {
return splitIntoBatchesAsync(data, actionType, null);
}
/**
* Split records into smaller chunks before sending them to the API asynchronously
*
* @param data The data to send and chunk
* @param actionType The action type of the batch
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
CompletableFuture splitIntoBatchesAsync(
@Nonnull Iterable data, @Nonnull String actionType, RequestOptions requestOptions) {
Objects.requireNonNull(data, "Data are required.");
Objects.requireNonNull(actionType, "An action type is required.");
List> futures = new ArrayList<>();
List records = new ArrayList<>();
for (E item : data) {
if (records.size() == config.getBatchSize()) {
BatchRequest request = new BatchRequest<>(actionType, records);
CompletableFuture batch = batchAsync(request, requestOptions);
futures.add(batch);
records.clear();
}
records.add(item);
}
if (records.size() > 0) {
BatchRequest request = new BatchRequest<>(actionType, records);
CompletableFuture batch = batchAsync(request, requestOptions);
futures.add(batch);
}
return CompletableFuture.allOf(futures.toArray(new CompletableFuture[0]))
.thenComposeAsync(
v -> {
List resp =
futures.stream().map(CompletableFuture::join).collect(toList());
return CompletableFuture.completedFuture(new BatchIndexingResponse(resp));
},
config.getExecutor());
}
/**
* Perform several indexing operations in one API call.
*
* @param request The batch request -
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public BatchResponse batch(@Nonnull BatchRequest request) {
return LaunderThrowable.await(batchAsync(request, null));
}
/**
* Perform several indexing operations in one API call.
*
* @param request The batch request
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public BatchResponse batch(@Nonnull BatchRequest request, RequestOptions requestOptions) {
return LaunderThrowable.await(batchAsync(request, requestOptions));
}
/**
* Perform several indexing operations in one API call.
*
* @param request The batch request -
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture batchAsync(@Nonnull BatchRequest request) {
return batchAsync(request, null);
}
/**
* Perform several indexing operations in one API call.
*
* @param request The batch request
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture batchAsync(
@Nonnull BatchRequest request, RequestOptions requestOptions) {
Objects.requireNonNull(request, "A BatchRequest is required.");
return transport
.executeRequestAsync(
HttpMethod.POST,
"/1/indexes/" + urlEncodedIndexName + "/batch",
CallType.WRITE,
request,
BatchResponse.class,
requestOptions)
.thenApplyAsync(
resp -> {
resp.setWaitConsumer(this::waitTask);
return resp;
},
config.getExecutor());
}
/**
* Remove objects from an index using their object ids.
*
* @param objectID The Algolia objectID
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public DeleteResponse deleteObject(@Nonnull String objectID) {
return LaunderThrowable.await(deleteObjectAsync(objectID, null));
}
/**
* Remove objects from an index using their object ids.
*
* @param objectID The Algolia objectID
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public DeleteResponse deleteObject(@Nonnull String objectID, RequestOptions requestOptions) {
return LaunderThrowable.await(deleteObjectAsync(objectID, requestOptions));
}
/**
* Remove objects from an index using their object ids.
*
* @param objectID The Algolia objectID
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture deleteObjectAsync(@Nonnull String objectID) {
return deleteObjectAsync(objectID, null);
}
/**
* Remove objects from an index using their object ids.
*
* @param objectID The Algolia objectID
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture deleteObjectAsync(
@Nonnull String objectID, RequestOptions requestOptions) {
Objects.requireNonNull(objectID, "The objectID is required.");
if (AlgoliaUtils.isEmptyWhiteSpace(objectID)) {
throw new AlgoliaRuntimeException("objectID must not be empty.");
}
return transport
.executeRequestAsync(
HttpMethod.DELETE,
"/1/indexes/" + urlEncodedIndexName + "/" + objectID,
CallType.WRITE,
DeleteResponse.class,
requestOptions)
.thenApplyAsync(
resp -> {
resp.setWaitConsumer(this::waitTask);
return resp;
},
config.getExecutor());
}
/**
* Remove objects from an index using their object ids.
*
* @param objectIDs List of objectIDs to delete
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public BatchIndexingResponse deleteObjects(@Nonnull List objectIDs) {
return LaunderThrowable.await(deleteObjectsAsync(objectIDs));
}
/**
* Remove objects from an index using their object ids.
*
* @param objectIDs List of objectIDs to delete
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public BatchIndexingResponse deleteObjects(
@Nonnull List objectIDs, RequestOptions requestOptions) {
return LaunderThrowable.await(deleteObjectsAsync(objectIDs, requestOptions));
}
/**
* Remove objects from an index using their object ids.
*
* @param objectIDs List of objectIDs to delete
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture deleteObjectsAsync(
@Nonnull List objectIDs) {
return deleteObjectsAsync(objectIDs, null);
}
/**
* Remove objects from an index using their object ids.
*
* @param objectIDs List of objectIDs to delete
* @param requestOptions Options to pass to this request
* @throws AlgoliaRetryException When the retry has failed on all hosts
* @throws AlgoliaApiException When the API sends an http error code
* @throws AlgoliaRuntimeException When an error occurred during the serialization
*/
public CompletableFuture deleteObjectsAsync(
@Nonnull List objectIDs, RequestOptions requestOptions) {
Objects.requireNonNull(objectIDs, "The objectID is required.");
if (objectIDs.isEmpty()) {
throw new IllegalArgumentException("objectIDs can't be empty.");
}
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy