Commit e173fca0 authored by Yusuke Iwaki's avatar Yusuke Iwaki

fix logout

parent b83c2e63
......@@ -9,9 +9,9 @@ import chat.rocket.android.R;
import chat.rocket.android.fragment.chatroom.HomeFragment;
import chat.rocket.android.fragment.chatroom.RoomFragment;
import chat.rocket.android.fragment.sidebar.SidebarMainFragment;
import chat.rocket.android.helper.TextUtils;
import chat.rocket.android.model.internal.Session;
import chat.rocket.android.realm_helper.RealmHelper;
import chat.rocket.android.realm_helper.RealmObjectObserver;
import chat.rocket.android.realm_helper.RealmStore;
import hugo.weaving.DebugLog;
......@@ -19,11 +19,13 @@ import hugo.weaving.DebugLog;
* Entry-point for Rocket.Chat.Android application.
*/
public class MainActivity extends AbstractAuthedActivity {
private RealmObjectObserver<Session> sessionObserver;
@Override protected int getLayoutContainerForFragment() {
return R.id.activity_main_container;
}
@Override protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
......@@ -62,18 +64,16 @@ public class MainActivity extends AbstractAuthedActivity {
@DebugLog
@Override protected void onServerConfigIdUpdated() {
super.onServerConfigIdUpdated();
updateSessionObserver();
updateSidebarMainFragment();
showServerConfigActivityIfNeeded();
}
private void updateSidebarMainFragment() {
getSupportFragmentManager().beginTransaction()
.replace(R.id.sidebar_fragment_container, SidebarMainFragment.create(serverConfigId))
.commit();
private void updateSessionObserver() {
if (sessionObserver != null) {
sessionObserver.unsub();
sessionObserver = null;
}
private void showServerConfigActivityIfNeeded() {
if (serverConfigId == null) {
return;
}
......@@ -83,17 +83,25 @@ public class MainActivity extends AbstractAuthedActivity {
return;
}
Session session = realmHelper.executeTransactionForRead(realm ->
realm.where(Session.class).equalTo("sessionId", Session.DEFAULT_ID).findFirst());
if (session != null
&& !TextUtils.isEmpty(session.getToken())
&& session.isTokenVerified()
&& TextUtils.isEmpty(session.getError())) {
// session is OK.
} else {
sessionObserver = realmHelper
.createObjectObserver(realm ->
realm.where(Session.class)
.equalTo("sessionId", Session.DEFAULT_ID)
.isNotNull("token")
.equalTo("tokenVerified", true)
.isNull("error"))
.setOnUpdateListener(session -> {
if (session == null) {
LaunchUtil.showServerConfigActivity(this, serverConfigId);
}
});
sessionObserver.sub();
}
private void updateSidebarMainFragment() {
getSupportFragmentManager().beginTransaction()
.replace(R.id.sidebar_fragment_container, SidebarMainFragment.create(serverConfigId))
.commit();
}
@Override protected void onRoomIdUpdated() {
......@@ -107,6 +115,21 @@ public class MainActivity extends AbstractAuthedActivity {
}
}
@Override protected void onResume() {
super.onResume();
if (sessionObserver != null) {
sessionObserver.keepalive();
}
}
@Override protected void onDestroy() {
if (sessionObserver != null) {
sessionObserver.unsub();
sessionObserver = null;
}
super.onDestroy();
}
@Override protected boolean onBackPress() {
return closeSidebarIfNeeded() || super.onBackPress();
}
......
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