package io.vertx.reactivex;

import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper;
import io.reactivex.Maybe;
import io.reactivex.MaybeObserver;
import io.reactivex.MaybeTransformer;
import io.reactivex.annotations.NonNull;
import io.reactivex.disposables.Disposable;
import io.vertx.core.AsyncResult;
import io.vertx.core.Handler;
import io.vertx.core.buffer.Buffer;
import io.vertx.reactivex.impl.AsyncResultMaybe;
import io.vertx.reactivex.impl.MaybeUnmarshaller;

import java.util.concurrent.atomic.AtomicBoolean;
import java.util.function.Consumer;

Author:Julien Viet
/** * @author <a href="mailto:julien@julienviet.com">Julien Viet</a> */
public class MaybeHelper {
Returns a Maybe that, when subscribed, uses the provided handler to adapt a callback-based asynchronous method.

For example:

 
io.vertx.core.Vertx vertx = Vertx.vertx();
Maybe<String> blockingMethodResult = MaybeHelper.toMaybe(handler -> vertx.<String>executeBlocking(fut -> fut.complete(invokeBlocking()), handler));

This is useful when using RxJava without the Vert.x Rxified API or your own asynchronous methods.

Params:
  • handler – the code executed when the returned Maybe is subscribed
/** * Returns a {@link Maybe} that, when subscribed, uses the provided {@code handler} to adapt a callback-based asynchronous method. * <p> * For example: * <pre> {@code * io.vertx.core.Vertx vertx = Vertx.vertx(); * Maybe<String> blockingMethodResult = MaybeHelper.toMaybe(handler -> vertx.<String>executeBlocking(fut -> fut.complete(invokeBlocking()), handler)); * }</pre> * <p> * This is useful when using RxJava without the Vert.x Rxified API or your own asynchronous methods. * * @param handler the code executed when the returned {@link Maybe} is subscribed */
public static <T> Maybe<T> toMaybe(Consumer<Handler<AsyncResult<T>>> handler) { return AsyncResultMaybe.toMaybe(handler); }
Adapts an Vert.x Handler<AsyncResult<T>> to an RxJava2 MaybeObserver.

The returned observer can be subscribed to an Maybe.subscribe(MaybeObserver).

Params:
  • handler – the handler to adapt
Returns:the observer
/** * Adapts an Vert.x {@code Handler<AsyncResult<T>>} to an RxJava2 {@link MaybeObserver}. * <p> * The returned observer can be subscribed to an {@link Maybe#subscribe(MaybeObserver)}. * * @param handler the handler to adapt * @return the observer */
public static <T> MaybeObserver<T> toObserver(Handler<AsyncResult<T>> handler) { AtomicBoolean completed = new AtomicBoolean(); return new MaybeObserver<T>() { @Override public void onSubscribe(@NonNull Disposable d) { } @Override public void onComplete() { if (completed.compareAndSet(false, true)) { handler.handle(io.vertx.core.Future.succeededFuture()); } } @Override public void onSuccess(@NonNull T item) { if (completed.compareAndSet(false, true)) { handler.handle(io.vertx.core.Future.succeededFuture(item)); } } @Override public void onError(Throwable error) { if (completed.compareAndSet(false, true)) { handler.handle(io.vertx.core.Future.failedFuture(error)); } } }; } public static <T> MaybeTransformer<Buffer, T> unmarshaller(Class<T> mappedType) { return new MaybeUnmarshaller<>(java.util.function.Function.identity(), mappedType); } public static <T> MaybeTransformer<Buffer, T> unmarshaller(TypeReference<T> mappedTypeRef) { return new MaybeUnmarshaller<>(java.util.function.Function.identity(), mappedTypeRef); } public static <T> MaybeTransformer<Buffer, T> unmarshaller(Class<T> mappedType, ObjectMapper mapper) { return new MaybeUnmarshaller<>(java.util.function.Function.identity(), mappedType, mapper); } public static <T> MaybeTransformer<Buffer, T> unmarshaller(TypeReference<T> mappedTypeRef, ObjectMapper mapper) { return new MaybeUnmarshaller<>(java.util.function.Function.identity(), mappedTypeRef, mapper); } }