From c89960a3d8ef504dd53115a2571f84dfc25ae0a6 Mon Sep 17 00:00:00 2001 From: dankito Date: Tue, 15 Oct 2019 23:38:18 +0200 Subject: [PATCH] Made determining TanProcedureType more robust; added PhotoTan --- .../kotlin/net/dankito/fints/FinTsClient.kt | 28 +++++++++++++------ .../dankito/fints/model/TanProcedureType.kt | 2 ++ 2 files changed, 21 insertions(+), 9 deletions(-) diff --git a/fints4javaLib/src/main/kotlin/net/dankito/fints/FinTsClient.kt b/fints4javaLib/src/main/kotlin/net/dankito/fints/FinTsClient.kt index c061209c..3d9bb7ed 100644 --- a/fints4javaLib/src/main/kotlin/net/dankito/fints/FinTsClient.kt +++ b/fints4javaLib/src/main/kotlin/net/dankito/fints/FinTsClient.kt @@ -553,22 +553,32 @@ open class FinTsClient @JvmOverloads constructor( } protected open fun mapToTanProcedure(parameters: TanProcedureParameters): TanProcedure? { - val function = parameters.securityFunction val procedureName = parameters.procedureName - val nameLowerCase = procedureName.toLowerCase() + + // we filter out iTAN and Einschritt-Verfahren as they are not permitted anymore according to PSD2 + if (procedureName.toLowerCase() == "itan") { + return null + } + + return TanProcedure(procedureName, parameters.securityFunction, + mapToTanProcedureType(parameters) ?: TanProcedureType.EnterTan) + } + + protected open fun mapToTanProcedureType(parameters: TanProcedureParameters): TanProcedureType? { + val nameLowerCase = parameters.procedureName.toLowerCase() return when { + nameLowerCase.contains("photo") -> TanProcedureType.PhotoTan + nameLowerCase.contains("chiptan") -> { - if (nameLowerCase.contains("qr")) { - TanProcedure(procedureName, function, TanProcedureType.ChipTanQrCode) - } - else { - TanProcedure(procedureName, function, TanProcedureType.ChipTan) + return when { + nameLowerCase.contains("qr") -> TanProcedureType.ChipTanQrCode + else -> TanProcedureType.ChipTan } } - nameLowerCase.contains("sms") -> TanProcedure(procedureName, function, TanProcedureType.SmsTan) - nameLowerCase.contains("push") -> TanProcedure(procedureName, function, TanProcedureType.PushTan) + nameLowerCase.contains("push") -> return TanProcedureType.PushTan + nameLowerCase.contains("sms") || nameLowerCase.contains("mobile") -> return TanProcedureType.SmsTan // TODO: what about other tan procedures we're not aware of? // we filter out iTAN and Einschritt-Verfahren as they are not permitted anymore according to PSD2 diff --git a/fints4javaLib/src/main/kotlin/net/dankito/fints/model/TanProcedureType.kt b/fints4javaLib/src/main/kotlin/net/dankito/fints/model/TanProcedureType.kt index e70dbfce..6f9d8872 100644 --- a/fints4javaLib/src/main/kotlin/net/dankito/fints/model/TanProcedureType.kt +++ b/fints4javaLib/src/main/kotlin/net/dankito/fints/model/TanProcedureType.kt @@ -9,6 +9,8 @@ enum class TanProcedureType { ChipTanQrCode, + PhotoTan, + SmsTan, PushTan