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

Commit 27e750e

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 8d1285e commit 27e750e

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
@@ -99,7 +99,7 @@ public void onCreate() {
9999
currentRealm = globalSettings.getInt(GLOBAL_SETTINGS_CURRENT, currentRealm);
100100
serverStringSet = new ArrayList<String>(globalSettings.getStringSet(GLOBAL_SETTINGS_REALMS, new HashSet<String>()));
101101

102-
102+
switchToRealm(currentRealm);
103103
if (BuildHelper.shouldLogToCrashlytics()) {
104104
Crashlytics.start(this);
105105
}
@@ -356,4 +356,22 @@ public void createNewRealm() {
356356
pointer = settings.getInt("pointer", -1);
357357

358358
}
359+
360+
public void switchToRealm(int position) {
361+
databaseHelper = new DatabaseHelper(this, SERVER_SETTINGS + position);
362+
this.settings = getSharedPreferences(SERVER_SETTINGS + position, Context.MODE_PRIVATE);
363+
this.api_key = settings.getString("api_key", null);
364+
max_message_id = settings.getInt("max_message_id", -1);
365+
eventQueueId = settings.getString("eventQueueId", null);
366+
lastEventId = settings.getInt("lastEventId", -1);
367+
pointer = settings.getInt("pointer", -1);
368+
if (settings.contains("email"))
369+
this.you = Person.getOrUpdate(this, settings.getString("email", null), null, null);
370+
currentRealm = position;
371+
if (position != currentRealm) {
372+
SharedPreferences.Editor edit = globalSettings.edit();
373+
edit.putInt(GLOBAL_SETTINGS_CURRENT, position);
374+
edit.apply();
375+
}
376+
}
359377
}

0 commit comments

Comments
 (0)