mirror of
https://github.com/SchildiChat/SchildiChat-android.git
synced 2024-11-25 02:45:53 +03:00
Merge pull request #8485 from vector-im/feature/bca/fix_anrs
Make cryptoDevice calls suspendable
This commit is contained in:
commit
2f1a7b76ad
20 changed files with 98 additions and 53 deletions
1
changelog.d/8482.bugfix
Normal file
1
changelog.d/8482.bugfix
Normal file
|
@ -0,0 +1 @@
|
||||||
|
fix: Make some crypto calls suspendable to avoid reported ANR
|
|
@ -256,7 +256,7 @@ internal class DefaultCryptoService @Inject constructor(
|
||||||
return if (longFormat) olmManager.getDetailedVersion(context) else olmManager.version
|
return if (longFormat) olmManager.getDetailedVersion(context) else olmManager.version
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun getMyCryptoDevice(): CryptoDeviceInfo {
|
override suspend fun getMyCryptoDevice(): CryptoDeviceInfo {
|
||||||
return myDeviceInfoHolder.get().myDevice
|
return myDeviceInfoHolder.get().myDevice
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -536,7 +536,7 @@ internal class DefaultCryptoService @Inject constructor(
|
||||||
// .executeBy(taskExecutor)
|
// .executeBy(taskExecutor)
|
||||||
// }
|
// }
|
||||||
|
|
||||||
override fun getCryptoDeviceInfo(userId: String): List<CryptoDeviceInfo> {
|
override suspend fun getCryptoDeviceInfo(userId: String): List<CryptoDeviceInfo> {
|
||||||
return cryptoStore.getUserDeviceList(userId).orEmpty()
|
return cryptoStore.getUserDeviceList(userId).orEmpty()
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
|
|
|
@ -73,7 +73,7 @@ interface CryptoService {
|
||||||
|
|
||||||
suspend fun getUserDevices(userId: String): List<CryptoDeviceInfo>
|
suspend fun getUserDevices(userId: String): List<CryptoDeviceInfo>
|
||||||
|
|
||||||
fun getMyCryptoDevice(): CryptoDeviceInfo
|
suspend fun getMyCryptoDevice(): CryptoDeviceInfo
|
||||||
|
|
||||||
fun getGlobalBlacklistUnverifiedDevices(): Boolean
|
fun getGlobalBlacklistUnverifiedDevices(): Boolean
|
||||||
|
|
||||||
|
@ -130,7 +130,7 @@ interface CryptoService {
|
||||||
|
|
||||||
suspend fun getCryptoDeviceInfo(userId: String, deviceId: String?): CryptoDeviceInfo?
|
suspend fun getCryptoDeviceInfo(userId: String, deviceId: String?): CryptoDeviceInfo?
|
||||||
|
|
||||||
fun getCryptoDeviceInfo(userId: String): List<CryptoDeviceInfo>
|
suspend fun getCryptoDeviceInfo(userId: String): List<CryptoDeviceInfo>
|
||||||
|
|
||||||
// fun getCryptoDeviceInfoFlow(userId: String): Flow<List<CryptoDeviceInfo>>
|
// fun getCryptoDeviceInfoFlow(userId: String): Flow<List<CryptoDeviceInfo>>
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,6 @@ import org.matrix.android.sdk.api.session.events.model.toValidDecryptedEvent
|
||||||
import org.matrix.android.sdk.api.session.room.model.message.MessageContent
|
import org.matrix.android.sdk.api.session.room.model.message.MessageContent
|
||||||
import org.matrix.android.sdk.api.session.room.model.message.MessagePollContent
|
import org.matrix.android.sdk.api.session.room.model.message.MessagePollContent
|
||||||
import org.matrix.android.sdk.internal.crypto.store.IMXCommonCryptoStore
|
import org.matrix.android.sdk.internal.crypto.store.IMXCommonCryptoStore
|
||||||
import timber.log.Timber
|
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
internal class EventEditValidator @Inject constructor(val cryptoStore: IMXCommonCryptoStore) {
|
internal class EventEditValidator @Inject constructor(val cryptoStore: IMXCommonCryptoStore) {
|
||||||
|
@ -53,7 +52,6 @@ internal class EventEditValidator @Inject constructor(val cryptoStore: IMXCommon
|
||||||
* If the original event was encrypted, the replacement should be too.
|
* If the original event was encrypted, the replacement should be too.
|
||||||
*/
|
*/
|
||||||
fun validateEdit(originalEvent: Event?, replaceEvent: Event): EditValidity {
|
fun validateEdit(originalEvent: Event?, replaceEvent: Event): EditValidity {
|
||||||
Timber.v("###REPLACE valide event $originalEvent replaced $replaceEvent")
|
|
||||||
// we might not know the original event at that time. In this case we can't perform the validation
|
// we might not know the original event at that time. In this case we can't perform the validation
|
||||||
// Edits should be revalidated when the original event is received
|
// Edits should be revalidated when the original event is received
|
||||||
if (originalEvent == null) {
|
if (originalEvent == null) {
|
||||||
|
|
|
@ -22,6 +22,8 @@ import com.zhuinden.monarchy.Monarchy
|
||||||
import dagger.assisted.Assisted
|
import dagger.assisted.Assisted
|
||||||
import dagger.assisted.AssistedFactory
|
import dagger.assisted.AssistedFactory
|
||||||
import dagger.assisted.AssistedInject
|
import dagger.assisted.AssistedInject
|
||||||
|
import kotlinx.coroutines.withContext
|
||||||
|
import org.matrix.android.sdk.api.MatrixCoroutineDispatchers
|
||||||
import org.matrix.android.sdk.api.session.room.model.ReadReceipt
|
import org.matrix.android.sdk.api.session.room.model.ReadReceipt
|
||||||
import org.matrix.android.sdk.api.session.room.read.ReadService
|
import org.matrix.android.sdk.api.session.room.read.ReadService
|
||||||
import org.matrix.android.sdk.api.util.Optional
|
import org.matrix.android.sdk.api.util.Optional
|
||||||
|
@ -43,7 +45,8 @@ internal class DefaultReadService @AssistedInject constructor(
|
||||||
private val setReadMarkersTask: SetReadMarkersTask,
|
private val setReadMarkersTask: SetReadMarkersTask,
|
||||||
private val readReceiptsSummaryMapper: ReadReceiptsSummaryMapper,
|
private val readReceiptsSummaryMapper: ReadReceiptsSummaryMapper,
|
||||||
@UserId private val userId: String,
|
@UserId private val userId: String,
|
||||||
private val homeServerCapabilitiesDataSource: HomeServerCapabilitiesDataSource
|
private val homeServerCapabilitiesDataSource: HomeServerCapabilitiesDataSource,
|
||||||
|
private val matrixCoroutineDispatchers: MatrixCoroutineDispatchers,
|
||||||
) : ReadService {
|
) : ReadService {
|
||||||
|
|
||||||
@AssistedFactory
|
@AssistedFactory
|
||||||
|
@ -66,7 +69,7 @@ internal class DefaultReadService @AssistedInject constructor(
|
||||||
setReadMarkersTask.execute(taskParams)
|
setReadMarkersTask.execute(taskParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
override suspend fun setReadReceipt(eventId: String, threadId: String) {
|
override suspend fun setReadReceipt(eventId: String, threadId: String) = withContext(matrixCoroutineDispatchers.io) {
|
||||||
val readReceiptThreadId = if (homeServerCapabilitiesDataSource.getHomeServerCapabilities()?.canUseThreadReadReceiptsAndNotifications == true) {
|
val readReceiptThreadId = if (homeServerCapabilitiesDataSource.getHomeServerCapabilities()?.canUseThreadReadReceiptsAndNotifications == true) {
|
||||||
threadId
|
threadId
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -25,7 +25,6 @@ import kotlinx.coroutines.CoroutineScope
|
||||||
import kotlinx.coroutines.NonCancellable
|
import kotlinx.coroutines.NonCancellable
|
||||||
import kotlinx.coroutines.cancelChildren
|
import kotlinx.coroutines.cancelChildren
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
import kotlinx.coroutines.runBlocking
|
|
||||||
import kotlinx.coroutines.withContext
|
import kotlinx.coroutines.withContext
|
||||||
import org.matrix.android.sdk.api.MatrixConfiguration
|
import org.matrix.android.sdk.api.MatrixConfiguration
|
||||||
import org.matrix.android.sdk.api.MatrixCoroutineDispatchers
|
import org.matrix.android.sdk.api.MatrixCoroutineDispatchers
|
||||||
|
@ -188,8 +187,8 @@ internal class RustCryptoService @Inject constructor(
|
||||||
return if (longFormat) "Rust SDK $version, Vodozemac $vodozemac" else version
|
return if (longFormat) "Rust SDK $version, Vodozemac $vodozemac" else version
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun getMyCryptoDevice(): CryptoDeviceInfo {
|
override suspend fun getMyCryptoDevice(): CryptoDeviceInfo = withContext(coroutineDispatchers.io) {
|
||||||
return runBlocking { olmMachine.ownDevice() }
|
olmMachine.ownDevice()
|
||||||
}
|
}
|
||||||
|
|
||||||
override suspend fun fetchDevicesList(): List<DeviceInfo> {
|
override suspend fun fetchDevicesList(): List<DeviceInfo> {
|
||||||
|
@ -341,11 +340,11 @@ internal class RustCryptoService @Inject constructor(
|
||||||
*/
|
*/
|
||||||
override suspend fun getCryptoDeviceInfo(userId: String, deviceId: String?): CryptoDeviceInfo? {
|
override suspend fun getCryptoDeviceInfo(userId: String, deviceId: String?): CryptoDeviceInfo? {
|
||||||
if (userId.isEmpty() || deviceId.isNullOrEmpty()) return null
|
if (userId.isEmpty() || deviceId.isNullOrEmpty()) return null
|
||||||
return olmMachine.getCryptoDeviceInfo(userId, deviceId)
|
return withContext(coroutineDispatchers.io) { olmMachine.getCryptoDeviceInfo(userId, deviceId) }
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun getCryptoDeviceInfo(userId: String): List<CryptoDeviceInfo> {
|
override suspend fun getCryptoDeviceInfo(userId: String): List<CryptoDeviceInfo> {
|
||||||
return runBlocking {
|
return withContext(coroutineDispatchers.io) {
|
||||||
olmMachine.getCryptoDeviceInfo(userId)
|
olmMachine.getCryptoDeviceInfo(userId)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@ package im.vector.app.gplay.features.settings.troubleshoot
|
||||||
|
|
||||||
import androidx.fragment.app.FragmentActivity
|
import androidx.fragment.app.FragmentActivity
|
||||||
import androidx.lifecycle.Observer
|
import androidx.lifecycle.Observer
|
||||||
|
import androidx.lifecycle.lifecycleScope
|
||||||
import androidx.work.WorkInfo
|
import androidx.work.WorkInfo
|
||||||
import androidx.work.WorkManager
|
import androidx.work.WorkManager
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
|
@ -25,6 +26,8 @@ import im.vector.app.core.pushers.FcmHelper
|
||||||
import im.vector.app.core.pushers.PushersManager
|
import im.vector.app.core.pushers.PushersManager
|
||||||
import im.vector.app.core.resources.StringProvider
|
import im.vector.app.core.resources.StringProvider
|
||||||
import im.vector.app.features.settings.troubleshoot.TroubleshootTest
|
import im.vector.app.features.settings.troubleshoot.TroubleshootTest
|
||||||
|
import kotlinx.coroutines.Dispatchers
|
||||||
|
import kotlinx.coroutines.launch
|
||||||
import org.matrix.android.sdk.api.session.pushers.PusherState
|
import org.matrix.android.sdk.api.session.pushers.PusherState
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
|
@ -60,16 +63,18 @@ class TestTokenRegistration @Inject constructor(
|
||||||
)
|
)
|
||||||
quickFix = object : TroubleshootQuickFix(R.string.settings_troubleshoot_test_token_registration_quick_fix) {
|
quickFix = object : TroubleshootQuickFix(R.string.settings_troubleshoot_test_token_registration_quick_fix) {
|
||||||
override fun doFix() {
|
override fun doFix() {
|
||||||
val workId = pushersManager.enqueueRegisterPusherWithFcmKey(fcmToken)
|
context.lifecycleScope.launch(Dispatchers.IO) {
|
||||||
WorkManager.getInstance(context).getWorkInfoByIdLiveData(workId).observe(context, Observer { workInfo ->
|
val workId = pushersManager.enqueueRegisterPusherWithFcmKey(fcmToken)
|
||||||
if (workInfo != null) {
|
WorkManager.getInstance(context).getWorkInfoByIdLiveData(workId).observe(context, Observer { workInfo ->
|
||||||
if (workInfo.state == WorkInfo.State.SUCCEEDED) {
|
if (workInfo != null) {
|
||||||
manager?.retry(testParameters)
|
if (workInfo.state == WorkInfo.State.SUCCEEDED) {
|
||||||
} else if (workInfo.state == WorkInfo.State.FAILED) {
|
manager?.retry(testParameters)
|
||||||
manager?.retry(testParameters)
|
} else if (workInfo.state == WorkInfo.State.FAILED) {
|
||||||
|
manager?.retry(testParameters)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
})
|
||||||
})
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,8 +26,11 @@ import dagger.hilt.android.qualifiers.ApplicationContext
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.di.ActiveSessionHolder
|
import im.vector.app.core.di.ActiveSessionHolder
|
||||||
import im.vector.app.core.di.DefaultPreferences
|
import im.vector.app.core.di.DefaultPreferences
|
||||||
|
import im.vector.app.core.dispatchers.CoroutineDispatchers
|
||||||
import im.vector.app.core.pushers.FcmHelper
|
import im.vector.app.core.pushers.FcmHelper
|
||||||
import im.vector.app.core.pushers.PushersManager
|
import im.vector.app.core.pushers.PushersManager
|
||||||
|
import kotlinx.coroutines.CoroutineScope
|
||||||
|
import kotlinx.coroutines.launch
|
||||||
import timber.log.Timber
|
import timber.log.Timber
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
|
@ -38,7 +41,12 @@ import javax.inject.Inject
|
||||||
class GoogleFcmHelper @Inject constructor(
|
class GoogleFcmHelper @Inject constructor(
|
||||||
@ApplicationContext private val context: Context,
|
@ApplicationContext private val context: Context,
|
||||||
@DefaultPreferences private val sharedPrefs: SharedPreferences,
|
@DefaultPreferences private val sharedPrefs: SharedPreferences,
|
||||||
|
appScope: CoroutineScope,
|
||||||
|
private val coroutineDispatchers: CoroutineDispatchers
|
||||||
) : FcmHelper {
|
) : FcmHelper {
|
||||||
|
|
||||||
|
private val scope = CoroutineScope(appScope.coroutineContext + coroutineDispatchers.io)
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
private const val PREFS_KEY_FCM_TOKEN = "FCM_TOKEN"
|
private const val PREFS_KEY_FCM_TOKEN = "FCM_TOKEN"
|
||||||
}
|
}
|
||||||
|
@ -64,7 +72,9 @@ class GoogleFcmHelper @Inject constructor(
|
||||||
.addOnSuccessListener { token ->
|
.addOnSuccessListener { token ->
|
||||||
storeFcmToken(token)
|
storeFcmToken(token)
|
||||||
if (registerPusher) {
|
if (registerPusher) {
|
||||||
pushersManager.enqueueRegisterPusherWithFcmKey(token)
|
scope.launch {
|
||||||
|
pushersManager.enqueueRegisterPusherWithFcmKey(token)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.addOnFailureListener { e ->
|
.addOnFailureListener { e ->
|
||||||
|
|
|
@ -27,6 +27,10 @@ import im.vector.app.core.pushers.PushersManager
|
||||||
import im.vector.app.core.pushers.UnifiedPushHelper
|
import im.vector.app.core.pushers.UnifiedPushHelper
|
||||||
import im.vector.app.core.pushers.VectorPushHandler
|
import im.vector.app.core.pushers.VectorPushHandler
|
||||||
import im.vector.app.features.settings.VectorPreferences
|
import im.vector.app.features.settings.VectorPreferences
|
||||||
|
import kotlinx.coroutines.CoroutineScope
|
||||||
|
import kotlinx.coroutines.SupervisorJob
|
||||||
|
import kotlinx.coroutines.cancel
|
||||||
|
import kotlinx.coroutines.launch
|
||||||
import org.matrix.android.sdk.api.logger.LoggerTag
|
import org.matrix.android.sdk.api.logger.LoggerTag
|
||||||
import timber.log.Timber
|
import timber.log.Timber
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
@ -43,6 +47,12 @@ class VectorFirebaseMessagingService : FirebaseMessagingService() {
|
||||||
@Inject lateinit var vectorPushHandler: VectorPushHandler
|
@Inject lateinit var vectorPushHandler: VectorPushHandler
|
||||||
@Inject lateinit var unifiedPushHelper: UnifiedPushHelper
|
@Inject lateinit var unifiedPushHelper: UnifiedPushHelper
|
||||||
|
|
||||||
|
private val scope = CoroutineScope(SupervisorJob())
|
||||||
|
|
||||||
|
override fun onDestroy() {
|
||||||
|
scope.cancel()
|
||||||
|
super.onDestroy()
|
||||||
|
}
|
||||||
override fun onNewToken(token: String) {
|
override fun onNewToken(token: String) {
|
||||||
Timber.tag(loggerTag.value).d("New Firebase token")
|
Timber.tag(loggerTag.value).d("New Firebase token")
|
||||||
fcmHelper.storeFcmToken(token)
|
fcmHelper.storeFcmToken(token)
|
||||||
|
@ -51,7 +61,9 @@ class VectorFirebaseMessagingService : FirebaseMessagingService() {
|
||||||
activeSessionHolder.hasActiveSession() &&
|
activeSessionHolder.hasActiveSession() &&
|
||||||
unifiedPushHelper.isEmbeddedDistributor()
|
unifiedPushHelper.isEmbeddedDistributor()
|
||||||
) {
|
) {
|
||||||
pushersManager.enqueueRegisterPusher(token, getString(R.string.pusher_http_url))
|
scope.launch {
|
||||||
|
pushersManager.enqueueRegisterPusher(token, getString(R.string.pusher_http_url))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,14 +22,14 @@ import javax.inject.Inject
|
||||||
|
|
||||||
interface GetDeviceInfoUseCase {
|
interface GetDeviceInfoUseCase {
|
||||||
|
|
||||||
fun execute(): CryptoDeviceInfo
|
suspend fun execute(): CryptoDeviceInfo
|
||||||
}
|
}
|
||||||
|
|
||||||
class DefaultGetDeviceInfoUseCase @Inject constructor(
|
class DefaultGetDeviceInfoUseCase @Inject constructor(
|
||||||
private val activeSessionHolder: ActiveSessionHolder
|
private val activeSessionHolder: ActiveSessionHolder
|
||||||
) : GetDeviceInfoUseCase {
|
) : GetDeviceInfoUseCase {
|
||||||
|
|
||||||
override fun execute(): CryptoDeviceInfo {
|
override suspend fun execute(): CryptoDeviceInfo {
|
||||||
return activeSessionHolder.getActiveSession().cryptoService().getMyCryptoDevice()
|
return activeSessionHolder.getActiveSession().cryptoService().getMyCryptoDevice()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,11 +49,11 @@ class PushersManager @Inject constructor(
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
fun enqueueRegisterPusherWithFcmKey(pushKey: String): UUID {
|
suspend fun enqueueRegisterPusherWithFcmKey(pushKey: String): UUID {
|
||||||
return enqueueRegisterPusher(pushKey, stringProvider.getString(R.string.pusher_http_url))
|
return enqueueRegisterPusher(pushKey, stringProvider.getString(R.string.pusher_http_url))
|
||||||
}
|
}
|
||||||
|
|
||||||
fun enqueueRegisterPusher(
|
suspend fun enqueueRegisterPusher(
|
||||||
pushKey: String,
|
pushKey: String,
|
||||||
gateway: String
|
gateway: String
|
||||||
): UUID {
|
): UUID {
|
||||||
|
@ -62,7 +62,7 @@ class PushersManager @Inject constructor(
|
||||||
return currentSession.pushersService().enqueueAddHttpPusher(pusher)
|
return currentSession.pushersService().enqueueAddHttpPusher(pusher)
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun createHttpPusher(
|
private suspend fun createHttpPusher(
|
||||||
pushKey: String,
|
pushKey: String,
|
||||||
gateway: String
|
gateway: String
|
||||||
) = HttpPusher(
|
) = HttpPusher(
|
||||||
|
|
|
@ -76,7 +76,9 @@ class VectorUnifiedPushMessagingReceiver : MessagingReceiver() {
|
||||||
coroutineScope.launch {
|
coroutineScope.launch {
|
||||||
unifiedPushHelper.storeCustomOrDefaultGateway(endpoint) {
|
unifiedPushHelper.storeCustomOrDefaultGateway(endpoint) {
|
||||||
unifiedPushHelper.getPushGateway()?.let {
|
unifiedPushHelper.getPushGateway()?.let {
|
||||||
pushersManager.enqueueRegisterPusher(endpoint, it)
|
coroutineScope.launch {
|
||||||
|
pushersManager.enqueueRegisterPusher(endpoint, it)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -275,7 +275,7 @@ class SelfVerificationController @Inject constructor(
|
||||||
id("notice_div")
|
id("notice_div")
|
||||||
}
|
}
|
||||||
// Option to verify with another device
|
// Option to verify with another device
|
||||||
if (state.hasAnyOtherSession) {
|
if (state.hasAnyOtherSession.invoke() == true) {
|
||||||
bottomSheetVerificationActionItem {
|
bottomSheetVerificationActionItem {
|
||||||
id("start")
|
id("start")
|
||||||
title(host.stringProvider.getString(R.string.verification_verify_with_another_device))
|
title(host.stringProvider.getString(R.string.verification_verify_with_another_device))
|
||||||
|
|
|
@ -83,7 +83,7 @@ data class SelfVerificationViewState(
|
||||||
val transactionId: String? = null,
|
val transactionId: String? = null,
|
||||||
val currentDeviceCanCrossSign: Boolean = false,
|
val currentDeviceCanCrossSign: Boolean = false,
|
||||||
val userWantsToCancel: Boolean = false,
|
val userWantsToCancel: Boolean = false,
|
||||||
val hasAnyOtherSession: Boolean = false,
|
val hasAnyOtherSession: Async<Boolean> = Uninitialized,
|
||||||
val quadSContainsSecrets: Boolean = false,
|
val quadSContainsSecrets: Boolean = false,
|
||||||
val isVerificationRequired: Boolean = false,
|
val isVerificationRequired: Boolean = false,
|
||||||
val isThisSessionVerified: Boolean = false,
|
val isThisSessionVerified: Boolean = false,
|
||||||
|
@ -146,21 +146,28 @@ class SelfVerificationViewModel @AssistedInject constructor(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
val hasAnyOtherSession = session.cryptoService()
|
setState { copy(hasAnyOtherSession = Loading()) }
|
||||||
.getCryptoDeviceInfo(session.myUserId)
|
viewModelScope.launch {
|
||||||
.any {
|
val hasAnyOtherSession = session.cryptoService()
|
||||||
it.deviceId != session.sessionParams.deviceId
|
.getCryptoDeviceInfo(session.myUserId)
|
||||||
}
|
.any {
|
||||||
|
it.deviceId != session.sessionParams.deviceId
|
||||||
|
}
|
||||||
|
setState {
|
||||||
|
copy(
|
||||||
|
hasAnyOtherSession = Success(hasAnyOtherSession)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
setState {
|
setState {
|
||||||
copy(
|
copy(
|
||||||
currentDeviceCanCrossSign = session.cryptoService().crossSigningService().canCrossSign(),
|
currentDeviceCanCrossSign = session.cryptoService().crossSigningService().canCrossSign(),
|
||||||
quadSContainsSecrets = session.sharedSecretStorageService().isRecoverySetup(),
|
quadSContainsSecrets = session.sharedSecretStorageService().isRecoverySetup(),
|
||||||
hasAnyOtherSession = hasAnyOtherSession
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
viewModelScope.launch {
|
viewModelScope.launch(Dispatchers.IO) {
|
||||||
val isThisSessionVerified = session.cryptoService().crossSigningService().isCrossSigningVerified()
|
val isThisSessionVerified = session.cryptoService().crossSigningService().isCrossSigningVerified()
|
||||||
setState {
|
setState {
|
||||||
copy(
|
copy(
|
||||||
|
|
|
@ -92,11 +92,6 @@ class UnknownDeviceDetectorSharedViewModel @AssistedInject constructor(
|
||||||
}
|
}
|
||||||
|
|
||||||
init {
|
init {
|
||||||
val currentSessionTs = session.cryptoService().getCryptoDeviceInfo(session.myUserId)
|
|
||||||
.firstOrNull { it.deviceId == session.sessionParams.deviceId }
|
|
||||||
?.firstTimeSeenLocalTs
|
|
||||||
?: clock.epochMillis()
|
|
||||||
Timber.v("## Detector - Current Session first time seen $currentSessionTs")
|
|
||||||
|
|
||||||
combine(
|
combine(
|
||||||
session.flow().liveUserCryptoDevices(session.myUserId),
|
session.flow().liveUserCryptoDevices(session.myUserId),
|
||||||
|
@ -108,6 +103,12 @@ class UnknownDeviceDetectorSharedViewModel @AssistedInject constructor(
|
||||||
|
|
||||||
deleteUnusedClientInformation(infoList)
|
deleteUnusedClientInformation(infoList)
|
||||||
|
|
||||||
|
val currentSessionTs = session.cryptoService().getCryptoDeviceInfo(session.myUserId)
|
||||||
|
.firstOrNull { it.deviceId == session.sessionParams.deviceId }
|
||||||
|
?.firstTimeSeenLocalTs
|
||||||
|
?: clock.epochMillis()
|
||||||
|
Timber.v("## Detector - Current Session first time seen $currentSessionTs")
|
||||||
|
|
||||||
infoList
|
infoList
|
||||||
.asSequence()
|
.asSequence()
|
||||||
.filter {
|
.filter {
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
package im.vector.app.features.settings.troubleshoot
|
package im.vector.app.features.settings.troubleshoot
|
||||||
|
|
||||||
import androidx.fragment.app.FragmentActivity
|
import androidx.fragment.app.FragmentActivity
|
||||||
|
import androidx.lifecycle.lifecycleScope
|
||||||
import androidx.work.WorkInfo
|
import androidx.work.WorkInfo
|
||||||
import androidx.work.WorkManager
|
import androidx.work.WorkManager
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
|
@ -72,13 +73,15 @@ class TestEndpointAsTokenRegistration @Inject constructor(
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun unregisterThenRegister(testParameters: TestParameters, pushKey: String) {
|
private fun unregisterThenRegister(testParameters: TestParameters, pushKey: String) {
|
||||||
activeSessionHolder.getSafeActiveSession()?.coroutineScope?.launch {
|
val scope = activeSessionHolder.getSafeActiveSession()?.coroutineScope ?: return
|
||||||
|
val io = activeSessionHolder.getActiveSession().coroutineDispatchers.io
|
||||||
|
scope.launch(io) {
|
||||||
unregisterUnifiedPushUseCase.execute(pushersManager)
|
unregisterUnifiedPushUseCase.execute(pushersManager)
|
||||||
registerUnifiedPush(distributor = "", testParameters, pushKey)
|
registerUnifiedPush(distributor = "", testParameters, pushKey)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun registerUnifiedPush(
|
private suspend fun registerUnifiedPush(
|
||||||
distributor: String,
|
distributor: String,
|
||||||
testParameters: TestParameters,
|
testParameters: TestParameters,
|
||||||
pushKey: String,
|
pushKey: String,
|
||||||
|
@ -106,7 +109,9 @@ class TestEndpointAsTokenRegistration @Inject constructor(
|
||||||
pushKey: String,
|
pushKey: String,
|
||||||
) {
|
) {
|
||||||
unifiedPushHelper.showSelectDistributorDialog(context) { selection ->
|
unifiedPushHelper.showSelectDistributorDialog(context) { selection ->
|
||||||
registerUnifiedPush(distributor = selection, testParameters, pushKey)
|
context.lifecycleScope.launch {
|
||||||
|
registerUnifiedPush(distributor = selection, testParameters, pushKey)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,6 +19,7 @@ package im.vector.app.core.device
|
||||||
import im.vector.app.test.fakes.FakeActiveSessionHolder
|
import im.vector.app.test.fakes.FakeActiveSessionHolder
|
||||||
import im.vector.app.test.fakes.FakeCryptoService
|
import im.vector.app.test.fakes.FakeCryptoService
|
||||||
import im.vector.app.test.fakes.FakeSession
|
import im.vector.app.test.fakes.FakeSession
|
||||||
|
import kotlinx.coroutines.test.runTest
|
||||||
import org.amshove.kluent.shouldBeEqualTo
|
import org.amshove.kluent.shouldBeEqualTo
|
||||||
import org.junit.Test
|
import org.junit.Test
|
||||||
|
|
||||||
|
@ -31,7 +32,7 @@ class DefaultGetDeviceInfoUseCaseTest {
|
||||||
private val getDeviceInfoUseCase = DefaultGetDeviceInfoUseCase(activeSessionHolder.instance)
|
private val getDeviceInfoUseCase = DefaultGetDeviceInfoUseCase(activeSessionHolder.instance)
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun `when execute, then get crypto device info`() {
|
fun `when execute, then get crypto device info`() = runTest {
|
||||||
val result = getDeviceInfoUseCase.execute()
|
val result = getDeviceInfoUseCase.execute()
|
||||||
|
|
||||||
result shouldBeEqualTo cryptoService.cryptoDeviceInfo
|
result shouldBeEqualTo cryptoService.cryptoDeviceInfo
|
||||||
|
|
|
@ -29,6 +29,7 @@ import im.vector.app.test.fixtures.CryptoDeviceInfoFixture.aCryptoDeviceInfo
|
||||||
import im.vector.app.test.fixtures.PusherFixture
|
import im.vector.app.test.fixtures.PusherFixture
|
||||||
import im.vector.app.test.fixtures.SessionParamsFixture
|
import im.vector.app.test.fixtures.SessionParamsFixture
|
||||||
import io.mockk.mockk
|
import io.mockk.mockk
|
||||||
|
import kotlinx.coroutines.test.runTest
|
||||||
import org.amshove.kluent.shouldBeEqualTo
|
import org.amshove.kluent.shouldBeEqualTo
|
||||||
import org.junit.Test
|
import org.junit.Test
|
||||||
import org.matrix.android.sdk.api.session.crypto.model.UnsignedDeviceInfo
|
import org.matrix.android.sdk.api.session.crypto.model.UnsignedDeviceInfo
|
||||||
|
@ -56,7 +57,7 @@ class PushersManagerTest {
|
||||||
)
|
)
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun `when enqueueRegisterPusher, then HttpPusher created and enqueued`() {
|
fun `when enqueueRegisterPusher, then HttpPusher created and enqueued`() = runTest {
|
||||||
val pushKey = "abc"
|
val pushKey = "abc"
|
||||||
val gateway = "123"
|
val gateway = "123"
|
||||||
val pusherAppId = "app-id"
|
val pusherAppId = "app-id"
|
||||||
|
|
|
@ -84,5 +84,5 @@ class FakeCryptoService(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun getMyCryptoDevice() = cryptoDeviceInfo
|
override suspend fun getMyCryptoDevice() = cryptoDeviceInfo
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,13 +17,13 @@
|
||||||
package im.vector.app.test.fakes
|
package im.vector.app.test.fakes
|
||||||
|
|
||||||
import im.vector.app.core.device.GetDeviceInfoUseCase
|
import im.vector.app.core.device.GetDeviceInfoUseCase
|
||||||
import io.mockk.every
|
import io.mockk.coEvery
|
||||||
import io.mockk.mockk
|
import io.mockk.mockk
|
||||||
import org.matrix.android.sdk.api.session.crypto.model.CryptoDeviceInfo
|
import org.matrix.android.sdk.api.session.crypto.model.CryptoDeviceInfo
|
||||||
|
|
||||||
class FakeGetDeviceInfoUseCase : GetDeviceInfoUseCase by mockk() {
|
class FakeGetDeviceInfoUseCase : GetDeviceInfoUseCase by mockk() {
|
||||||
|
|
||||||
fun givenDeviceInfo(cryptoDeviceInfo: CryptoDeviceInfo) {
|
fun givenDeviceInfo(cryptoDeviceInfo: CryptoDeviceInfo) {
|
||||||
every { execute() } returns cryptoDeviceInfo
|
coEvery { execute() } returns cryptoDeviceInfo
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue