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; ...@@ -2,22 +2,23 @@ package chat.rocket.persistence.realm.repositories;
import android.os.Looper; import android.os.Looper;
import android.support.v4.util.Pair; import android.support.v4.util.Pair;
import com.hadisatrio.optional.Optional;
import io.reactivex.Flowable; import com.hadisatrio.optional.Optional;
import io.reactivex.android.schedulers.AndroidSchedulers;
import io.realm.Case;
import io.realm.Realm;
import io.realm.RealmResults;
import io.realm.Sort;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import chat.rocket.core.models.User; import chat.rocket.core.models.User;
import chat.rocket.core.repositories.UserRepository; import chat.rocket.core.repositories.UserRepository;
import chat.rocket.persistence.realm.RealmStore; import chat.rocket.persistence.realm.RealmStore;
import chat.rocket.persistence.realm.models.ddp.RealmUser; import chat.rocket.persistence.realm.models.ddp.RealmUser;
import hu.akarnokd.rxjava.interop.RxJavaInterop; 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 { public class RealmUserRepository extends RealmRepository implements UserRepository {
private final String hostname; private final String hostname;
...@@ -28,16 +29,17 @@ public class RealmUserRepository extends RealmRepository implements UserReposito ...@@ -28,16 +29,17 @@ public class RealmUserRepository extends RealmRepository implements UserReposito
@Override @Override
public Flowable<Optional<User>> getCurrent() { public Flowable<Optional<User>> getCurrent() {
return Flowable.defer(this::realmGetCurrent) return Flowable.defer(() ->
.unsubscribeOn(AndroidSchedulers.from(Looper.myLooper())) realmGetCurrent()
.filter(it -> it != null && it.isLoaded() && it.isValid()) .unsubscribeOn(AndroidSchedulers.from(Looper.myLooper()))
.map(realmUsers -> { .filter(it -> it != null && it.isLoaded() && it.isValid())
if (realmUsers.size() > 0) { .map(realmUsers -> {
return Optional.of(realmUsers.get(0).asUser()); if (realmUsers.size() > 0) {
} return Optional.of(realmUsers.get(0).asUser());
}
return Optional.<User>absent();
}); return Optional.<User>absent();
}));
} }
private Flowable<RealmResults<RealmUser>> realmGetCurrent() { private Flowable<RealmResults<RealmUser>> realmGetCurrent() {
...@@ -53,15 +55,16 @@ public class RealmUserRepository extends RealmRepository implements UserReposito ...@@ -53,15 +55,16 @@ public class RealmUserRepository extends RealmRepository implements UserReposito
@Override @Override
public Flowable<Optional<User>> getByUsername(String username) { public Flowable<Optional<User>> getByUsername(String username) {
return Flowable.defer(() -> realmGetByUsername(username)) return Flowable.defer(() ->
.unsubscribeOn(AndroidSchedulers.from(Looper.myLooper())) realmGetByUsername(username)
.map(optional -> { .unsubscribeOn(AndroidSchedulers.from(Looper.myLooper()))
if (optional.isPresent()) { .map(optional -> {
return Optional.of(optional.get().asUser()); if (optional.isPresent()) {
} return Optional.of(optional.get().asUser());
}
return Optional.absent();
}); return Optional.absent();
}));
} }
private Flowable<Optional<RealmUser>> realmGetByUsername(String username) { private Flowable<Optional<RealmUser>> realmGetByUsername(String username) {
...@@ -89,11 +92,12 @@ public class RealmUserRepository extends RealmRepository implements UserReposito ...@@ -89,11 +92,12 @@ public class RealmUserRepository extends RealmRepository implements UserReposito
@Override @Override
public Flowable<List<User>> getSortedLikeName(String name, int limit) { public Flowable<List<User>> getSortedLikeName(String name, int limit) {
return Flowable.defer(() -> realmGetSortedLikeName(name)) return Flowable.defer(() ->
.unsubscribeOn(AndroidSchedulers.from(Looper.myLooper())) realmGetSortedLikeName(name)
.filter(realmUsers -> realmUsers != null && realmUsers.isLoaded() .unsubscribeOn(AndroidSchedulers.from(Looper.myLooper()))
&& realmUsers.isValid()) .filter(realmUsers -> realmUsers != null && realmUsers.isLoaded()
.map(realmUsers -> toList(safeSubList(realmUsers, 0, limit))); && realmUsers.isValid())
.map(realmUsers -> toList(safeSubList(realmUsers, 0, limit))));
} }
private Flowable<RealmResults<RealmUser>> realmGetSortedLikeName(String name) { 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