diff --git a/app/src/main/kotlin/com/wire/android/ui/WireActivity.kt b/app/src/main/kotlin/com/wire/android/ui/WireActivity.kt index 3d4a4bc556a..9ea51911f6c 100644 --- a/app/src/main/kotlin/com/wire/android/ui/WireActivity.kt +++ b/app/src/main/kotlin/com/wire/android/ui/WireActivity.kt @@ -93,6 +93,7 @@ import com.wire.android.ui.legalhold.dialog.deactivated.LegalHoldDeactivatedView import com.wire.android.ui.legalhold.dialog.requested.LegalHoldRequestedDialog import com.wire.android.ui.legalhold.dialog.requested.LegalHoldRequestedState import com.wire.android.ui.legalhold.dialog.requested.LegalHoldRequestedViewModel +import com.wire.android.ui.settings.devices.e2ei.E2EICertificateDetails import com.wire.android.ui.theme.ThemeOption import com.wire.android.ui.theme.WireTheme import com.wire.android.ui.userprofile.self.dialog.LogoutOptionsDialog @@ -388,7 +389,15 @@ class WireActivity : AppCompatActivity() { result = e2EIResult, updateCertificate = featureFlagNotificationViewModel::enrollE2EICertificate, snoozeDialog = featureFlagNotificationViewModel::snoozeE2EIdRequiredDialog, - openCertificateDetails = { navigate(NavigationCommand(E2eiCertificateDetailsScreenDestination(it))) }, + openCertificateDetails = { + navigate( + NavigationCommand( + E2eiCertificateDetailsScreenDestination( + E2EICertificateDetails.DuringLoginCertificateDetails(it) + ) + ) + ) + }, dismissSuccessDialog = featureFlagNotificationViewModel::dismissSuccessE2EIdDialog, isE2EILoading = isE2EILoading ) diff --git a/app/src/main/kotlin/com/wire/android/ui/e2eiEnrollment/E2EIEnrollmentScreen.kt b/app/src/main/kotlin/com/wire/android/ui/e2eiEnrollment/E2EIEnrollmentScreen.kt index cc11e227b11..a63c31d4f99 100644 --- a/app/src/main/kotlin/com/wire/android/ui/e2eiEnrollment/E2EIEnrollmentScreen.kt +++ b/app/src/main/kotlin/com/wire/android/ui/e2eiEnrollment/E2EIEnrollmentScreen.kt @@ -60,6 +60,7 @@ import com.wire.android.ui.destinations.InitialSyncScreenDestination import com.wire.android.ui.home.E2EIEnrollmentErrorWithDismissDialog import com.wire.android.ui.home.E2EISuccessDialog import com.wire.android.ui.markdown.MarkdownConstants +import com.wire.android.ui.settings.devices.e2ei.E2EICertificateDetails import com.wire.android.ui.theme.WireTheme import com.wire.android.ui.theme.wireDimensions import com.wire.android.ui.theme.wireTypography @@ -89,7 +90,15 @@ fun E2EIEnrollmentScreen( enrollE2EICertificate = viewModel::enrollE2EICertificate, handleE2EIEnrollmentResult = viewModel::handleE2EIEnrollmentResult, openCertificateDetails = { - navigator.navigate(NavigationCommand(E2eiCertificateDetailsScreenDestination(state.certificate))) + navigator.navigate( + NavigationCommand( + E2eiCertificateDetailsScreenDestination( + E2EICertificateDetails.DuringLoginCertificateDetails( + state.certificate + ) + ) + ) + ) }, onBackButtonClicked = viewModel::onBackButtonClicked, onCancelEnrollmentClicked = { viewModel.onCancelEnrollmentClicked(NavigationSwitchAccountActions(navigator::navigate)) }, diff --git a/app/src/main/kotlin/com/wire/android/ui/settings/devices/DeviceDetailsScreen.kt b/app/src/main/kotlin/com/wire/android/ui/settings/devices/DeviceDetailsScreen.kt index 029a283e75a..2cdb86be34f 100644 --- a/app/src/main/kotlin/com/wire/android/ui/settings/devices/DeviceDetailsScreen.kt +++ b/app/src/main/kotlin/com/wire/android/ui/settings/devices/DeviceDetailsScreen.kt @@ -78,18 +78,20 @@ import com.wire.android.ui.e2eiEnrollment.GetE2EICertificateUI import com.wire.android.ui.home.E2EISuccessDialog import com.wire.android.ui.home.E2EIUpdateErrorWithDismissDialog import com.wire.android.ui.home.conversationslist.common.FolderHeader +import com.wire.android.ui.settings.devices.e2ei.E2EICertificateDetails import com.wire.android.ui.settings.devices.model.DeviceDetailsState import com.wire.android.ui.theme.wireColorScheme import com.wire.android.ui.theme.wireDimensions import com.wire.android.ui.theme.wireTypography import com.wire.android.util.CustomTabsHelper +import com.wire.android.util.deviceDateTimeFormat import com.wire.android.util.dialogErrorStrings import com.wire.android.util.extension.formatAsFingerPrint import com.wire.android.util.extension.formatAsString -import com.wire.android.util.deviceDateTimeFormat import com.wire.android.util.ui.UIText import com.wire.kalium.logic.CoreFailure import com.wire.kalium.logic.data.conversation.ClientId +import com.wire.kalium.logic.feature.e2ei.E2eiCertificate import com.wire.kalium.logic.feature.e2ei.usecase.E2EIEnrollmentResult import com.wire.kalium.logic.functional.Either @@ -117,7 +119,7 @@ fun DeviceDetailsScreen( handleE2EIEnrollmentResult = viewModel::handleE2EIEnrollmentResult, onNavigateToE2eiCertificateDetailsScreen = { navigator.navigate( - NavigationCommand(E2eiCertificateDetailsScreenDestination(it)) + NavigationCommand(E2eiCertificateDetailsScreenDestination(E2EICertificateDetails.AfterLoginCertificateDetails(it))) ) }, onEnrollE2EIErrorDismiss = viewModel::hideEnrollE2EICertificateError, @@ -125,13 +127,13 @@ fun DeviceDetailsScreen( ) } } - +@Suppress("ComplexMethod") @Composable fun DeviceDetailsContent( state: DeviceDetailsState, onDeleteDevice: () -> Unit = {}, onNavigateBack: () -> Unit = {}, - onNavigateToE2eiCertificateDetailsScreen: (String) -> Unit = {}, + onNavigateToE2eiCertificateDetailsScreen: (E2eiCertificate) -> Unit = {}, onPasswordChange: (TextFieldValue) -> Unit = {}, onRemoveConfirm: () -> Unit = {}, onDialogDismiss: () -> Unit = {}, @@ -192,7 +194,7 @@ fun DeviceDetailsContent( } } - if (state.isE2EIEnabled) { + if (state.isE2EIEnabled && state.e2eiCertificate != null) { item { EndToEndIdentityCertificateItem( isE2eiCertificateActivated = state.isE2eiCertificateActivated, @@ -286,9 +288,9 @@ fun DeviceDetailsContent( ) } - if (state.isE2EICertificateEnrollSuccess) { + if (state.isE2EICertificateEnrollSuccess && state.e2eiCertificate != null) { E2EISuccessDialog( - openCertificateDetails = { onNavigateToE2eiCertificateDetailsScreen(state.e2eiCertificate.certificateDetail) }, + openCertificateDetails = { onNavigateToE2eiCertificateDetailsScreen(state.e2eiCertificate) }, dismissDialog = onEnrollE2EISuccessDismiss ) } diff --git a/app/src/main/kotlin/com/wire/android/ui/settings/devices/EndToEndIdentityCertificateItem.kt b/app/src/main/kotlin/com/wire/android/ui/settings/devices/EndToEndIdentityCertificateItem.kt index 9bdafc232ee..30a3969d952 100644 --- a/app/src/main/kotlin/com/wire/android/ui/settings/devices/EndToEndIdentityCertificateItem.kt +++ b/app/src/main/kotlin/com/wire/android/ui/settings/devices/EndToEndIdentityCertificateItem.kt @@ -51,7 +51,7 @@ fun EndToEndIdentityCertificateItem( isCurrentDevice: Boolean, isLoadingCertificate: Boolean, enrollE2eiCertificate: () -> Unit, - showCertificate: (String) -> Unit + showCertificate: (E2eiCertificate) -> Unit ) { Column( modifier = Modifier @@ -124,7 +124,7 @@ fun EndToEndIdentityCertificateItem( enabled = true, isLoading = false, onShowCertificateClicked = { - showCertificate(certificate.certificateDetail) + showCertificate(certificate) } ) } else { @@ -199,9 +199,11 @@ fun PreviewEndToEndIdentityCertificateItem() { isE2eiCertificateActivated = true, isCurrentDevice = false, certificate = E2eiCertificate( + userHandle = "userHandle", status = CertificateStatus.VALID, serialNumber = "e5:d5:e6:75:7e:04:86:07:14:3c:a0:ed:9a:8d:e4:fd", certificateDetail = "", + thumbprint = "thumbprint", endAt = Instant.DISTANT_FUTURE ), isLoadingCertificate = false, @@ -217,9 +219,11 @@ fun PreviewEndToEndIdentityCertificateSelfItem() { isE2eiCertificateActivated = true, isCurrentDevice = true, certificate = E2eiCertificate( + userHandle = "userHandle", status = CertificateStatus.VALID, serialNumber = "e5:d5:e6:75:7e:04:86:07:14:3c:a0:ed:9a:8d:e4:fd", certificateDetail = "", + thumbprint = "thumbprint", endAt = Instant.DISTANT_FUTURE ), isLoadingCertificate = false, diff --git a/app/src/main/kotlin/com/wire/android/ui/settings/devices/e2ei/E2eiCertificateDetailsScreenNavArgs.kt b/app/src/main/kotlin/com/wire/android/ui/settings/devices/e2ei/E2eiCertificateDetailsScreenNavArgs.kt index 340caeb21de..893e951e915 100644 --- a/app/src/main/kotlin/com/wire/android/ui/settings/devices/e2ei/E2eiCertificateDetailsScreenNavArgs.kt +++ b/app/src/main/kotlin/com/wire/android/ui/settings/devices/e2ei/E2eiCertificateDetailsScreenNavArgs.kt @@ -17,6 +17,13 @@ */ package com.wire.android.ui.settings.devices.e2ei -data class E2eiCertificateDetailsScreenNavArgs( - val certificateString: String -) +import com.wire.kalium.logic.feature.e2ei.E2eiCertificate +import kotlinx.serialization.Serializable + +data class E2eiCertificateDetailsScreenNavArgs(val certificateDetails: E2EICertificateDetails) + +@Serializable +sealed class E2EICertificateDetails { + data class AfterLoginCertificateDetails(val certificate: E2eiCertificate) : E2EICertificateDetails() + data class DuringLoginCertificateDetails(val certificate: String) : E2EICertificateDetails() +} diff --git a/app/src/main/kotlin/com/wire/android/ui/settings/devices/e2ei/E2eiCertificateDetailsViewModel.kt b/app/src/main/kotlin/com/wire/android/ui/settings/devices/e2ei/E2eiCertificateDetailsViewModel.kt index 3d195b8b38b..5b2bb047913 100644 --- a/app/src/main/kotlin/com/wire/android/ui/settings/devices/e2ei/E2eiCertificateDetailsViewModel.kt +++ b/app/src/main/kotlin/com/wire/android/ui/settings/devices/e2ei/E2eiCertificateDetailsViewModel.kt @@ -42,7 +42,7 @@ class E2eiCertificateDetailsViewModel @Inject constructor( var state: E2eiCertificateDetailsState by mutableStateOf(E2eiCertificateDetailsState()) private set - private val e2eiCertificateDetailsScreenNavArgs: E2eiCertificateDetailsScreenNavArgs = + private val navArgs: E2eiCertificateDetailsScreenNavArgs = savedStateHandle.navArgs() private var selfUserHandle: String? = null @@ -57,11 +57,27 @@ class E2eiCertificateDetailsViewModel @Inject constructor( } } - fun getCertificate() = e2eiCertificateDetailsScreenNavArgs.certificateString + fun getCertificate() = + when (navArgs.certificateDetails) { + is E2EICertificateDetails.DuringLoginCertificateDetails -> + navArgs.certificateDetails.certificate + + is E2EICertificateDetails.AfterLoginCertificateDetails -> + navArgs.certificateDetails.certificate.certificateDetail + } + + fun userHandle() = + when (navArgs.certificateDetails) { + is E2EICertificateDetails.DuringLoginCertificateDetails -> + selfUserHandle + + is E2EICertificateDetails.AfterLoginCertificateDetails -> + navArgs.certificateDetails.certificate.userHandle + } fun getCertificateName(): String { val date = DateTimeUtil.currentInstant().fileDateTime() - return "wire-certificate-$selfUserHandle-$date.txt" + return "wire-certificate-${userHandle()}-$date.txt" } } diff --git a/app/src/main/kotlin/com/wire/android/ui/settings/devices/model/DeviceDetailsState.kt b/app/src/main/kotlin/com/wire/android/ui/settings/devices/model/DeviceDetailsState.kt index 784f0d38fb1..4a1641fafea 100644 --- a/app/src/main/kotlin/com/wire/android/ui/settings/devices/model/DeviceDetailsState.kt +++ b/app/src/main/kotlin/com/wire/android/ui/settings/devices/model/DeviceDetailsState.kt @@ -20,9 +20,7 @@ package com.wire.android.ui.settings.devices.model import com.wire.android.ui.authentication.devices.model.Device import com.wire.android.ui.authentication.devices.remove.RemoveDeviceDialogState import com.wire.android.ui.authentication.devices.remove.RemoveDeviceError -import com.wire.kalium.logic.feature.e2ei.CertificateStatus import com.wire.kalium.logic.feature.e2ei.E2eiCertificate -import kotlinx.datetime.Instant data class DeviceDetailsState( val device: Device = Device(), @@ -33,12 +31,7 @@ data class DeviceDetailsState( val isSelfClient: Boolean = false, val userName: String? = null, val isE2eiCertificateActivated: Boolean = false, - val e2eiCertificate: E2eiCertificate = E2eiCertificate( - status = CertificateStatus.EXPIRED, - serialNumber = "", - certificateDetail = "", - endAt = Instant.DISTANT_FUTURE - ), + val e2eiCertificate: E2eiCertificate? = null, val canBeRemoved: Boolean = false, val isLoadingCertificate: Boolean = false, val isE2EICertificateEnrollSuccess: Boolean = false, diff --git a/kalium b/kalium index d7dccb81769..a1fdb7faa65 160000 --- a/kalium +++ b/kalium @@ -1 +1 @@ -Subproject commit d7dccb817696a857789954977725a49b2c253d2a +Subproject commit a1fdb7faa6566154e3ea48adb5bcb41634722083