I want to make two concurent request to Realm database and return results with RxJava. The issue is that one of requests can return NULL object and I have a crash. How can I properly return results from both DB even if one of them NULL? Thanks.
public void getDataFromTwoSources(DisposableObserver<ComplexUserDto> observer, String shopId) {
Preconditions.checkNotNull(observer);
final Observable<ComplexUserDto> observable = Observable.zip(firstRepository.getUserData(userId), secondRepository.getUserDetailData(userId),
(userData, userDetails) -> {
ComplexUserDto resultDto = new ComplexUserDto(userData, userDetails);
return resultDto;
})
.compose(rxTransformers.applyUnauthorizedHandler())
.compose(rxTransformers.applySchedulers());
addDisposable(observable.subscribeWith(observer));
}
public class ComplexUserDto {
private UserData userData;
private UserDetailData userDetailData;
public ComplexUserDto(UserData userData, UserDetailData userDetailData) {
this.userData = userData;
this.userDetailData = userDetailData;
}
public UserData getUserData() {
return userData;
}
public UserDetailData getUserDetailData() {
return userDetailData;
}
}
Exception:
java.lang.NullPointerException: onNext called with null. Null values are generally not allowed in 2.x operators and sources.
at io.reactivex.internal.operators.observable.ObservableCreate$CreateEmitter.onNext(ObservableCreate.java:63)
at com.yozhik.data.database.shop.RealmDatabaseManagerImpl.lambda$null$15$RealmDatabaseManagerImpl(RealmDatabaseManagerImpl.java:261)
at com.yozhik.data.database.shop.RealmDatabaseManagerImpl$$Lambda$15.execute(Unknown Source)
at io.realm.Realm$1.run(Realm.java:1502)
at io.realm.internal.async.BgPriorityRunnable.run(BgPriorityRunnable.java:34)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:422)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
at java.lang.Thread.run(Thread.java:818)
You can return Optional from DB and then check if it's present.