From 820e271d1f10dc087051b9ef611c0274fa4a373a Mon Sep 17 00:00:00 2001 From: dankito Date: Sat, 8 Aug 2020 18:15:48 +0200 Subject: [PATCH] Fixed that TanProcedures didn't get saved and restored --- .../BankingiOSApp.xcdatamodel/contents | 15 +++- .../BankingiOSApp/persistence/Mapper.swift | 68 +++++++++++++++++++ 2 files changed, 80 insertions(+), 3 deletions(-) diff --git a/ui/BankingiOSApp/BankingiOSApp/BankingiOSApp.xcdatamodeld/BankingiOSApp.xcdatamodel/contents b/ui/BankingiOSApp/BankingiOSApp/BankingiOSApp.xcdatamodeld/BankingiOSApp.xcdatamodel/contents index b854aba3..ea23a254 100644 --- a/ui/BankingiOSApp/BankingiOSApp/BankingiOSApp.xcdatamodeld/BankingiOSApp.xcdatamodel/contents +++ b/ui/BankingiOSApp/BankingiOSApp/BankingiOSApp.xcdatamodeld/BankingiOSApp.xcdatamodel/contents @@ -64,12 +64,21 @@ + - + + + + + + + + - - + + + \ No newline at end of file diff --git a/ui/BankingiOSApp/BankingiOSApp/persistence/Mapper.swift b/ui/BankingiOSApp/BankingiOSApp/persistence/Mapper.swift index 63c265cc..4815273a 100644 --- a/ui/BankingiOSApp/BankingiOSApp/persistence/Mapper.swift +++ b/ui/BankingiOSApp/BankingiOSApp/persistence/Mapper.swift @@ -12,6 +12,8 @@ class Mapper { private var mappedTransactions = [AccountTransaction:PersistedAccountTransaction]() + private var mappedTanProcedures = [TanProcedure:PersistedTanProcedure]() + func map(_ customer: PersistedCustomer) -> Customer { let mapped = Customer(bankCode: map(customer.bankCode), customerId: map(customer.customerId), password: map(customer.password), finTsServerAddress: map(customer.finTsServerAddress), bankName: map(customer.bankName), bic: map(customer.bic), customerName: map(customer.customerName), userId: map(customer.userId), iconUrl: customer.iconUrl, accounts: []) @@ -20,6 +22,9 @@ class Mapper { mappedBanks[mapped] = customer + mapped.supportedTanProcedures = map(customer.supportedTanProcedures?.array as? [PersistedTanProcedure]) + mapped.selectedTanProcedure = mapped.supportedTanProcedures.first(where: { $0.bankInternalProcedureCode == customer.selectedTanProcedureCode }) + return mapped } @@ -40,6 +45,9 @@ class Mapper { mappedBanks[customer] = mapped + mapped.supportedTanProcedures = NSOrderedSet(array: map(customer.supportedTanProcedures, context)) + mapped.selectedTanProcedureCode = customer.selectedTanProcedure?.bankInternalProcedureCode + return mapped } @@ -188,6 +196,66 @@ class Mapper { } + func map(_ tanProcedures: [PersistedTanProcedure]?) -> [TanProcedure] { + return tanProcedures?.map { map($0) } ?? [] + } + + func map(_ tanProcedure: PersistedTanProcedure) -> TanProcedure { + let mapped = TanProcedure( + displayName: map(tanProcedure.displayName), + type: mapTanProcedureType(tanProcedure.type), + bankInternalProcedureCode: map(tanProcedure.bankInternalProcedureCode) + ) + + mappedTanProcedures[mapped] = tanProcedure + + return mapped + } + + func map(_ tanProcedures: [TanProcedure], _ context: NSManagedObjectContext) -> [PersistedTanProcedure] { + return tanProcedures.map { map($0, context) } + } + + func map(_ tanProcedure: TanProcedure, _ context: NSManagedObjectContext) -> PersistedTanProcedure { + let mapped = mappedTanProcedures[tanProcedure] ?? PersistedTanProcedure(context: context) + + mapped.displayName = tanProcedure.displayName + mapped.type = tanProcedure.type.name + mapped.bankInternalProcedureCode = tanProcedure.bankInternalProcedureCode + + mappedTanProcedures[tanProcedure] = mapped + + return mapped + } + + func mapTanProcedureType(_ type: String?) -> TanProcedureType { + switch type { + case TanProcedureType.entertan.name: + return TanProcedureType.entertan + case TanProcedureType.chiptanmanuell.name: + return TanProcedureType.chiptanmanuell + case TanProcedureType.chiptanflickercode.name: + return TanProcedureType.chiptanflickercode + case TanProcedureType.chiptanusb.name: + return TanProcedureType.chiptanusb + case TanProcedureType.chiptanqrcode.name: + return TanProcedureType.chiptanqrcode + case TanProcedureType.chiptanphototanmatrixcode.name: + return TanProcedureType.chiptanphototanmatrixcode + case TanProcedureType.smstan.name: + return TanProcedureType.smstan + case TanProcedureType.apptan.name: + return TanProcedureType.apptan + case TanProcedureType.phototan.name: + return TanProcedureType.phototan + case TanProcedureType.qrcode.name: + return TanProcedureType.qrcode + default: + return TanProcedureType.entertan + } + } + + func map(_ date: Date?) -> CommonDate { if let date = date { return CommonDate(date: date)