Skip to content

Commit

Permalink
fix: Remove useless runCatchings
Browse files Browse the repository at this point in the history
  • Loading branch information
KevinBoulongne authored and LunarX committed Dec 20, 2024
1 parent de26d31 commit a2696b5
Showing 1 changed file with 20 additions and 37 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,6 @@ import com.infomaniak.swisstransfer.ui.screen.newtransfer.ImportFilesViewModel.A
import com.infomaniak.swisstransfer.ui.screen.newtransfer.ImportFilesViewModel.SendActionResult
import com.infomaniak.swisstransfer.workers.UploadWorker
import dagger.hilt.android.scopes.ViewModelScoped
import kotlinx.coroutines.CancellationException
import kotlinx.coroutines.coroutineScope
import kotlinx.coroutines.flow.MutableStateFlow
import kotlinx.coroutines.flow.asStateFlow
Expand Down Expand Up @@ -67,11 +66,11 @@ class TransferSendManager @Inject constructor(
}

private suspend fun sendTransfer(uploadSessionUuid: String) {
runCatching {
_integrityCheckResult.value = AppIntegrityResult.Ongoing
_integrityCheckResult.value = AppIntegrityResult.Ongoing

withIntegrityToken(
onSuccess = { attestationToken ->
withIntegrityToken(
onSuccess = { attestationToken ->
runCatching {
_integrityCheckResult.value = AppIntegrityResult.Success
_sendActionResult.update { SendActionResult.Pending }

Expand All @@ -84,43 +83,27 @@ class TransferSendManager @Inject constructor(
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)
}
}.onFailure { exception ->
SentryLog.e(TAG, "Failed to start the upload", exception)
_sendActionResult.update { SendActionResult.Failure }
},
)
}.onFailure { exception ->
SentryLog.e(TAG, "Failed to start the upload", exception)
_sendActionResult.update { SendActionResult.Failure }
}
}
},
onRefused = { _integrityCheckResult.value = AppIntegrityResult.Fail },
)
}

//region App Integrity
private suspend inline fun withIntegrityToken(
onSuccess: (attestationToken: String) -> Unit,
onRefused: () -> Unit = {},
onFailure: (exception: Throwable) -> Unit = {},
) {
runCatching {
var attestationToken: String? = null

coroutineScope {
appIntegrityManager.getChallenge(
onSuccess = { launch { attestationToken = requestAppIntegrityToken(appIntegrityManager) } },
onFailure = {},
)
}

attestationToken?.let(onSuccess) ?: onRefused()
}.onFailure {
onFailure.invoke(it)
private suspend inline fun withIntegrityToken(onSuccess: (attestationToken: String) -> Unit, onRefused: () -> Unit = {}) {
var attestationToken: String? = null

coroutineScope {
appIntegrityManager.getChallenge(
onSuccess = { launch { attestationToken = requestAppIntegrityToken(appIntegrityManager) } },
onFailure = {},
)
}

attestationToken?.let(onSuccess) ?: onRefused()
}

private suspend fun requestAppIntegrityToken(appIntegrityManager: AppIntegrityManager): String? {
Expand Down

0 comments on commit a2696b5

Please sign in to comment.