From 1cb88d0548c2e6c070e879a85381515c8a8c5ad2 Mon Sep 17 00:00:00 2001 From: Nicklas Warming Jacobsen Date: Tue, 30 Jan 2024 12:34:54 +0100 Subject: [PATCH 1/2] Fixes: #462: In com.android.identity.wallet.transfer.Communication sendResponse If `closeAfterSending` is true, only close the connection after we know the `deviceResponse` payload have been sent. Signed-off-by: Nicklas Warming Jacobsen --- .../fragment/TransferDocumentFragment.kt | 4 ++-- .../identity/wallet/transfer/Communication.kt | 23 ++++++++----------- .../wallet/transfer/TransferManager.kt | 12 +++++----- 3 files changed, 17 insertions(+), 22 deletions(-) diff --git a/appholder/src/main/java/com/android/identity/wallet/fragment/TransferDocumentFragment.kt b/appholder/src/main/java/com/android/identity/wallet/fragment/TransferDocumentFragment.kt index 886dba211..0751d82c3 100644 --- a/appholder/src/main/java/com/android/identity/wallet/fragment/TransferDocumentFragment.kt +++ b/appholder/src/main/java/com/android/identity/wallet/fragment/TransferDocumentFragment.kt @@ -163,13 +163,13 @@ class TransferDocumentFragment : Fragment() { private fun onTransferDisconnected() { log("Disconnected") hideButtons() - TransferManager.getInstance(requireContext()).disconnect() + TransferManager.getInstance(requireContext()).disconnect(true) } private fun onTransferError() { Toast.makeText(requireContext(), "An error occurred.", Toast.LENGTH_SHORT).show() hideButtons() - TransferManager.getInstance(requireContext()).disconnect() + TransferManager.getInstance(requireContext()).disconnect(true) } private fun hideButtons() { diff --git a/appholder/src/main/java/com/android/identity/wallet/transfer/Communication.kt b/appholder/src/main/java/com/android/identity/wallet/transfer/Communication.kt index 3b2d04891..e53de72b0 100644 --- a/appholder/src/main/java/com/android/identity/wallet/transfer/Communication.kt +++ b/appholder/src/main/java/com/android/identity/wallet/transfer/Communication.kt @@ -45,21 +45,16 @@ class Communication private constructor( if (progress == max) { log("Completed...") } + if (progress == max && closeAfterSending) { + deviceRetrievalHelper?.disconnect() + } } - if (closeAfterSending) { - deviceRetrievalHelper?.sendDeviceResponse( - deviceResponse, - OptionalLong.of(Constants.SESSION_DATA_STATUS_SESSION_TERMINATION), - progressListener, - context.mainExecutor()) - deviceRetrievalHelper?.disconnect() - } else { - deviceRetrievalHelper?.sendDeviceResponse( - deviceResponse, - OptionalLong.empty(), - progressListener, - context.mainExecutor()) - } + + deviceRetrievalHelper?.sendDeviceResponse( + deviceResponse, + OptionalLong.of(Constants.SESSION_DATA_STATUS_SESSION_TERMINATION), + progressListener, + context.mainExecutor()) } fun stopPresentation( diff --git a/appholder/src/main/java/com/android/identity/wallet/transfer/TransferManager.kt b/appholder/src/main/java/com/android/identity/wallet/transfer/TransferManager.kt index 0dbb7d392..c130112a6 100644 --- a/appholder/src/main/java/com/android/identity/wallet/transfer/TransferManager.kt +++ b/appholder/src/main/java/com/android/identity/wallet/transfer/TransferManager.kt @@ -244,11 +244,13 @@ class TransferManager private constructor(private val context: Context) { sendSessionTerminationMessage, useTransportSpecificSessionTermination ) - disconnect() + disconnect(true) } - fun disconnect() { - communication.disconnect() + fun disconnect(disconnectCommunication: Boolean) { + if (disconnectCommunication) { + communication.disconnect() + } qrCommunicationSetup?.close() transferStatusLd = MutableLiveData() destroy() @@ -262,9 +264,7 @@ class TransferManager private constructor(private val context: Context) { fun sendResponse(deviceResponse: ByteArray, closeAfterSending: Boolean) { communication.sendResponse(deviceResponse, closeAfterSending) - if (closeAfterSending) { - disconnect() - } + disconnect(!closeAfterSending) } fun readDocumentEntries(documentName: String): DocumentElements { From 069e9dbd342741a92cb2d04f756df52ee7e97df5 Mon Sep 17 00:00:00 2001 From: Nicklas Warming Jacobsen Date: Thu, 1 Feb 2024 09:17:27 +0100 Subject: [PATCH 2/2] conditionally call disconnect in SendResponse Signed-off-by: Nicklas Warming Jacobsen --- .../com/android/identity/wallet/transfer/TransferManager.kt | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/appholder/src/main/java/com/android/identity/wallet/transfer/TransferManager.kt b/appholder/src/main/java/com/android/identity/wallet/transfer/TransferManager.kt index c130112a6..5d6748392 100644 --- a/appholder/src/main/java/com/android/identity/wallet/transfer/TransferManager.kt +++ b/appholder/src/main/java/com/android/identity/wallet/transfer/TransferManager.kt @@ -264,7 +264,9 @@ class TransferManager private constructor(private val context: Context) { fun sendResponse(deviceResponse: ByteArray, closeAfterSending: Boolean) { communication.sendResponse(deviceResponse, closeAfterSending) - disconnect(!closeAfterSending) + if (closeAfterSending) { + disconnect(false) + } } fun readDocumentEntries(documentName: String): DocumentElements {