Replaced areWeThatGentleToCloseDialogs by DialogContext.closeDialog
This commit is contained in:
parent
95736a8150
commit
ee38799cad
|
@ -55,8 +55,6 @@ open class FinTsClient(
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
open var areWeThatGentleToCloseDialogs: Boolean = true
|
|
||||||
|
|
||||||
protected val messageLog = ArrayList<MessageLogEntry>() // TODO: make thread safe like with CopyOnWriteArrayList
|
protected val messageLog = ArrayList<MessageLogEntry>() // TODO: make thread safe like with CopyOnWriteArrayList
|
||||||
|
|
||||||
// in either case remove sensitive data after response is parsed as otherwise some information like account holder name and accounts may is not set yet on BankData
|
// in either case remove sensitive data after response is parsed as otherwise some information like account holder name and accounts may is not set yet on BankData
|
||||||
|
@ -108,7 +106,7 @@ open class FinTsClient(
|
||||||
protected open fun closeAnonymousDialog(dialogContext: DialogContext, response: BankResponse) {
|
protected open fun closeAnonymousDialog(dialogContext: DialogContext, response: BankResponse) {
|
||||||
|
|
||||||
// bank already closed dialog -> there's no need to send dialog end message
|
// bank already closed dialog -> there's no need to send dialog end message
|
||||||
if (areWeThatGentleToCloseDialogs == false || dialogContext.didBankCloseDialog) {
|
if (dialogContext.closeDialog == false || dialogContext.didBankCloseDialog) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,12 +117,12 @@ open class FinTsClient(
|
||||||
|
|
||||||
|
|
||||||
open fun getUsersTanMethods(bank: BankData, callback: (FinTsClientResponse) -> Unit) {
|
open fun getUsersTanMethods(bank: BankData, callback: (FinTsClientResponse) -> Unit) {
|
||||||
getUsersTanMethodsInternal(bank) {
|
getUsersTanMethodsInternal(bank, true) {
|
||||||
callback(FinTsClientResponse(it))
|
callback(FinTsClientResponse(it))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected open fun getUsersTanMethodsInternal(bank: BankData, callback: (BankResponse) -> Unit) {
|
protected open fun getUsersTanMethodsInternal(bank: BankData, closeDialog: Boolean = false, callback: (BankResponse) -> Unit) {
|
||||||
// just to ensure settings are in its initial state and that bank sends us bank parameter (BPD),
|
// just to ensure settings are in its initial state and that bank sends us bank parameter (BPD),
|
||||||
// user parameter (UPD) and allowed tan methods for user (therefore the resetSelectedTanMethod())
|
// user parameter (UPD) and allowed tan methods for user (therefore the resetSelectedTanMethod())
|
||||||
bank.resetBpdVersion()
|
bank.resetBpdVersion()
|
||||||
|
@ -138,7 +136,7 @@ open class FinTsClient(
|
||||||
bank.resetSelectedTanMethod()
|
bank.resetSelectedTanMethod()
|
||||||
|
|
||||||
// this is the only case where Einschritt-TAN-Verfahren is accepted: to get user's TAN methods
|
// this is the only case where Einschritt-TAN-Verfahren is accepted: to get user's TAN methods
|
||||||
val dialogContext = DialogContext(bank, product, versionOfSecurityMethod = VersionDesSicherheitsverfahrens.Version_1)
|
val dialogContext = DialogContext(bank, product, closeDialog, versionOfSecurityMethod = VersionDesSicherheitsverfahrens.Version_1)
|
||||||
|
|
||||||
val message = messageBuilder.createInitDialogMessage(dialogContext)
|
val message = messageBuilder.createInitDialogMessage(dialogContext)
|
||||||
|
|
||||||
|
@ -200,7 +198,7 @@ open class FinTsClient(
|
||||||
|
|
||||||
protected open fun getAccounts(bank: BankData, callback: (BankResponse) -> Unit) {
|
protected open fun getAccounts(bank: BankData, callback: (BankResponse) -> Unit) {
|
||||||
|
|
||||||
val dialogContext = DialogContext(bank, product)
|
val dialogContext = DialogContext(bank, product, false)
|
||||||
|
|
||||||
initDialogWithStrongCustomerAuthenticationAfterSuccessfulPreconditionChecks(dialogContext) { response ->
|
initDialogWithStrongCustomerAuthenticationAfterSuccessfulPreconditionChecks(dialogContext) { response ->
|
||||||
closeDialog(dialogContext)
|
closeDialog(dialogContext)
|
||||||
|
@ -247,9 +245,6 @@ open class FinTsClient(
|
||||||
open fun addAccountAsync(parameter: AddAccountParameter, callback: (AddAccountResponse) -> Unit) {
|
open fun addAccountAsync(parameter: AddAccountParameter, callback: (AddAccountResponse) -> Unit) {
|
||||||
val bank = parameter.bank
|
val bank = parameter.bank
|
||||||
|
|
||||||
val originalAreWeThatGentleToCloseDialogs = areWeThatGentleToCloseDialogs
|
|
||||||
areWeThatGentleToCloseDialogs = false
|
|
||||||
|
|
||||||
/* First dialog: Get user's basic data like BPD, customer system ID and her TAN methods */
|
/* First dialog: Get user's basic data like BPD, customer system ID and her TAN methods */
|
||||||
|
|
||||||
getUsersTanMethodsInternal(bank) { newUserInfoResponse ->
|
getUsersTanMethodsInternal(bank) { newUserInfoResponse ->
|
||||||
|
@ -290,12 +285,10 @@ open class FinTsClient(
|
||||||
/* Fourth dialog (if requested): Try to retrieve account balances and transactions of last 90 days without TAN */
|
/* Fourth dialog (if requested): Try to retrieve account balances and transactions of last 90 days without TAN */
|
||||||
|
|
||||||
if (parameter.fetchBalanceAndTransactions) {
|
if (parameter.fetchBalanceAndTransactions) {
|
||||||
addAccountGetAccountBalancesAndTransactions(bank, getAccountsResponse, didOverwriteUserUnselectedTanMethod,
|
addAccountGetAccountBalancesAndTransactions(bank, getAccountsResponse, didOverwriteUserUnselectedTanMethod, callback)
|
||||||
originalAreWeThatGentleToCloseDialogs, callback)
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
addAccountDone(bank, getAccountsResponse, didOverwriteUserUnselectedTanMethod, originalAreWeThatGentleToCloseDialogs,
|
addAccountDone(bank, getAccountsResponse, didOverwriteUserUnselectedTanMethod, mapOf(), callback)
|
||||||
mapOf(), callback)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -303,7 +296,7 @@ open class FinTsClient(
|
||||||
}
|
}
|
||||||
|
|
||||||
protected open fun addAccountGetAccountBalancesAndTransactions(bank: BankData, getAccountsResponse: BankResponse,
|
protected open fun addAccountGetAccountBalancesAndTransactions(bank: BankData, getAccountsResponse: BankResponse,
|
||||||
didOverwriteUserUnselectedTanMethod: Boolean, originalAreWeThatGentleToCloseDialogs: Boolean,
|
didOverwriteUserUnselectedTanMethod: Boolean,
|
||||||
callback: (AddAccountResponse) -> Unit) {
|
callback: (AddAccountResponse) -> Unit) {
|
||||||
|
|
||||||
val retrievedAccountData = bank.accounts.associateBy( { it }, { RetrievedAccountData.unsuccessful(it) } ).toMutableMap()
|
val retrievedAccountData = bank.accounts.associateBy( { it }, { RetrievedAccountData.unsuccessful(it) } ).toMutableMap()
|
||||||
|
@ -313,8 +306,7 @@ open class FinTsClient(
|
||||||
var countRetrievedAccounts = 0
|
var countRetrievedAccounts = 0
|
||||||
|
|
||||||
if (countAccountsSupportingRetrievingTransactions == 0) {
|
if (countAccountsSupportingRetrievingTransactions == 0) {
|
||||||
addAccountDone(bank, getAccountsResponse, didOverwriteUserUnselectedTanMethod,
|
addAccountDone(bank, getAccountsResponse, didOverwriteUserUnselectedTanMethod, retrievedAccountData, callback)
|
||||||
originalAreWeThatGentleToCloseDialogs, retrievedAccountData, callback)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
accountsSupportingRetrievingTransactions.forEach { account ->
|
accountsSupportingRetrievingTransactions.forEach { account ->
|
||||||
|
@ -323,7 +315,7 @@ open class FinTsClient(
|
||||||
|
|
||||||
countRetrievedAccounts++
|
countRetrievedAccounts++
|
||||||
if (countRetrievedAccounts == countAccountsSupportingRetrievingTransactions) {
|
if (countRetrievedAccounts == countAccountsSupportingRetrievingTransactions) {
|
||||||
addAccountDone(bank, getAccountsResponse, didOverwriteUserUnselectedTanMethod, originalAreWeThatGentleToCloseDialogs,
|
addAccountDone(bank, getAccountsResponse, didOverwriteUserUnselectedTanMethod,
|
||||||
retrievedAccountData, callback)
|
retrievedAccountData, callback)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -331,15 +323,13 @@ open class FinTsClient(
|
||||||
}
|
}
|
||||||
|
|
||||||
protected open fun addAccountDone(bank: BankData, getAccountsResponse: BankResponse,
|
protected open fun addAccountDone(bank: BankData, getAccountsResponse: BankResponse,
|
||||||
didOverwriteUserUnselectedTanMethod: Boolean, originalAreWeThatGentleToCloseDialogs: Boolean,
|
didOverwriteUserUnselectedTanMethod: Boolean,
|
||||||
retrievedAccountData: Map<AccountData, RetrievedAccountData>,
|
retrievedAccountData: Map<AccountData, RetrievedAccountData>,
|
||||||
callback: (AddAccountResponse) -> Unit) {
|
callback: (AddAccountResponse) -> Unit) {
|
||||||
if (didOverwriteUserUnselectedTanMethod) {
|
if (didOverwriteUserUnselectedTanMethod) {
|
||||||
bank.resetSelectedTanMethod()
|
bank.resetSelectedTanMethod()
|
||||||
}
|
}
|
||||||
|
|
||||||
areWeThatGentleToCloseDialogs = originalAreWeThatGentleToCloseDialogs
|
|
||||||
|
|
||||||
callback(AddAccountResponse(getAccountsResponse, bank, retrievedAccountData.values.toList()))
|
callback(AddAccountResponse(getAccountsResponse, bank, retrievedAccountData.values.toList()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -453,7 +443,7 @@ open class FinTsClient(
|
||||||
open fun getTanMediaList(bank: BankData, tanMediaKind: TanMedienArtVersion = TanMedienArtVersion.Alle,
|
open fun getTanMediaList(bank: BankData, tanMediaKind: TanMedienArtVersion = TanMedienArtVersion.Alle,
|
||||||
tanMediumClass: TanMediumKlasse = TanMediumKlasse.AlleMedien, callback: (GetTanMediaListResponse) -> Unit) {
|
tanMediumClass: TanMediumKlasse = TanMediumKlasse.AlleMedien, callback: (GetTanMediaListResponse) -> Unit) {
|
||||||
|
|
||||||
sendMessageAndHandleResponse(bank, CustomerSegmentId.TanMediaList, { dialogContext ->
|
sendMessageAndHandleResponse(bank, CustomerSegmentId.TanMediaList, false, { dialogContext ->
|
||||||
messageBuilder.createGetTanMediaListMessage(dialogContext, tanMediaKind, tanMediumClass)
|
messageBuilder.createGetTanMediaListMessage(dialogContext, tanMediaKind, tanMediumClass)
|
||||||
}) { response ->
|
}) { response ->
|
||||||
handleGetTanMediaListResponse(response, bank, callback)
|
handleGetTanMediaListResponse(response, bank, callback)
|
||||||
|
@ -500,7 +490,7 @@ open class FinTsClient(
|
||||||
protected open fun sendChangeTanMediumMessage(bank: BankData, newActiveTanMedium: TanGeneratorTanMedium, enteredAtc: EnterTanGeneratorAtcResult?,
|
protected open fun sendChangeTanMediumMessage(bank: BankData, newActiveTanMedium: TanGeneratorTanMedium, enteredAtc: EnterTanGeneratorAtcResult?,
|
||||||
callback: (BankResponse) -> Unit) {
|
callback: (BankResponse) -> Unit) {
|
||||||
|
|
||||||
sendMessageAndHandleResponse(bank, null, { dialogContext ->
|
sendMessageAndHandleResponse(bank, null, true, { dialogContext ->
|
||||||
messageBuilder.createChangeTanMediumMessage(newActiveTanMedium, dialogContext, enteredAtc?.tan, enteredAtc?.atc)
|
messageBuilder.createChangeTanMediumMessage(newActiveTanMedium, dialogContext, enteredAtc?.tan, enteredAtc?.atc)
|
||||||
}) { response ->
|
}) { response ->
|
||||||
callback(response)
|
callback(response)
|
||||||
|
@ -510,7 +500,7 @@ open class FinTsClient(
|
||||||
|
|
||||||
open fun doBankTransferAsync(bankTransferData: BankTransferData, bank: BankData, account: AccountData, callback: (FinTsClientResponse) -> Unit) {
|
open fun doBankTransferAsync(bankTransferData: BankTransferData, bank: BankData, account: AccountData, callback: (FinTsClientResponse) -> Unit) {
|
||||||
|
|
||||||
sendMessageAndHandleResponse(bank, null, { dialogContext ->
|
sendMessageAndHandleResponse(bank, null, true, { dialogContext ->
|
||||||
messageBuilder.createBankTransferMessage(bankTransferData, account, dialogContext)
|
messageBuilder.createBankTransferMessage(bankTransferData, account, dialogContext)
|
||||||
}) { response ->
|
}) { response ->
|
||||||
callback(FinTsClientResponse(response))
|
callback(FinTsClientResponse(response))
|
||||||
|
@ -519,9 +509,9 @@ open class FinTsClient(
|
||||||
|
|
||||||
|
|
||||||
protected open fun sendMessageAndHandleResponse(bank: BankData, segmentForNonStrongCustomerAuthenticationTwoStepTanProcess: CustomerSegmentId? = null,
|
protected open fun sendMessageAndHandleResponse(bank: BankData, segmentForNonStrongCustomerAuthenticationTwoStepTanProcess: CustomerSegmentId? = null,
|
||||||
createMessage: (DialogContext) -> MessageBuilderResult, callback: (BankResponse) -> Unit) {
|
closeDialog: Boolean = true, createMessage: (DialogContext) -> MessageBuilderResult, callback: (BankResponse) -> Unit) {
|
||||||
|
|
||||||
val dialogContext = DialogContext(bank, product)
|
val dialogContext = DialogContext(bank, product, closeDialog)
|
||||||
|
|
||||||
if (segmentForNonStrongCustomerAuthenticationTwoStepTanProcess == null) {
|
if (segmentForNonStrongCustomerAuthenticationTwoStepTanProcess == null) {
|
||||||
initDialogWithStrongCustomerAuthentication(dialogContext) { initDialogResponse ->
|
initDialogWithStrongCustomerAuthentication(dialogContext) { initDialogResponse ->
|
||||||
|
@ -605,7 +595,7 @@ open class FinTsClient(
|
||||||
protected open fun closeDialog(dialogContext: DialogContext) {
|
protected open fun closeDialog(dialogContext: DialogContext) {
|
||||||
|
|
||||||
// bank already closed dialog -> there's no need to send dialog end message
|
// bank already closed dialog -> there's no need to send dialog end message
|
||||||
if (areWeThatGentleToCloseDialogs == false || dialogContext.didBankCloseDialog) {
|
if (dialogContext.closeDialog == false || dialogContext.didBankCloseDialog) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue