Ensure BackupState and RecoveryState values are set from the SDK only when the first sync is finished.
This commit is contained in:
@@ -70,6 +70,7 @@ fun SecureBackupRootView(
|
||||
|
||||
// Disable / Enable backup
|
||||
when (state.backupState) {
|
||||
BackupState.WAITING_FOR_SYNC,
|
||||
BackupState.UNKNOWN -> Unit
|
||||
BackupState.DISABLED -> {
|
||||
PreferenceText(
|
||||
@@ -97,6 +98,7 @@ fun SecureBackupRootView(
|
||||
|
||||
// Setup recovery
|
||||
when (state.recoveryState) {
|
||||
RecoveryState.WAITING_FOR_SYNC -> Unit
|
||||
RecoveryState.UNKNOWN,
|
||||
RecoveryState.DISABLED -> {
|
||||
PreferenceText(
|
||||
|
||||
@@ -17,6 +17,14 @@
|
||||
package io.element.android.libraries.matrix.api.encryption
|
||||
|
||||
enum class BackupState {
|
||||
/**
|
||||
* Special value, when the SDK is waiting for the first sync to be done.
|
||||
*/
|
||||
WAITING_FOR_SYNC,
|
||||
|
||||
/**
|
||||
* Values mapped from the SDK.
|
||||
*/
|
||||
UNKNOWN,
|
||||
CREATING,
|
||||
ENABLING,
|
||||
|
||||
@@ -17,6 +17,14 @@
|
||||
package io.element.android.libraries.matrix.api.encryption
|
||||
|
||||
enum class RecoveryState {
|
||||
/**
|
||||
* Special value, when the SDK is waiting for the first sync to be done.
|
||||
*/
|
||||
WAITING_FOR_SYNC,
|
||||
|
||||
/**
|
||||
* Values mapped from the SDK.
|
||||
*/
|
||||
UNKNOWN,
|
||||
ENABLED,
|
||||
DISABLED,
|
||||
|
||||
@@ -121,7 +121,12 @@ class RustMatrixClient constructor(
|
||||
private val notificationService = RustNotificationService(sessionId, notificationClient, dispatchers, clock)
|
||||
private val notificationSettingsService = RustNotificationSettingsService(notificationSettings, dispatchers)
|
||||
private val roomSyncSubscriber = RoomSyncSubscriber(innerRoomListService, dispatchers)
|
||||
private val encryptionService = RustEncryptionService(client, dispatchers).apply { start() }
|
||||
private val encryptionService = RustEncryptionService(
|
||||
client = client,
|
||||
syncService = rustSyncService,
|
||||
sessionCoroutineScope = sessionCoroutineScope,
|
||||
dispatchers = dispatchers,
|
||||
).apply { start() }
|
||||
|
||||
private val isLoggingOut = AtomicBoolean(false)
|
||||
|
||||
|
||||
@@ -22,10 +22,16 @@ import io.element.android.libraries.matrix.api.encryption.BackupUploadState
|
||||
import io.element.android.libraries.matrix.api.encryption.EnableRecoveryProgress
|
||||
import io.element.android.libraries.matrix.api.encryption.EncryptionService
|
||||
import io.element.android.libraries.matrix.api.encryption.RecoveryState
|
||||
import io.element.android.libraries.matrix.api.sync.SyncState
|
||||
import io.element.android.libraries.matrix.impl.sync.RustSyncService
|
||||
import kotlinx.coroutines.CoroutineScope
|
||||
import kotlinx.coroutines.channels.awaitClose
|
||||
import kotlinx.coroutines.flow.Flow
|
||||
import kotlinx.coroutines.flow.MutableStateFlow
|
||||
import kotlinx.coroutines.flow.SharingStarted
|
||||
import kotlinx.coroutines.flow.callbackFlow
|
||||
import kotlinx.coroutines.flow.combine
|
||||
import kotlinx.coroutines.flow.stateIn
|
||||
import kotlinx.coroutines.withContext
|
||||
import org.matrix.rustcomponents.sdk.BackupStateListener
|
||||
import org.matrix.rustcomponents.sdk.BackupSteadyStateListener
|
||||
@@ -41,6 +47,8 @@ import org.matrix.rustcomponents.sdk.SteadyStateException as RustSteadyStateExce
|
||||
|
||||
internal class RustEncryptionService(
|
||||
client: Client,
|
||||
syncService: RustSyncService,
|
||||
sessionCoroutineScope: CoroutineScope,
|
||||
private val dispatchers: CoroutineDispatchers,
|
||||
) : EncryptionService {
|
||||
|
||||
@@ -52,20 +60,44 @@ internal class RustEncryptionService(
|
||||
private val backupUploadStateMapper = BackupUploadStateMapper()
|
||||
private val steadyStateExceptionMapper = SteadyStateExceptionMapper()
|
||||
|
||||
override val backupStateStateFlow: MutableStateFlow<BackupState> = MutableStateFlow(service.backupState().let(backupStateMapper::map))
|
||||
override val recoveryStateStateFlow: MutableStateFlow<RecoveryState> = MutableStateFlow(service.recoveryState().let(recoveryStateMapper::map))
|
||||
private val backupStateFlow = MutableStateFlow(service.backupState().let(backupStateMapper::map))
|
||||
|
||||
override val backupStateStateFlow = combine(
|
||||
backupStateFlow,
|
||||
syncService.syncState,
|
||||
) { backupState, syncState ->
|
||||
if (syncState == SyncState.Running) {
|
||||
backupState
|
||||
} else {
|
||||
BackupState.WAITING_FOR_SYNC
|
||||
}
|
||||
}.stateIn(sessionCoroutineScope, SharingStarted.Eagerly, BackupState.WAITING_FOR_SYNC)
|
||||
|
||||
private val recoveryStateFlow: MutableStateFlow<RecoveryState> = MutableStateFlow(service.recoveryState().let(recoveryStateMapper::map))
|
||||
|
||||
override val recoveryStateStateFlow = combine(
|
||||
recoveryStateFlow,
|
||||
syncService.syncState,
|
||||
) { recoveryState, syncState ->
|
||||
if (syncState == SyncState.Running) {
|
||||
recoveryState
|
||||
} else {
|
||||
RecoveryState.WAITING_FOR_SYNC
|
||||
}
|
||||
}.stateIn(sessionCoroutineScope, SharingStarted.Eagerly, RecoveryState.WAITING_FOR_SYNC)
|
||||
|
||||
override val enableRecoveryProgressStateFlow: MutableStateFlow<EnableRecoveryProgress> = MutableStateFlow(EnableRecoveryProgress.Unknown)
|
||||
|
||||
fun start() {
|
||||
service.backupStateListener(object : BackupStateListener {
|
||||
override fun onUpdate(status: RustBackupState) {
|
||||
backupStateStateFlow.value = backupStateMapper.map(status)
|
||||
backupStateFlow.value = backupStateMapper.map(status)
|
||||
}
|
||||
})
|
||||
|
||||
service.recoveryStateListener(object : RecoveryStateListener {
|
||||
override fun onUpdate(status: RustRecoveryState) {
|
||||
recoveryStateStateFlow.value = recoveryStateMapper.map(status)
|
||||
recoveryStateFlow.value = recoveryStateMapper.map(status)
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user