From e8e35a3fe2b5eaed400406932cb7927b647c0cc9 Mon Sep 17 00:00:00 2001 From: dankito Date: Sun, 31 Oct 2021 01:19:14 +0200 Subject: [PATCH] Fixed that if balance should not get fetched that we did abort instead of continuing with retrieving transactions --- .../net/dankito/banking/fints/FinTsJobExecutor.kt | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) 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 1cd27e7f..8d3d6900 100644 --- a/fints4k/src/commonMain/kotlin/net/dankito/banking/fints/FinTsJobExecutor.kt +++ b/fints4k/src/commonMain/kotlin/net/dankito/banking/fints/FinTsJobExecutor.kt @@ -196,7 +196,7 @@ open class FinTsJobExecutor( else { mayGetBalance(parameter, dialogContext) { balanceResponse -> if (dialogContext.didBankCloseDialog) { - callback(GetTransactionsResponse(balanceResponse, RetrievedAccountData.unsuccessfulList(parameter.account))) + callback(GetTransactionsResponse(balanceResponse ?: initDialogResponse, RetrievedAccountData.unsuccessfulList(parameter.account))) } else { getTransactionsAfterInitAndGetBalance(parameter, dialogContext, balanceResponse, callback) @@ -207,8 +207,8 @@ open class FinTsJobExecutor( } protected open fun getTransactionsAfterInitAndGetBalance(parameter: GetTransactionsParameter, dialogContext: DialogContext, - balanceResponse: BankResponse, callback: (GetTransactionsResponse) -> Unit) { - var balance: Money? = balanceResponse.getFirstSegmentById(InstituteSegmentId.Balance)?.let { + balanceResponse: BankResponse?, callback: (GetTransactionsResponse) -> Unit) { + var balance: Money? = balanceResponse?.getFirstSegmentById(InstituteSegmentId.Balance)?.let { Money(it.balance, it.currency) } val bookedTransactions = mutableSetOf() @@ -255,7 +255,7 @@ open class FinTsJobExecutor( } } - protected open fun mayGetBalance(parameter: GetTransactionsParameter, dialogContext: DialogContext, callback: (BankResponse) -> Unit) { + protected open fun mayGetBalance(parameter: GetTransactionsParameter, dialogContext: DialogContext, callback: (BankResponse?) -> Unit) { if (parameter.alsoRetrieveBalance && parameter.account.supportsRetrievingBalance) { val message = messageBuilder.createGetBalanceMessage(parameter.account, dialogContext) @@ -264,8 +264,7 @@ open class FinTsJobExecutor( } } else { - callback(BankResponse(false, errorMessage = "Either not requested to get balance or account does not support retrieving balance. " + - "Should retrieve balance = ${parameter.alsoRetrieveBalance}, account supports retrieving balance = ${parameter.account.supportsRetrievingBalance}.")) + callback(null) } }