forked from GitHub-Mirror/riotX-android
58 lines
2.5 KiB
Kotlin
58 lines
2.5 KiB
Kotlin
/*
|
|
* Copyright 2019 New Vector Ltd
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package im.vector.matrix.android.internal.session.sync
|
|
|
|
import arrow.core.Try
|
|
import im.vector.matrix.android.internal.crypto.CryptoManager
|
|
import im.vector.matrix.android.internal.session.sync.model.SyncResponse
|
|
import timber.log.Timber
|
|
import kotlin.system.measureTimeMillis
|
|
|
|
internal class SyncResponseHandler(private val roomSyncHandler: RoomSyncHandler,
|
|
private val userAccountDataSyncHandler: UserAccountDataSyncHandler,
|
|
private val groupSyncHandler: GroupSyncHandler,
|
|
private val cryptoSyncHandler: CryptoSyncHandler,
|
|
private val cryptoManager: CryptoManager) {
|
|
|
|
fun handleResponse(syncResponse: SyncResponse, fromToken: String?, isCatchingUp: Boolean): Try<SyncResponse> {
|
|
return Try {
|
|
Timber.v("Start handling sync")
|
|
val measure = measureTimeMillis {
|
|
// Handle the to device events before the room ones
|
|
// to ensure to decrypt them properly
|
|
if (syncResponse.toDevice != null) {
|
|
cryptoSyncHandler.handleToDevice(syncResponse.toDevice)
|
|
}
|
|
if (syncResponse.rooms != null) {
|
|
roomSyncHandler.handle(syncResponse.rooms)
|
|
}
|
|
if (syncResponse.groups != null) {
|
|
groupSyncHandler.handle(syncResponse.groups)
|
|
}
|
|
if (syncResponse.accountData != null) {
|
|
userAccountDataSyncHandler.handle(syncResponse.accountData)
|
|
}
|
|
cryptoSyncHandler.onSyncCompleted(syncResponse, fromToken, isCatchingUp)
|
|
}
|
|
val isInitialSync = fromToken == null
|
|
cryptoManager.start(isInitialSync)
|
|
Timber.v("Finish handling sync in $measure ms")
|
|
syncResponse
|
|
}
|
|
}
|
|
|
|
} |