From 46c9f95a1b39c5fcb121605453911a605760c2b7 Mon Sep 17 00:00:00 2001 From: Andrew Edwards Date: Sun, 1 Sep 2024 12:56:52 -0400 Subject: [PATCH] WIP (#269) --- .../External Accounts/ExternalAccounts.swift | 38 +++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/Sources/StripeKit/Connect/External Accounts/ExternalAccounts.swift b/Sources/StripeKit/Connect/External Accounts/ExternalAccounts.swift index a48bfd5b..e1918eb1 100644 --- a/Sources/StripeKit/Connect/External Accounts/ExternalAccounts.swift +++ b/Sources/StripeKit/Connect/External Accounts/ExternalAccounts.swift @@ -35,6 +35,24 @@ public struct ConnectAccountExternalAccountsList: Codable { bankAccounts = try container.decodeIfPresent([BankAccount].self, forKey: .data)?.filter{ $0.object == "bank_account" } } + public func encode(to encoder: any Encoder) throws { + var container = encoder.container(keyedBy: CodingKeys.self) + try container.encode(object, forKey: .object) + try container.encodeIfPresent(hasMore, forKey: .hasMore) + try container.encodeIfPresent(url, forKey: .url) + + // Merge cardAccounts and bankAccounts into a single array + var accounts: [AnyEncodable] = [] + if let cardAccounts = cardAccounts { + accounts.append(contentsOf: cardAccounts.map { AnyEncodable($0) }) + } + if let bankAccounts = bankAccounts { + accounts.append(contentsOf: bankAccounts.map { AnyEncodable($0) }) + } + + try container.encode(accounts, forKey: .data) + } + public init(object: String, data: String? = nil, hasMore: Bool? = nil, @@ -48,4 +66,24 @@ public struct ConnectAccountExternalAccountsList: Codable { self.cardAccounts = cardAccounts self.bankAccounts = bankAccounts } + + enum CodingKeys: CodingKey { + case object + case data + case hasMore + case url + } + + // A helper type to encode heterogeneous elements + struct AnyEncodable: Encodable { + private let _encode: (Encoder) throws -> Void + + init(_ encodable: T) { + _encode = encodable.encode + } + + func encode(to encoder: Encoder) throws { + try _encode(encoder) + } + } }