Skip to content

Commit 47b684f

Browse files
committed
Let RootFlowNode manage MatrixClientsHolder save and restoration.
1 parent 5622517 commit 47b684f

File tree

4 files changed

+23
-25
lines changed

4 files changed

+23
-25
lines changed

app/src/main/kotlin/io/element/android/x/MainActivity.kt

Lines changed: 1 addition & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -52,8 +52,7 @@ class MainActivity : NodeComponentActivity() {
5252
Timber.tag(loggerTag.value).w("onCreate, with savedInstanceState: ${savedInstanceState != null}")
5353
installSplashScreen()
5454
super.onCreate(savedInstanceState)
55-
appBindings = bindings<AppBindings>()
56-
appBindings.matrixClientsHolder().restore(savedInstanceState)
55+
appBindings = bindings()
5756
WindowCompat.setDecorFitsSystemWindows(window, false)
5857
setContent {
5958
MainContent(appBindings)
@@ -125,9 +124,4 @@ class MainActivity : NodeComponentActivity() {
125124
super.onDestroy()
126125
Timber.tag(loggerTag.value).w("onDestroy")
127126
}
128-
129-
override fun onSaveInstanceState(outState: Bundle) {
130-
super.onSaveInstanceState(outState)
131-
bindings<AppBindings>().matrixClientsHolder().onSaveInstanceState(outState)
132-
}
133127
}

app/src/main/kotlin/io/element/android/x/di/AppBindings.kt

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -17,13 +17,11 @@
1717
package io.element.android.x.di
1818

1919
import com.squareup.anvil.annotations.ContributesTo
20-
import io.element.android.appnav.di.MatrixClientsHolder
2120
import io.element.android.libraries.designsystem.utils.SnackbarDispatcher
2221
import io.element.android.libraries.di.AppScope
2322

2423
@ContributesTo(AppScope::class)
2524
interface AppBindings {
26-
fun matrixClientsHolder(): MatrixClientsHolder
2725
fun mainDaggerComponentOwner(): MainDaggerComponentsOwner
2826
fun snackbarDispatcher(): SnackbarDispatcher
2927
}

appnav/src/main/kotlin/io/element/android/appnav/RootFlowNode.kt

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -30,6 +30,7 @@ import com.bumble.appyx.core.node.Node
3030
import com.bumble.appyx.core.node.node
3131
import com.bumble.appyx.core.plugin.Plugin
3232
import com.bumble.appyx.core.plugin.plugins
33+
import com.bumble.appyx.core.state.MutableSavedStateMap
3334
import com.bumble.appyx.navmodel.backstack.BackStack
3435
import com.bumble.appyx.navmodel.backstack.operation.pop
3536
import com.bumble.appyx.navmodel.backstack.operation.push
@@ -90,10 +91,16 @@ class RootFlowNode @AssistedInject constructor(
9091
) {
9192

9293
override fun onBuilt() {
94+
matrixClientsHolder.restore(buildContext.savedStateMap)
9395
super.onBuilt()
9496
observeLoggedInState()
9597
}
9698

99+
override fun onSaveInstanceState(state: MutableSavedStateMap) {
100+
super.onSaveInstanceState(state)
101+
matrixClientsHolder.save(state)
102+
}
103+
97104
private fun observeLoggedInState() {
98105
combine(
99106
cacheService.onClearedCacheEventFlow(),

appnav/src/main/kotlin/io/element/android/appnav/di/MatrixClientsHolder.kt

Lines changed: 15 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -16,21 +16,18 @@
1616

1717
package io.element.android.appnav.di
1818

19-
import android.os.Bundle
20-
import io.element.android.libraries.di.AppScope
21-
import io.element.android.libraries.di.SingleIn
19+
import com.bumble.appyx.core.state.MutableSavedStateMap
20+
import com.bumble.appyx.core.state.SavedStateMap
2221
import io.element.android.libraries.matrix.api.MatrixClient
2322
import io.element.android.libraries.matrix.api.auth.MatrixAuthenticationService
2423
import io.element.android.libraries.matrix.api.core.SessionId
25-
import io.element.android.libraries.matrix.api.core.UserId
2624
import kotlinx.coroutines.runBlocking
2725
import timber.log.Timber
2826
import java.util.concurrent.ConcurrentHashMap
2927
import javax.inject.Inject
3028

3129
private const val SAVE_INSTANCE_KEY = "io.element.android.x.di.MatrixClientsHolder.SaveInstanceKey"
3230

33-
@SingleIn(AppScope::class)
3431
class MatrixClientsHolder @Inject constructor(private val authenticationService: MatrixAuthenticationService) {
3532

3633
private val sessionIdsToMatrixClient = ConcurrentHashMap<SessionId, MatrixClient>()
@@ -55,16 +52,18 @@ class MatrixClientsHolder @Inject constructor(private val authenticationService:
5552
return sessionIdsToMatrixClient[sessionId]
5653
}
5754

58-
@Suppress("DEPRECATION")
59-
fun restore(savedInstanceState: Bundle?) {
60-
if (savedInstanceState == null || sessionIdsToMatrixClient.isNotEmpty()) return
61-
val userIds = savedInstanceState.getSerializable(SAVE_INSTANCE_KEY) as? Array<UserId>
62-
if (userIds.isNullOrEmpty()) return
55+
@Suppress("UNCHECKED_CAST")
56+
fun restore(state: SavedStateMap?) {
57+
if (state == null || sessionIdsToMatrixClient.isNotEmpty()) return Unit.also {
58+
Timber.w("Restore with non-empty map")
59+
}
60+
val sessionIds = state[SAVE_INSTANCE_KEY] as? Array<SessionId>
61+
if (sessionIds.isNullOrEmpty()) return
6362
// Not ideal but should only happens in case of process recreation. This ensure we restore all the active sessions before restoring the node graphs.
6463
runBlocking {
65-
userIds.forEach { userId ->
66-
Timber.v("Restore matrix session: $userId")
67-
authenticationService.restoreSession(userId)
64+
sessionIds.forEach { sessionId ->
65+
Timber.d("Restore matrix session: $sessionId")
66+
authenticationService.restoreSession(sessionId)
6867
.onSuccess { matrixClient ->
6968
add(matrixClient)
7069
}
@@ -75,9 +74,9 @@ class MatrixClientsHolder @Inject constructor(private val authenticationService:
7574
}
7675
}
7776

78-
fun onSaveInstanceState(outState: Bundle) {
77+
fun save(state: MutableSavedStateMap) {
7978
val sessionKeys = sessionIdsToMatrixClient.keys.toTypedArray()
80-
Timber.v("Save matrix session keys = $sessionKeys")
81-
outState.putSerializable(SAVE_INSTANCE_KEY, sessionKeys)
79+
Timber.d("Save matrix session keys = $sessionKeys")
80+
state[SAVE_INSTANCE_KEY] = sessionKeys
8281
}
8382
}

0 commit comments

Comments
 (0)