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:
@@ -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)
|
||||
|
||||
@@ -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() {
|
||||
|
||||
Reference in New Issue
Block a user