Commit 6f9e4848 authored by Lucio Maciel's avatar Lucio Maciel

Fix realm threading on RealmUserRepository

parent 36955585
......@@ -2,22 +2,23 @@ package chat.rocket.persistence.realm.repositories;
import android.os.Looper;
import android.support.v4.util.Pair;
import com.hadisatrio.optional.Optional;
import io.reactivex.Flowable;
import io.reactivex.android.schedulers.AndroidSchedulers;
import io.realm.Case;
import io.realm.Realm;
import io.realm.RealmResults;
import io.realm.Sort;
import com.hadisatrio.optional.Optional;
import java.util.ArrayList;
import java.util.List;
import chat.rocket.core.models.User;
import chat.rocket.core.repositories.UserRepository;
import chat.rocket.persistence.realm.RealmStore;
import chat.rocket.persistence.realm.models.ddp.RealmUser;
import hu.akarnokd.rxjava.interop.RxJavaInterop;
import io.reactivex.Flowable;
import io.reactivex.android.schedulers.AndroidSchedulers;
import io.realm.Case;
import io.realm.Realm;
import io.realm.RealmResults;
import io.realm.Sort;
public class RealmUserRepository extends RealmRepository implements UserRepository {
private final String hostname;
......@@ -28,16 +29,17 @@ public class RealmUserRepository extends RealmRepository implements UserReposito
@Override
public Flowable<Optional<User>> getCurrent() {
return Flowable.defer(this::realmGetCurrent)
.unsubscribeOn(AndroidSchedulers.from(Looper.myLooper()))
.filter(it -> it != null && it.isLoaded() && it.isValid())
.map(realmUsers -> {
if (realmUsers.size() > 0) {
return Optional.of(realmUsers.get(0).asUser());
}
return Optional.<User>absent();
});
return Flowable.defer(() ->
realmGetCurrent()
.unsubscribeOn(AndroidSchedulers.from(Looper.myLooper()))
.filter(it -> it != null && it.isLoaded() && it.isValid())
.map(realmUsers -> {
if (realmUsers.size() > 0) {
return Optional.of(realmUsers.get(0).asUser());
}
return Optional.<User>absent();
}));
}
private Flowable<RealmResults<RealmUser>> realmGetCurrent() {
......@@ -53,15 +55,16 @@ public class RealmUserRepository extends RealmRepository implements UserReposito
@Override
public Flowable<Optional<User>> getByUsername(String username) {
return Flowable.defer(() -> realmGetByUsername(username))
.unsubscribeOn(AndroidSchedulers.from(Looper.myLooper()))
.map(optional -> {
if (optional.isPresent()) {
return Optional.of(optional.get().asUser());
}
return Optional.absent();
});
return Flowable.defer(() ->
realmGetByUsername(username)
.unsubscribeOn(AndroidSchedulers.from(Looper.myLooper()))
.map(optional -> {
if (optional.isPresent()) {
return Optional.of(optional.get().asUser());
}
return Optional.absent();
}));
}
private Flowable<Optional<RealmUser>> realmGetByUsername(String username) {
......@@ -89,11 +92,12 @@ public class RealmUserRepository extends RealmRepository implements UserReposito
@Override
public Flowable<List<User>> getSortedLikeName(String name, int limit) {
return Flowable.defer(() -> realmGetSortedLikeName(name))
.unsubscribeOn(AndroidSchedulers.from(Looper.myLooper()))
.filter(realmUsers -> realmUsers != null && realmUsers.isLoaded()
&& realmUsers.isValid())
.map(realmUsers -> toList(safeSubList(realmUsers, 0, limit)));
return Flowable.defer(() ->
realmGetSortedLikeName(name)
.unsubscribeOn(AndroidSchedulers.from(Looper.myLooper()))
.filter(realmUsers -> realmUsers != null && realmUsers.isLoaded()
&& realmUsers.isValid())
.map(realmUsers -> toList(safeSubList(realmUsers, 0, limit))));
}
private Flowable<RealmResults<RealmUser>> realmGetSortedLikeName(String name) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment