From 4ec366f7cde03a2b60cf726e3bb126c831b0d0cd Mon Sep 17 00:00:00 2001 From: dankito Date: Mon, 14 Feb 2022 00:45:13 +0100 Subject: [PATCH] Made clearer that sendMessageAndHandleResponse() starts a new dialog --- .../dankito/banking/fints/FinTsClientDeprecated.kt | 3 ++- .../net/dankito/banking/fints/FinTsJobExecutor.kt | 12 ++++++------ 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/fints4k/src/commonMain/kotlin/net/dankito/banking/fints/FinTsClientDeprecated.kt b/fints4k/src/commonMain/kotlin/net/dankito/banking/fints/FinTsClientDeprecated.kt index d590688a..96b2a972 100644 --- a/fints4k/src/commonMain/kotlin/net/dankito/banking/fints/FinTsClientDeprecated.kt +++ b/fints4k/src/commonMain/kotlin/net/dankito/banking/fints/FinTsClientDeprecated.kt @@ -70,7 +70,8 @@ open class FinTsClientDeprecated @JvmOverloads constructor( return@retrieveBasicDataLikeUsersTanMethods } - /* Second dialog: some banks require that in order to initialize a dialog with strong customer authorization TAN media is required */ + /* Second dialog, executed in retrieveBasicDataLikeUsersTanMethods() if required: some banks require that in order to initialize a dialog with + strong customer authorization TAN media is required */ addAccountGetAccountsAndTransactions(context, parameter, callback) } diff --git a/fints4k/src/commonMain/kotlin/net/dankito/banking/fints/FinTsJobExecutor.kt b/fints4k/src/commonMain/kotlin/net/dankito/banking/fints/FinTsJobExecutor.kt index c8b44424..3ea52c0f 100644 --- a/fints4k/src/commonMain/kotlin/net/dankito/banking/fints/FinTsJobExecutor.kt +++ b/fints4k/src/commonMain/kotlin/net/dankito/banking/fints/FinTsJobExecutor.kt @@ -176,7 +176,7 @@ open class FinTsJobExecutor( open fun getTransactionsAsync(context: JobContext, parameter: GetAccountTransactionsParameter, callback: (GetAccountTransactionsResponse) -> Unit) { - val dialogContext = context.startNewDialog() + val dialogContext = context.startNewDialog() // TODO: initDialogWithStrongCustomerAuthentication() also starts a new dialog in initDialogWithStrongCustomerAuthenticationAfterSuccessfulPreconditionChecks() initDialogWithStrongCustomerAuthentication(context) { initDialogResponse -> @@ -296,7 +296,7 @@ open class FinTsJobExecutor( protected open fun getTanMediaList(context: JobContext, tanMediaKind: TanMedienArtVersion = TanMedienArtVersion.Alle, tanMediumClass: TanMediumKlasse = TanMediumKlasse.AlleMedien, preferredTanMedium: String? = null, callback: (GetTanMediaListResponse) -> Unit) { - sendMessageAndHandleResponse(context, CustomerSegmentId.TanMediaList, false, { + sendMessageInNewDialogAndHandleResponse(context, CustomerSegmentId.TanMediaList, false, { messageBuilder.createGetTanMediaListMessage(context, tanMediaKind, tanMediumClass) }) { response -> handleGetTanMediaListResponse(context, response, preferredTanMedium, callback) @@ -344,7 +344,7 @@ open class FinTsJobExecutor( protected open fun sendChangeTanMediumMessage(context: JobContext, newActiveTanMedium: TanGeneratorTanMedium, enteredAtc: EnterTanGeneratorAtcResult?, callback: (BankResponse) -> Unit) { - sendMessageAndHandleResponse(context, null, true, { + sendMessageInNewDialogAndHandleResponse(context, null, true, { messageBuilder.createChangeTanMediumMessage(context, newActiveTanMedium, enteredAtc?.tan, enteredAtc?.atc) }, callback) } @@ -352,7 +352,7 @@ open class FinTsJobExecutor( open fun doBankTransferAsync(context: JobContext, bankTransferData: BankTransferData, callback: (FinTsClientResponse) -> Unit) { - sendMessageAndHandleResponse(context, null, true, { + sendMessageInNewDialogAndHandleResponse(context, null, true, { val updatedAccount = getUpdatedAccount(context, context.account!!) messageBuilder.createBankTransferMessage(context, bankTransferData, updatedAccount) }) { response -> @@ -521,8 +521,8 @@ open class FinTsJobExecutor( } - protected open fun sendMessageAndHandleResponse(context: JobContext, segmentForNonStrongCustomerAuthenticationTwoStepTanProcess: CustomerSegmentId? = null, - closeDialog: Boolean = true, createMessage: () -> MessageBuilderResult, callback: (BankResponse) -> Unit) { + protected open fun sendMessageInNewDialogAndHandleResponse(context: JobContext, segmentForNonStrongCustomerAuthenticationTwoStepTanProcess: CustomerSegmentId? = null, + closeDialog: Boolean = true, createMessage: () -> MessageBuilderResult, callback: (BankResponse) -> Unit) { context.startNewDialog(closeDialog)