From 0de9e51cc8b79ad88897e2df99a1c3606dca37cc Mon Sep 17 00:00:00 2001 From: Kevin Boulongne Date: Thu, 19 Dec 2024 14:32:52 +0100 Subject: [PATCH] feat: Add `resendLastTransfer()` function in TransferSend manager --- .../newtransfer/ImportFilesViewModel.kt | 2 +- .../screen/newtransfer/TransferSendManager.kt | 74 ++++++++++--------- 2 files changed, 42 insertions(+), 34 deletions(-) diff --git a/app/src/main/java/com/infomaniak/swisstransfer/ui/screen/newtransfer/ImportFilesViewModel.kt b/app/src/main/java/com/infomaniak/swisstransfer/ui/screen/newtransfer/ImportFilesViewModel.kt index ca2a72d186..448fb27315 100644 --- a/app/src/main/java/com/infomaniak/swisstransfer/ui/screen/newtransfer/ImportFilesViewModel.kt +++ b/app/src/main/java/com/infomaniak/swisstransfer/ui/screen/newtransfer/ImportFilesViewModel.kt @@ -131,7 +131,7 @@ class ImportFilesViewModel @Inject constructor( fun sendTransfer() { viewModelScope.launch(ioDispatcher) { - transferSendManager.sendTransfer(generateNewUploadSession()) + transferSendManager.sendNewTransfer(generateNewUploadSession()) } } diff --git a/app/src/main/java/com/infomaniak/swisstransfer/ui/screen/newtransfer/TransferSendManager.kt b/app/src/main/java/com/infomaniak/swisstransfer/ui/screen/newtransfer/TransferSendManager.kt index 05ecb882df..2e23735439 100644 --- a/app/src/main/java/com/infomaniak/swisstransfer/ui/screen/newtransfer/TransferSendManager.kt +++ b/app/src/main/java/com/infomaniak/swisstransfer/ui/screen/newtransfer/TransferSendManager.kt @@ -46,49 +46,57 @@ class TransferSendManager @Inject constructor( private val uploadWorkerScheduler: UploadWorker.Scheduler, ) { - // TODO: Merge these two ui states in a single one for the whole flow of logic + // TODO: Merge these two UI states in a single one for the whole flow of logic private val _sendActionResult = MutableStateFlow(SendActionResult.NotStarted) val sendActionResult = _sendActionResult.asStateFlow() private val _integrityCheckResult = MutableStateFlow(AppIntegrityResult.Idle) val integrityCheckResult = _integrityCheckResult.asStateFlow() - suspend fun sendTransfer(newUploadSession: NewUploadSession) { - _integrityCheckResult.value = AppIntegrityResult.Ongoing - - withIntegrityToken( - onSuccess = { attestationToken -> - sendTransfer(newUploadSession, attestationToken) - }, - onRefused = { - _integrityCheckResult.value = AppIntegrityResult.Fail - }, - onFailure = { exception -> - if (exception !is CancellationException) { - SentryLog.e(TAG, "Integrity token received an exception", exception) - } else { - SentryLog.i(TAG, "Integrity token received an exception", exception) - } - _sendActionResult.update { SendActionResult.Failure } - } - ) + suspend fun sendNewTransfer(newUploadSession: NewUploadSession) { + val uploadSession = uploadManager.createAndGetUpload(newUploadSession) + sendTransfer(uploadSession.uuid) } - private suspend fun sendTransfer(newUploadSession: NewUploadSession, attestationToken: String) { - _integrityCheckResult.value = AppIntegrityResult.Success - _sendActionResult.update { SendActionResult.Pending } + suspend fun resendLastTransfer() { + val uploadSessionUuid = uploadManager.getLastUpload()?.uuid ?: run { + SentryLog.e(TAG, "No last upload found") + return + } + sendTransfer(uploadSessionUuid) + } + private suspend fun sendTransfer(uploadSessionUuid: String) { runCatching { - val uuid = uploadManager.createAndGetUpload(newUploadSession).uuid - uploadManager.initUploadSession( - attestationHeaderName = AppIntegrityManager.ATTESTATION_TOKEN_HEADER, - attestationToken = attestationToken, - )!! // TODO: Handle ContainerErrorsException here - uploadWorkerScheduler.scheduleWork(uuid) - _sendActionResult.update { - val totalSize = importationFilesManager.importedFiles.value.sumOf { it.fileSize } - SendActionResult.Success(totalSize) - } + _integrityCheckResult.value = AppIntegrityResult.Ongoing + + withIntegrityToken( + onSuccess = { attestationToken -> + _integrityCheckResult.value = AppIntegrityResult.Success + _sendActionResult.update { SendActionResult.Pending } + + uploadManager.initUploadSession( + attestationHeaderName = AppIntegrityManager.ATTESTATION_TOKEN_HEADER, + attestationToken = attestationToken, + )!! // TODO: Handle ContainerErrorsException here + uploadWorkerScheduler.scheduleWork(uploadSessionUuid) + _sendActionResult.update { + val totalSize = importationFilesManager.importedFiles.value.sumOf { it.fileSize } + SendActionResult.Success(totalSize) + } + }, + onRefused = { + _integrityCheckResult.value = AppIntegrityResult.Fail + }, + onFailure = { exception -> + if (exception !is CancellationException) { + SentryLog.e(TAG, "Integrity token received an exception", exception) + } else { + SentryLog.i(TAG, "Integrity token received an exception", exception) + } + _sendActionResult.update { SendActionResult.Failure } + }, + ) }.onFailure { exception -> SentryLog.e(TAG, "Failed to start the upload", exception) _sendActionResult.update { SendActionResult.Failure }