Skip to content
This repository was archived by the owner on Jul 25, 2024. It is now read-only.

Commit 70c4260

Browse files
committed
Method to switch the current realm
Saves current server position, changes the databaseHelper and get's the saved data for this server
1 parent 5af2c16 commit 70c4260

File tree

1 file changed

+19
-1
lines changed

1 file changed

+19
-1
lines changed

app/src/main/java/com/zulip/android/ZulipApp.java

Lines changed: 19 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -100,7 +100,7 @@ public void onCreate() {
100100
currentRealm = globalSettings.getInt(GLOBAL_SETTINGS_CURRENT, currentRealm);
101101
serverStringSet = new HashSet<String>(globalSettings.getStringSet(GLOBAL_SETTINGS_REALMS, new HashSet<String>()));
102102

103-
103+
switchToRealm(currentRealm);
104104
if (BuildHelper.shouldLogToCrashlytics()) {
105105
// TODO(lfaraone): figure out what to do about crash reporting
106106
}
@@ -389,4 +389,22 @@ public void createNewRealm() {
389389
lastEventId = settings.getInt("lastEventId", -1);
390390
pointer = settings.getInt("pointer", -1);
391391
}
392+
393+
public void switchToRealm(int position) {
394+
databaseHelper = new DatabaseHelper(this, SERVER_SETTINGS + position);
395+
this.settings = getSharedPreferences(SERVER_SETTINGS + position, Context.MODE_PRIVATE);
396+
this.api_key = settings.getString("api_key", null);
397+
max_message_id = settings.getInt("max_message_id", -1);
398+
eventQueueId = settings.getString("eventQueueId", null);
399+
lastEventId = settings.getInt("lastEventId", -1);
400+
pointer = settings.getInt("pointer", -1);
401+
if (settings.contains("email"))
402+
this.you = Person.getOrUpdate(this, settings.getString("email", null), null, null);
403+
currentRealm = position;
404+
if (position != currentRealm) {
405+
SharedPreferences.Editor edit = globalSettings.edit();
406+
edit.putInt(GLOBAL_SETTINGS_CURRENT, position);
407+
edit.apply();
408+
}
409+
}
392410
}

0 commit comments

Comments
 (0)