{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE OverloadedStrings #-} -- CHANGE WITH CAUTION: This is a generated code file generated by https://github.com/Haskell-OpenAPI-Code-Generator/Haskell-OpenAPI-Client-Code-Generator. -- | Contains the types generated from the schema PaymentMethodSepaDebit module StripeAPI.Types.PaymentMethodSepaDebit where import qualified Data.Aeson import qualified Data.Aeson as Data.Aeson.Types import qualified Data.Aeson as Data.Aeson.Types.FromJSON import qualified Data.Aeson as Data.Aeson.Types.ToJSON import qualified Data.Aeson as Data.Aeson.Types.Internal import qualified Data.ByteString.Char8 import qualified Data.ByteString.Char8 as Data.ByteString.Internal import qualified Data.Functor import qualified Data.Scientific import qualified Data.Text import qualified Data.Text.Internal import qualified Data.Time.Calendar as Data.Time.Calendar.Days import qualified Data.Time.LocalTime as Data.Time.LocalTime.Internal.ZonedTime import qualified GHC.Base import qualified GHC.Classes import qualified GHC.Generics import qualified GHC.Int import qualified GHC.Show import qualified GHC.Types import qualified StripeAPI.Common import qualified Prelude as GHC.Integer.Type import qualified Prelude as GHC.Maybe -- | Defines the data type for the schema payment_method_sepa_debit data PaymentMethodSepaDebit = PaymentMethodSepaDebit { -- | bank_code: Bank code of bank associated with the bank account. -- -- Constraints: -- -- * Maximum length of 5000 paymentMethodSepaDebitBankCode :: (GHC.Maybe.Maybe Data.Text.Internal.Text), -- | branch_code: Branch code of bank associated with the bank account. -- -- Constraints: -- -- * Maximum length of 5000 paymentMethodSepaDebitBranchCode :: (GHC.Maybe.Maybe Data.Text.Internal.Text), -- | country: Two-letter ISO code representing the country the bank account is located in. -- -- Constraints: -- -- * Maximum length of 5000 paymentMethodSepaDebitCountry :: (GHC.Maybe.Maybe Data.Text.Internal.Text), -- | fingerprint: Uniquely identifies this particular bank account. You can use this attribute to check whether two bank accounts are the same. -- -- Constraints: -- -- * Maximum length of 5000 paymentMethodSepaDebitFingerprint :: (GHC.Maybe.Maybe Data.Text.Internal.Text), -- | last4: Last four characters of the IBAN. -- -- Constraints: -- -- * Maximum length of 5000 paymentMethodSepaDebitLast4 :: (GHC.Maybe.Maybe Data.Text.Internal.Text) } deriving ( GHC.Show.Show, GHC.Classes.Eq ) instance Data.Aeson.ToJSON PaymentMethodSepaDebit where toJSON obj = Data.Aeson.object ((Data.Aeson..=) "bank_code" (paymentMethodSepaDebitBankCode obj) : (Data.Aeson..=) "branch_code" (paymentMethodSepaDebitBranchCode obj) : (Data.Aeson..=) "country" (paymentMethodSepaDebitCountry obj) : (Data.Aeson..=) "fingerprint" (paymentMethodSepaDebitFingerprint obj) : (Data.Aeson..=) "last4" (paymentMethodSepaDebitLast4 obj) : []) toEncoding obj = Data.Aeson.pairs ((Data.Aeson..=) "bank_code" (paymentMethodSepaDebitBankCode obj) GHC.Base.<> ((Data.Aeson..=) "branch_code" (paymentMethodSepaDebitBranchCode obj) GHC.Base.<> ((Data.Aeson..=) "country" (paymentMethodSepaDebitCountry obj) GHC.Base.<> ((Data.Aeson..=) "fingerprint" (paymentMethodSepaDebitFingerprint obj) GHC.Base.<> (Data.Aeson..=) "last4" (paymentMethodSepaDebitLast4 obj))))) instance Data.Aeson.Types.FromJSON.FromJSON PaymentMethodSepaDebit where parseJSON = Data.Aeson.Types.FromJSON.withObject "PaymentMethodSepaDebit" (\obj -> ((((GHC.Base.pure PaymentMethodSepaDebit GHC.Base.<*> (obj Data.Aeson.Types.FromJSON..:? "bank_code")) GHC.Base.<*> (obj Data.Aeson.Types.FromJSON..:? "branch_code")) GHC.Base.<*> (obj Data.Aeson.Types.FromJSON..:? "country")) GHC.Base.<*> (obj Data.Aeson.Types.FromJSON..:? "fingerprint")) GHC.Base.<*> (obj Data.Aeson.Types.FromJSON..:? "last4"))