From 6667cb2803328193538a11c054393a3559e8e136 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jakub=20=C5=BBerko?= Date: Wed, 8 Nov 2023 16:22:27 +0800 Subject: [PATCH 1/2] Commit with unresolved merge conflicts outside of --- .../com/wire/kalium/logic/CoreFailure.kt | 4 +++ .../kalium/logic/data/user/UserRepository.kt | 24 ++++++++++++++ .../logic/data/user/UserRepositoryTest.kt | 32 +++++++++++++++++++ .../logic/test_util/TestNetworkException.kt | 4 +++ .../network/api/base/model/ErrorResponse.kt | 2 +- .../network/exceptions/KaliumException.kt | 2 ++ .../network/exceptions/NetworkErrorLabel.kt | 7 ++-- 7 files changed, 72 insertions(+), 3 deletions(-) diff --git a/logic/src/commonMain/kotlin/com/wire/kalium/logic/CoreFailure.kt b/logic/src/commonMain/kotlin/com/wire/kalium/logic/CoreFailure.kt index e54ced20128..c31e693db7a 100644 --- a/logic/src/commonMain/kotlin/com/wire/kalium/logic/CoreFailure.kt +++ b/logic/src/commonMain/kotlin/com/wire/kalium/logic/CoreFailure.kt @@ -24,6 +24,7 @@ import com.wire.kalium.logic.functional.Either import com.wire.kalium.network.exceptions.APINotSupported import com.wire.kalium.network.exceptions.KaliumException import com.wire.kalium.network.exceptions.isFederationDenied +import com.wire.kalium.network.exceptions.isFederationNotEnabled import com.wire.kalium.network.utils.NetworkResponse import io.ktor.utils.io.errors.IOException import kotlinx.coroutines.flow.Flow @@ -154,6 +155,7 @@ sealed class NetworkFailure : CoreFailure { data class General(val label: String) : FederatedBackendFailure() data class FederationDenied(val label: String) : FederatedBackendFailure() + data class FederationNotEnabled(val label: String) : FederatedBackendFailure() data class ConflictingBackends(override val domains: List) : FederatedBackendFailure(), RetryableFailure @@ -221,6 +223,8 @@ internal inline fun wrapApiRequest(networkCall: () -> NetworkResponse< exception is KaliumException.FederationError -> { if (exception.isFederationDenied()) { Either.Left(NetworkFailure.FederatedBackendFailure.FederationDenied(exception.errorResponse.label)) + } else if (exception.isFederationNotEnabled()) { + Either.Left(NetworkFailure.FederatedBackendFailure.FederationNotEnabled(exception.errorResponse.label)) } else { Either.Left(NetworkFailure.FederatedBackendFailure.General(exception.errorResponse.label)) } diff --git a/logic/src/commonMain/kotlin/com/wire/kalium/logic/data/user/UserRepository.kt b/logic/src/commonMain/kotlin/com/wire/kalium/logic/data/user/UserRepository.kt index febb0475911..3adfab108ae 100644 --- a/logic/src/commonMain/kotlin/com/wire/kalium/logic/data/user/UserRepository.kt +++ b/logic/src/commonMain/kotlin/com/wire/kalium/logic/data/user/UserRepository.kt @@ -18,8 +18,13 @@ package com.wire.kalium.logic.data.user +<<<<<<< HEAD import co.touchlab.stately.collections.ConcurrentMutableMap +======= +import com.wire.kalium.logger.obfuscateDomain +>>>>>>> 9b8b0e6937 (fix: handle federation not enabled [WPB-5237] (#2189)) import com.wire.kalium.logic.CoreFailure +import com.wire.kalium.logic.NetworkFailure import com.wire.kalium.logic.StorageFailure import com.wire.kalium.logic.data.conversation.MemberMapper import com.wire.kalium.logic.data.conversation.Recipient @@ -42,6 +47,7 @@ import com.wire.kalium.logic.failure.SelfUserDeleted import com.wire.kalium.logic.data.id.SelfTeamIdProvider import com.wire.kalium.logic.functional.Either import com.wire.kalium.logic.functional.flatMap +import com.wire.kalium.logic.functional.flatMapLeft import com.wire.kalium.logic.functional.fold import com.wire.kalium.logic.functional.foldToEitherWhileRight import com.wire.kalium.logic.functional.getOrNull @@ -243,6 +249,24 @@ internal class UserDataSource internal constructor( ) } } + .flatMapLeft { error -> + if (error is NetworkFailure.FederatedBackendFailure.FederationNotEnabled) { + val domains = qualifiedUserIdList + .filterNot { it.domain == selfUserId.domain } + .map { it.domain.obfuscateDomain() } + .toSet() + val domainNames = domains.joinToString(separator = ", ") + kaliumLogger.e("User ids contains different domains when federation is not enabled by backend: $domainNames") + wrapApiRequest { + userDetailsApi.getMultipleUsers( + ListUserRequest.qualifiedIds(qualifiedUserIdList.filter { it.domain == selfUserId.domain } + .map { userId -> userId.toApi() }) + ) + } + } else { + Either.Left(error) + } + } .flatMap { listUserProfileDTO -> if (listUserProfileDTO.usersFailed.isNotEmpty()) { kaliumLogger.d("Handling ${listUserProfileDTO.usersFailed.size} failed users") diff --git a/logic/src/commonTest/kotlin/com/wire/kalium/logic/data/user/UserRepositoryTest.kt b/logic/src/commonTest/kotlin/com/wire/kalium/logic/data/user/UserRepositoryTest.kt index 4133b36c9c7..eaa611ab27e 100644 --- a/logic/src/commonTest/kotlin/com/wire/kalium/logic/data/user/UserRepositoryTest.kt +++ b/logic/src/commonTest/kotlin/com/wire/kalium/logic/data/user/UserRepositoryTest.kt @@ -36,7 +36,12 @@ import com.wire.kalium.logic.framework.TestUser import com.wire.kalium.logic.framework.TestUser.LIST_USERS_DTO import com.wire.kalium.logic.functional.Either import com.wire.kalium.logic.functional.getOrNull +<<<<<<< HEAD import com.wire.kalium.logic.test_util.TestNetworkResponseError +======= +import com.wire.kalium.logic.sync.receiver.UserEventReceiverTest +import com.wire.kalium.logic.test_util.TestNetworkException.federationNotEnabled +>>>>>>> 9b8b0e6937 (fix: handle federation not enabled [WPB-5237] (#2189)) import com.wire.kalium.logic.util.shouldFail import com.wire.kalium.logic.util.shouldSucceed import com.wire.kalium.network.api.base.authenticated.self.SelfApi @@ -181,6 +186,26 @@ class UserRepositoryTest { .wasNotInvoked() } + @Test + fun givenAnUserIdListWithDifferentDomain_whenApiReturnsFederationDisabledError_thenShouldTryToFetchOnlyUsersWithSelfDomain() = runTest { + // given + val requestedUserIds = setOf(TestUser.OTHER_USER_ID, TestUser.OTHER_FEDERATED_USER_ID) + val (arrangement, userRepository) = Arrangement() + .withGetMultipleUsersApiRequestFederationNotEnabledError() + .arrange() + // when + userRepository.fetchUsersByIds(requestedUserIds).shouldFail() + // then + verify(arrangement.userDetailsApi) + .suspendFunction(arrangement.userDetailsApi::getMultipleUsers) + .with(eq(QualifiedUserIdListRequest(requestedUserIds.map { it.toApi() }.toList()))) + .wasInvoked(exactly = once) + verify(arrangement.userDetailsApi) + .suspendFunction(arrangement.userDetailsApi::getMultipleUsers) + .with(eq(QualifiedUserIdListRequest(listOf(TestUser.OTHER_USER_ID.toApi())))) + .wasInvoked(exactly = once) + } + @Test fun givenAnEmptyUserIdListFromSameDomainAsSelf_whenFetchingUsers_thenShouldNotFetchMultipleUsersAndSucceed() = runTest { // given @@ -776,6 +801,13 @@ class UserRepositoryTest { .thenReturn(NetworkResponse.Success(result, mapOf(), HttpStatusCode.OK.value)) } + fun withGetMultipleUsersApiRequestFederationNotEnabledError() = apply { + given(userDetailsApi) + .suspendFunction(userDetailsApi::getMultipleUsers) + .whenInvokedWith(any()) + .thenReturn(NetworkResponse.Error(federationNotEnabled)) + } + fun withUpdateDisplayNameApiRequestResponse(response: NetworkResponse) = apply { given(selfApi) .suspendFunction(selfApi::updateSelf) diff --git a/logic/src/commonTest/kotlin/com/wire/kalium/logic/test_util/TestNetworkException.kt b/logic/src/commonTest/kotlin/com/wire/kalium/logic/test_util/TestNetworkException.kt index 850cafe01ec..23da8afe25f 100644 --- a/logic/src/commonTest/kotlin/com/wire/kalium/logic/test_util/TestNetworkException.kt +++ b/logic/src/commonTest/kotlin/com/wire/kalium/logic/test_util/TestNetworkException.kt @@ -130,6 +130,10 @@ object TestNetworkException { val guestLinkDisables = KaliumException.InvalidRequestError( ErrorResponse(409, "Guest links are disabled", "guest-links-disabled") ) + + val federationNotEnabled = KaliumException.FederationError( + ErrorResponse(400, "no federator configured", "federation-not-enabled") + ) } object TestNetworkResponseError { diff --git a/network/src/commonMain/kotlin/com/wire/kalium/network/api/base/model/ErrorResponse.kt b/network/src/commonMain/kotlin/com/wire/kalium/network/api/base/model/ErrorResponse.kt index d8167d436de..3bfe1af82c7 100644 --- a/network/src/commonMain/kotlin/com/wire/kalium/network/api/base/model/ErrorResponse.kt +++ b/network/src/commonMain/kotlin/com/wire/kalium/network/api/base/model/ErrorResponse.kt @@ -28,7 +28,7 @@ data class ErrorResponse( @SerialName("label") val label: String, @SerialName("data") val cause: Cause? = null, ) { - fun isFederationError() = cause?.type == "federation" + fun isFederationError() = cause?.type == "federation" || label.contains("federation") } @Serializable diff --git a/network/src/commonMain/kotlin/com/wire/kalium/network/exceptions/KaliumException.kt b/network/src/commonMain/kotlin/com/wire/kalium/network/exceptions/KaliumException.kt index 87575b423ae..df48be0e151 100644 --- a/network/src/commonMain/kotlin/com/wire/kalium/network/exceptions/KaliumException.kt +++ b/network/src/commonMain/kotlin/com/wire/kalium/network/exceptions/KaliumException.kt @@ -32,6 +32,7 @@ import com.wire.kalium.network.exceptions.NetworkErrorLabel.BLACKLISTED_EMAIL import com.wire.kalium.network.exceptions.NetworkErrorLabel.DOMAIN_BLOCKED_FOR_REGISTRATION import com.wire.kalium.network.exceptions.NetworkErrorLabel.FEDERATION_DENIED import com.wire.kalium.network.exceptions.NetworkErrorLabel.FEDERATION_FAILURE +import com.wire.kalium.network.exceptions.NetworkErrorLabel.FEDERATION_NOT_ENABLED import com.wire.kalium.network.exceptions.NetworkErrorLabel.GUEST_LINKS_DISABLED import com.wire.kalium.network.exceptions.NetworkErrorLabel.HANDLE_EXISTS import com.wire.kalium.network.exceptions.NetworkErrorLabel.INVALID_CODE @@ -224,3 +225,4 @@ val KaliumException.InvalidRequestError.authenticationCodeFailure: Authenticatio } fun KaliumException.FederationError.isFederationDenied() = errorResponse.label == FEDERATION_DENIED +fun KaliumException.FederationError.isFederationNotEnabled() = errorResponse.label == FEDERATION_NOT_ENABLED diff --git a/network/src/commonMain/kotlin/com/wire/kalium/network/exceptions/NetworkErrorLabel.kt b/network/src/commonMain/kotlin/com/wire/kalium/network/exceptions/NetworkErrorLabel.kt index bba49a103d6..8159370cbef 100644 --- a/network/src/commonMain/kotlin/com/wire/kalium/network/exceptions/NetworkErrorLabel.kt +++ b/network/src/commonMain/kotlin/com/wire/kalium/network/exceptions/NetworkErrorLabel.kt @@ -42,15 +42,18 @@ internal object NetworkErrorLabel { const val MLS_KEY_PACKAGE_REF_NOT_FOUND = "mls-key-package-ref-not-found" const val MLS_MISSING_GROUP_INFO = "mls-missing-group-info" const val UNKNOWN_CLIENT = "unknown-client" - const val FEDERATION_FAILURE = "federation-remote-error" const val NOT_TEAM_MEMBER = "no-team-member" const val NO_CONVERSATION = "no-conversation" const val NO_CONVERSATION_CODE = "no-conversation-code" const val GUEST_LINKS_DISABLED = "guest-links-disabled" const val ACCESS_DENIED = "access-denied" const val WRONG_CONVERSATION_PASSWORD = "invalid-conversation-password" - const val FEDERATION_UNREACHABLE_DOMAINS = "federation-unreachable-domains-error" + + // Federation + const val FEDERATION_FAILURE = "federation-remote-error" const val FEDERATION_DENIED = "federation-denied" + const val FEDERATION_NOT_ENABLED = "federation-not-enabled" + const val FEDERATION_UNREACHABLE_DOMAINS = "federation-unreachable-domains-error" object KaliumCustom { const val MISSING_REFRESH_TOKEN = "missing-refresh_token" From 1376365eee006f8fbc6442b4bdd8f280f15cf6e4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jakub=20=C5=BBerko?= Date: Wed, 8 Nov 2023 21:41:58 +0800 Subject: [PATCH 2/2] resolve merge conflicts --- .../kotlin/com/wire/kalium/logic/data/user/UserRepository.kt | 3 --- .../com/wire/kalium/logic/data/user/UserRepositoryTest.kt | 3 --- 2 files changed, 6 deletions(-) diff --git a/logic/src/commonMain/kotlin/com/wire/kalium/logic/data/user/UserRepository.kt b/logic/src/commonMain/kotlin/com/wire/kalium/logic/data/user/UserRepository.kt index 3adfab108ae..11f188f8f78 100644 --- a/logic/src/commonMain/kotlin/com/wire/kalium/logic/data/user/UserRepository.kt +++ b/logic/src/commonMain/kotlin/com/wire/kalium/logic/data/user/UserRepository.kt @@ -18,11 +18,8 @@ package com.wire.kalium.logic.data.user -<<<<<<< HEAD import co.touchlab.stately.collections.ConcurrentMutableMap -======= import com.wire.kalium.logger.obfuscateDomain ->>>>>>> 9b8b0e6937 (fix: handle federation not enabled [WPB-5237] (#2189)) import com.wire.kalium.logic.CoreFailure import com.wire.kalium.logic.NetworkFailure import com.wire.kalium.logic.StorageFailure diff --git a/logic/src/commonTest/kotlin/com/wire/kalium/logic/data/user/UserRepositoryTest.kt b/logic/src/commonTest/kotlin/com/wire/kalium/logic/data/user/UserRepositoryTest.kt index eaa611ab27e..e574bfedf4e 100644 --- a/logic/src/commonTest/kotlin/com/wire/kalium/logic/data/user/UserRepositoryTest.kt +++ b/logic/src/commonTest/kotlin/com/wire/kalium/logic/data/user/UserRepositoryTest.kt @@ -36,12 +36,9 @@ import com.wire.kalium.logic.framework.TestUser import com.wire.kalium.logic.framework.TestUser.LIST_USERS_DTO import com.wire.kalium.logic.functional.Either import com.wire.kalium.logic.functional.getOrNull -<<<<<<< HEAD import com.wire.kalium.logic.test_util.TestNetworkResponseError -======= import com.wire.kalium.logic.sync.receiver.UserEventReceiverTest import com.wire.kalium.logic.test_util.TestNetworkException.federationNotEnabled ->>>>>>> 9b8b0e6937 (fix: handle federation not enabled [WPB-5237] (#2189)) import com.wire.kalium.logic.util.shouldFail import com.wire.kalium.logic.util.shouldSucceed import com.wire.kalium.network.api.base.authenticated.self.SelfApi