io.github.honhimw.ms.internal.reactive.ReactiveTasksImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of meilisearch-rest-client Show documentation
Show all versions of meilisearch-rest-client Show documentation
Reactive meilisearch rest client powered by reactor-netty-http.
/*
* 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.internal.reactive;
import io.github.honhimw.ms.api.reactive.ReactiveTasks;
import io.github.honhimw.ms.model.*;
import io.github.honhimw.ms.model.exception.TaskStateException;
import io.github.honhimw.ms.support.TypeRefs;
import reactor.core.publisher.Mono;
import reactor.util.retry.RetrySpec;
import java.time.Duration;
import java.util.Map;
/**
* @author hon_him
* @since 2024-01-04
*/
class ReactiveTasksImpl extends AbstractReactiveImpl implements ReactiveTasks {
protected ReactiveTasksImpl(ReactiveMSearchClientImpl client) {
super(client);
}
@Override
public Mono> list(GetTasksRequest request) {
return get("/tasks", configurer -> {
Map parameters = request.toParameters();
configurer.params(parameters);
}, TypeRefs.PageTaskViewRef.INSTANCE);
}
@Override
public Mono delete(GetTasksRequest request) {
return delete("/tasks", configurer -> {
Map parameters = request.toParameters();
configurer.params(parameters);
}, TypeRefs.TaskInfoRef.INSTANCE);
}
@Override
public Mono get(Integer uid) {
return get(String.format("/tasks/%s", uid), TypeRefs.TaskViewRef.INSTANCE);
}
@Override
public Mono cancel(CancelTasksRequest request) {
return post("/tasks/cancel", configurer -> {
Map parameters = request.toParameters();
configurer.params(parameters);
}, TypeRefs.TaskInfoRef.INSTANCE);
}
@Override
public Mono await(int uid) {
return await(uid, _client.config.getAwaitAttempts(), _client.config.getAwaitFixedDelay());
}
@Override
public Mono await(int uid, int maxAttempts, Duration fixedDelay) {
boolean awaitExhaustedError = _client.config.isAwaitExhaustedError();
Mono mono = get(uid)
.doOnNext(taskView -> {
TaskStatus status = taskView.getStatus();
if (status == TaskStatus.ENQUEUED || status == TaskStatus.PROCESSING) {
throw new TaskStateException(taskView, "task not completed.");
}
})
.retryWhen(RetrySpec.fixedDelay(maxAttempts, fixedDelay)
.modifyErrorFilter(throwablePredicate -> throwable -> throwable instanceof TaskStateException)
.onRetryExhaustedThrow((retryBackoffSpec, retrySignal) -> {
TaskStateException failure = (TaskStateException) retrySignal.failure();
return new TaskStateException(failure.getTaskView(), String.format("task not completed after: %d attempts with fixed delay: %s", maxAttempts, fixedDelay));
})
);
if (!awaitExhaustedError) {
mono = mono.onErrorResume(TaskStateException.class::isInstance, throwable -> Mono.just(((TaskStateException) throwable).getTaskView()));
}
return mono;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy