Merge pull request #3109 from element-hq/feature/fga/fix_restore_session_no_network

Auth : fix restore session when there is no network.
This commit is contained in:
ganfra
2024-06-27 18:38:48 +02:00
committed by GitHub
2 changed files with 18 additions and 6 deletions

View File

@@ -16,7 +16,6 @@
package io.element.android.libraries.matrix.impl
import io.element.android.appconfig.AuthenticationConfig
import io.element.android.libraries.core.coroutine.CoroutineDispatchers
import io.element.android.libraries.di.CacheDirectory
import io.element.android.libraries.matrix.impl.analytics.UtdTracker
@@ -48,7 +47,7 @@ class RustMatrixClientFactory @Inject constructor(
) {
suspend fun create(sessionData: SessionData): RustMatrixClient = withContext(coroutineDispatchers.io) {
val client = getBaseClientBuilder(sessionData.sessionPath, sessionData.passphrase)
.serverNameOrHomeserverUrl(sessionData.homeserverUrl)
.homeserverUrl(sessionData.homeserverUrl)
.username(sessionData.userId)
.use { it.build() }
@@ -70,11 +69,15 @@ class RustMatrixClientFactory @Inject constructor(
)
}
internal fun getBaseClientBuilder(sessionPath: String, passphrase: String?): ClientBuilder {
internal fun getBaseClientBuilder(
sessionPath: String,
passphrase: String?,
slidingSyncProxy: String? = null,
): ClientBuilder {
return ClientBuilder()
.sessionPath(sessionPath)
.passphrase(passphrase)
.slidingSyncProxy(AuthenticationConfig.SLIDING_SYNC_PROXY_URL)
.slidingSyncProxy(slidingSyncProxy)
.userAgent(userAgentProvider.provide())
.addRootCertificates(userCertificatesProvider.provides())
.autoEnableBackups(true)

View File

@@ -17,6 +17,7 @@
package io.element.android.libraries.matrix.impl.auth
import com.squareup.anvil.annotations.ContributesBinding
import io.element.android.appconfig.AuthenticationConfig
import io.element.android.libraries.core.coroutine.CoroutineDispatchers
import io.element.android.libraries.core.extensions.mapFailure
import io.element.android.libraries.di.AppScope
@@ -205,7 +206,11 @@ class RustMatrixAuthenticationService @Inject constructor(
override suspend fun loginWithQrCode(qrCodeData: MatrixQrCodeLoginData, progress: (QrCodeLoginStep) -> Unit) =
withContext(coroutineDispatchers.io) {
runCatching {
val client = rustMatrixClientFactory.getBaseClientBuilder(sessionPath, pendingPassphrase)
val client = rustMatrixClientFactory.getBaseClientBuilder(
sessionPath = sessionPath,
passphrase = pendingPassphrase,
slidingSyncProxy = AuthenticationConfig.SLIDING_SYNC_PROXY_URL,
)
.buildWithQrCode(
qrCodeData = (qrCodeData as SdkQrCodeLoginData).rustQrCodeData,
oidcConfiguration = oidcConfigurationProvider.get(),
@@ -242,7 +247,11 @@ class RustMatrixAuthenticationService @Inject constructor(
}
private fun getBaseClientBuilder() = rustMatrixClientFactory
.getBaseClientBuilder(sessionPath, pendingPassphrase)
.getBaseClientBuilder(
sessionPath = sessionPath,
passphrase = pendingPassphrase,
slidingSyncProxy = AuthenticationConfig.SLIDING_SYNC_PROXY_URL,
)
.requiresSlidingSync()
private fun clear() {