{-# LANGUAGE MultiWayIf #-}
{-# LANGUAGE OverloadedStrings #-}
module StripeAPI.Types.PaymentIntentPaymentMethodOptionsCard where
import qualified Control.Monad.Fail
import qualified Data.Aeson
import qualified Data.Aeson as Data.Aeson.Encoding.Internal
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.Internal
import qualified Data.Aeson as Data.Aeson.Types.ToJSON
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.Int
import qualified GHC.Show
import qualified GHC.Types
import qualified StripeAPI.Common
import StripeAPI.TypeAlias
import {-# SOURCE #-} StripeAPI.Types.PaymentMethodDetailsCardInstallmentsPlan
import {-# SOURCE #-} StripeAPI.Types.PaymentMethodOptionsCardInstallments
import qualified Prelude as GHC.Integer.Type
import qualified Prelude as GHC.Maybe
data PaymentIntentPaymentMethodOptionsCard = PaymentIntentPaymentMethodOptionsCard
{
PaymentIntentPaymentMethodOptionsCard
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
paymentIntentPaymentMethodOptionsCardInstallments :: (GHC.Maybe.Maybe PaymentIntentPaymentMethodOptionsCardInstallments'),
PaymentIntentPaymentMethodOptionsCard
-> Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
paymentIntentPaymentMethodOptionsCardNetwork :: (GHC.Maybe.Maybe PaymentIntentPaymentMethodOptionsCardNetwork'),
PaymentIntentPaymentMethodOptionsCard
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
paymentIntentPaymentMethodOptionsCardRequestThreeDSecure :: (GHC.Maybe.Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure')
}
deriving
( Int -> PaymentIntentPaymentMethodOptionsCard -> ShowS
[PaymentIntentPaymentMethodOptionsCard] -> ShowS
PaymentIntentPaymentMethodOptionsCard -> String
(Int -> PaymentIntentPaymentMethodOptionsCard -> ShowS)
-> (PaymentIntentPaymentMethodOptionsCard -> String)
-> ([PaymentIntentPaymentMethodOptionsCard] -> ShowS)
-> Show PaymentIntentPaymentMethodOptionsCard
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PaymentIntentPaymentMethodOptionsCard] -> ShowS
$cshowList :: [PaymentIntentPaymentMethodOptionsCard] -> ShowS
show :: PaymentIntentPaymentMethodOptionsCard -> String
$cshow :: PaymentIntentPaymentMethodOptionsCard -> String
showsPrec :: Int -> PaymentIntentPaymentMethodOptionsCard -> ShowS
$cshowsPrec :: Int -> PaymentIntentPaymentMethodOptionsCard -> ShowS
GHC.Show.Show,
PaymentIntentPaymentMethodOptionsCard
-> PaymentIntentPaymentMethodOptionsCard -> Bool
(PaymentIntentPaymentMethodOptionsCard
-> PaymentIntentPaymentMethodOptionsCard -> Bool)
-> (PaymentIntentPaymentMethodOptionsCard
-> PaymentIntentPaymentMethodOptionsCard -> Bool)
-> Eq PaymentIntentPaymentMethodOptionsCard
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PaymentIntentPaymentMethodOptionsCard
-> PaymentIntentPaymentMethodOptionsCard -> Bool
$c/= :: PaymentIntentPaymentMethodOptionsCard
-> PaymentIntentPaymentMethodOptionsCard -> Bool
== :: PaymentIntentPaymentMethodOptionsCard
-> PaymentIntentPaymentMethodOptionsCard -> Bool
$c== :: PaymentIntentPaymentMethodOptionsCard
-> PaymentIntentPaymentMethodOptionsCard -> Bool
GHC.Classes.Eq
)
instance Data.Aeson.Types.ToJSON.ToJSON PaymentIntentPaymentMethodOptionsCard where
toJSON :: PaymentIntentPaymentMethodOptionsCard -> Value
toJSON PaymentIntentPaymentMethodOptionsCard
obj = [Pair] -> Value
Data.Aeson.Types.Internal.object (Text
"installments" Text
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments' -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCard
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
paymentIntentPaymentMethodOptionsCardInstallments PaymentIntentPaymentMethodOptionsCard
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"network" Text -> Maybe PaymentIntentPaymentMethodOptionsCardNetwork' -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCard
-> Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
paymentIntentPaymentMethodOptionsCardNetwork PaymentIntentPaymentMethodOptionsCard
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"request_three_d_secure" Text
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCard
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
paymentIntentPaymentMethodOptionsCardRequestThreeDSecure PaymentIntentPaymentMethodOptionsCard
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: [Pair]
forall a. Monoid a => a
GHC.Base.mempty)
toEncoding :: PaymentIntentPaymentMethodOptionsCard -> Encoding
toEncoding PaymentIntentPaymentMethodOptionsCard
obj = Series -> Encoding
Data.Aeson.Encoding.Internal.pairs ((Text
"installments" Text
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
-> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCard
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
paymentIntentPaymentMethodOptionsCardInstallments PaymentIntentPaymentMethodOptionsCard
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"network" Text
-> Maybe PaymentIntentPaymentMethodOptionsCardNetwork' -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCard
-> Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
paymentIntentPaymentMethodOptionsCardNetwork PaymentIntentPaymentMethodOptionsCard
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> (Text
"request_three_d_secure" Text
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCard
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
paymentIntentPaymentMethodOptionsCardRequestThreeDSecure PaymentIntentPaymentMethodOptionsCard
obj)))
instance Data.Aeson.Types.FromJSON.FromJSON PaymentIntentPaymentMethodOptionsCard where
parseJSON :: Value -> Parser PaymentIntentPaymentMethodOptionsCard
parseJSON = String
-> (Object -> Parser PaymentIntentPaymentMethodOptionsCard)
-> Value
-> Parser PaymentIntentPaymentMethodOptionsCard
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.Aeson.Types.FromJSON.withObject String
"PaymentIntentPaymentMethodOptionsCard" (\Object
obj -> (((Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCard)
-> Parser
(Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCard)
forall (f :: * -> *) a. Applicative f => a -> f a
GHC.Base.pure Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCard
PaymentIntentPaymentMethodOptionsCard Parser
(Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCard)
-> Parser
(Maybe PaymentIntentPaymentMethodOptionsCardInstallments')
-> Parser
(Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCard)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object
-> Text
-> Parser
(Maybe PaymentIntentPaymentMethodOptionsCardInstallments')
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"installments")) Parser
(Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCard)
-> Parser (Maybe PaymentIntentPaymentMethodOptionsCardNetwork')
-> Parser
(Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCard)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object
-> Text
-> Parser (Maybe PaymentIntentPaymentMethodOptionsCardNetwork')
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"network")) Parser
(Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCard)
-> Parser
(Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure')
-> Parser PaymentIntentPaymentMethodOptionsCard
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object
-> Text
-> Parser
(Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure')
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"request_three_d_secure"))
mkPaymentIntentPaymentMethodOptionsCard :: PaymentIntentPaymentMethodOptionsCard
mkPaymentIntentPaymentMethodOptionsCard :: PaymentIntentPaymentMethodOptionsCard
mkPaymentIntentPaymentMethodOptionsCard =
PaymentIntentPaymentMethodOptionsCard :: Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
-> Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCard
PaymentIntentPaymentMethodOptionsCard
{ paymentIntentPaymentMethodOptionsCardInstallments :: Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
paymentIntentPaymentMethodOptionsCardInstallments = Maybe PaymentIntentPaymentMethodOptionsCardInstallments'
forall a. Maybe a
GHC.Maybe.Nothing,
paymentIntentPaymentMethodOptionsCardNetwork :: Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
paymentIntentPaymentMethodOptionsCardNetwork = Maybe PaymentIntentPaymentMethodOptionsCardNetwork'
forall a. Maybe a
GHC.Maybe.Nothing,
paymentIntentPaymentMethodOptionsCardRequestThreeDSecure :: Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
paymentIntentPaymentMethodOptionsCardRequestThreeDSecure = Maybe PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
forall a. Maybe a
GHC.Maybe.Nothing
}
data PaymentIntentPaymentMethodOptionsCardInstallments' = PaymentIntentPaymentMethodOptionsCardInstallments'
{
PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe [PaymentMethodDetailsCardInstallmentsPlan]
paymentIntentPaymentMethodOptionsCardInstallments'AvailablePlans :: (GHC.Maybe.Maybe ([PaymentMethodDetailsCardInstallmentsPlan])),
PaymentIntentPaymentMethodOptionsCardInstallments' -> Maybe Bool
paymentIntentPaymentMethodOptionsCardInstallments'Enabled :: (GHC.Maybe.Maybe GHC.Types.Bool),
PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
paymentIntentPaymentMethodOptionsCardInstallments'Plan :: (GHC.Maybe.Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan')
}
deriving
( Int -> PaymentIntentPaymentMethodOptionsCardInstallments' -> ShowS
[PaymentIntentPaymentMethodOptionsCardInstallments'] -> ShowS
PaymentIntentPaymentMethodOptionsCardInstallments' -> String
(Int
-> PaymentIntentPaymentMethodOptionsCardInstallments' -> ShowS)
-> (PaymentIntentPaymentMethodOptionsCardInstallments' -> String)
-> ([PaymentIntentPaymentMethodOptionsCardInstallments'] -> ShowS)
-> Show PaymentIntentPaymentMethodOptionsCardInstallments'
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PaymentIntentPaymentMethodOptionsCardInstallments'] -> ShowS
$cshowList :: [PaymentIntentPaymentMethodOptionsCardInstallments'] -> ShowS
show :: PaymentIntentPaymentMethodOptionsCardInstallments' -> String
$cshow :: PaymentIntentPaymentMethodOptionsCardInstallments' -> String
showsPrec :: Int -> PaymentIntentPaymentMethodOptionsCardInstallments' -> ShowS
$cshowsPrec :: Int -> PaymentIntentPaymentMethodOptionsCardInstallments' -> ShowS
GHC.Show.Show,
PaymentIntentPaymentMethodOptionsCardInstallments'
-> PaymentIntentPaymentMethodOptionsCardInstallments' -> Bool
(PaymentIntentPaymentMethodOptionsCardInstallments'
-> PaymentIntentPaymentMethodOptionsCardInstallments' -> Bool)
-> (PaymentIntentPaymentMethodOptionsCardInstallments'
-> PaymentIntentPaymentMethodOptionsCardInstallments' -> Bool)
-> Eq PaymentIntentPaymentMethodOptionsCardInstallments'
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PaymentIntentPaymentMethodOptionsCardInstallments'
-> PaymentIntentPaymentMethodOptionsCardInstallments' -> Bool
$c/= :: PaymentIntentPaymentMethodOptionsCardInstallments'
-> PaymentIntentPaymentMethodOptionsCardInstallments' -> Bool
== :: PaymentIntentPaymentMethodOptionsCardInstallments'
-> PaymentIntentPaymentMethodOptionsCardInstallments' -> Bool
$c== :: PaymentIntentPaymentMethodOptionsCardInstallments'
-> PaymentIntentPaymentMethodOptionsCardInstallments' -> Bool
GHC.Classes.Eq
)
instance Data.Aeson.Types.ToJSON.ToJSON PaymentIntentPaymentMethodOptionsCardInstallments' where
toJSON :: PaymentIntentPaymentMethodOptionsCardInstallments' -> Value
toJSON PaymentIntentPaymentMethodOptionsCardInstallments'
obj = [Pair] -> Value
Data.Aeson.Types.Internal.object (Text
"available_plans" Text -> Maybe [PaymentMethodDetailsCardInstallmentsPlan] -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe [PaymentMethodDetailsCardInstallmentsPlan]
paymentIntentPaymentMethodOptionsCardInstallments'AvailablePlans PaymentIntentPaymentMethodOptionsCardInstallments'
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"enabled" Text -> Maybe Bool -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCardInstallments' -> Maybe Bool
paymentIntentPaymentMethodOptionsCardInstallments'Enabled PaymentIntentPaymentMethodOptionsCardInstallments'
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"plan" Text
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
paymentIntentPaymentMethodOptionsCardInstallments'Plan PaymentIntentPaymentMethodOptionsCardInstallments'
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: [Pair]
forall a. Monoid a => a
GHC.Base.mempty)
toEncoding :: PaymentIntentPaymentMethodOptionsCardInstallments' -> Encoding
toEncoding PaymentIntentPaymentMethodOptionsCardInstallments'
obj = Series -> Encoding
Data.Aeson.Encoding.Internal.pairs ((Text
"available_plans" Text -> Maybe [PaymentMethodDetailsCardInstallmentsPlan] -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe [PaymentMethodDetailsCardInstallmentsPlan]
paymentIntentPaymentMethodOptionsCardInstallments'AvailablePlans PaymentIntentPaymentMethodOptionsCardInstallments'
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"enabled" Text -> Maybe Bool -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCardInstallments' -> Maybe Bool
paymentIntentPaymentMethodOptionsCardInstallments'Enabled PaymentIntentPaymentMethodOptionsCardInstallments'
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> (Text
"plan" Text
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCardInstallments'
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
paymentIntentPaymentMethodOptionsCardInstallments'Plan PaymentIntentPaymentMethodOptionsCardInstallments'
obj)))
instance Data.Aeson.Types.FromJSON.FromJSON PaymentIntentPaymentMethodOptionsCardInstallments' where
parseJSON :: Value -> Parser PaymentIntentPaymentMethodOptionsCardInstallments'
parseJSON = String
-> (Object
-> Parser PaymentIntentPaymentMethodOptionsCardInstallments')
-> Value
-> Parser PaymentIntentPaymentMethodOptionsCardInstallments'
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.Aeson.Types.FromJSON.withObject String
"PaymentIntentPaymentMethodOptionsCardInstallments'" (\Object
obj -> (((Maybe [PaymentMethodDetailsCardInstallmentsPlan]
-> Maybe Bool
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments')
-> Parser
(Maybe [PaymentMethodDetailsCardInstallmentsPlan]
-> Maybe Bool
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments')
forall (f :: * -> *) a. Applicative f => a -> f a
GHC.Base.pure Maybe [PaymentMethodDetailsCardInstallmentsPlan]
-> Maybe Bool
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments'
PaymentIntentPaymentMethodOptionsCardInstallments' Parser
(Maybe [PaymentMethodDetailsCardInstallmentsPlan]
-> Maybe Bool
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments')
-> Parser (Maybe [PaymentMethodDetailsCardInstallmentsPlan])
-> Parser
(Maybe Bool
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments')
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object
-> Text
-> Parser (Maybe [PaymentMethodDetailsCardInstallmentsPlan])
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"available_plans")) Parser
(Maybe Bool
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments')
-> Parser (Maybe Bool)
-> Parser
(Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments')
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object -> Text -> Parser (Maybe Bool)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"enabled")) Parser
(Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments')
-> Parser
(Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan')
-> Parser PaymentIntentPaymentMethodOptionsCardInstallments'
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object
-> Text
-> Parser
(Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan')
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"plan"))
mkPaymentIntentPaymentMethodOptionsCardInstallments' :: PaymentIntentPaymentMethodOptionsCardInstallments'
mkPaymentIntentPaymentMethodOptionsCardInstallments' :: PaymentIntentPaymentMethodOptionsCardInstallments'
mkPaymentIntentPaymentMethodOptionsCardInstallments' =
PaymentIntentPaymentMethodOptionsCardInstallments' :: Maybe [PaymentMethodDetailsCardInstallmentsPlan]
-> Maybe Bool
-> Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments'
PaymentIntentPaymentMethodOptionsCardInstallments'
{ paymentIntentPaymentMethodOptionsCardInstallments'AvailablePlans :: Maybe [PaymentMethodDetailsCardInstallmentsPlan]
paymentIntentPaymentMethodOptionsCardInstallments'AvailablePlans = Maybe [PaymentMethodDetailsCardInstallmentsPlan]
forall a. Maybe a
GHC.Maybe.Nothing,
paymentIntentPaymentMethodOptionsCardInstallments'Enabled :: Maybe Bool
paymentIntentPaymentMethodOptionsCardInstallments'Enabled = Maybe Bool
forall a. Maybe a
GHC.Maybe.Nothing,
paymentIntentPaymentMethodOptionsCardInstallments'Plan :: Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
paymentIntentPaymentMethodOptionsCardInstallments'Plan = Maybe PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
forall a. Maybe a
GHC.Maybe.Nothing
}
data PaymentIntentPaymentMethodOptionsCardInstallments'Plan' = PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
{
PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> Maybe Int
paymentIntentPaymentMethodOptionsCardInstallments'Plan'Count :: (GHC.Maybe.Maybe GHC.Types.Int)
}
deriving
( Int
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> ShowS
[PaymentIntentPaymentMethodOptionsCardInstallments'Plan'] -> ShowS
PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> String
(Int
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> ShowS)
-> (PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> String)
-> ([PaymentIntentPaymentMethodOptionsCardInstallments'Plan']
-> ShowS)
-> Show PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PaymentIntentPaymentMethodOptionsCardInstallments'Plan'] -> ShowS
$cshowList :: [PaymentIntentPaymentMethodOptionsCardInstallments'Plan'] -> ShowS
show :: PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> String
$cshow :: PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> String
showsPrec :: Int
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> ShowS
$cshowsPrec :: Int
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> ShowS
GHC.Show.Show,
PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> Bool
(PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> Bool)
-> (PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> Bool)
-> Eq PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> Bool
$c/= :: PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> Bool
== :: PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> Bool
$c== :: PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> Bool
GHC.Classes.Eq
)
instance Data.Aeson.Types.ToJSON.ToJSON PaymentIntentPaymentMethodOptionsCardInstallments'Plan' where
toJSON :: PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> Value
toJSON PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
obj = [Pair] -> Value
Data.Aeson.Types.Internal.object (Text
"count" Text -> Maybe Int -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> Maybe Int
paymentIntentPaymentMethodOptionsCardInstallments'Plan'Count PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"interval" Text -> Value -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= Text -> Value
Data.Aeson.Types.Internal.String Text
"month" Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"type" Text -> Value -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= Text -> Value
Data.Aeson.Types.Internal.String Text
"fixed_count" Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: [Pair]
forall a. Monoid a => a
GHC.Base.mempty)
toEncoding :: PaymentIntentPaymentMethodOptionsCardInstallments'Plan' -> Encoding
toEncoding PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
obj = Series -> Encoding
Data.Aeson.Encoding.Internal.pairs ((Text
"count" Text -> Maybe Int -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
-> Maybe Int
paymentIntentPaymentMethodOptionsCardInstallments'Plan'Count PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"interval" Text -> Value -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= Text -> Value
Data.Aeson.Types.Internal.String Text
"month") Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> (Text
"type" Text -> Value -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= Text -> Value
Data.Aeson.Types.Internal.String Text
"fixed_count")))
instance Data.Aeson.Types.FromJSON.FromJSON PaymentIntentPaymentMethodOptionsCardInstallments'Plan' where
parseJSON :: Value
-> Parser PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
parseJSON = String
-> (Object
-> Parser PaymentIntentPaymentMethodOptionsCardInstallments'Plan')
-> Value
-> Parser PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.Aeson.Types.FromJSON.withObject String
"PaymentIntentPaymentMethodOptionsCardInstallments'Plan'" (\Object
obj -> (Maybe Int
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan')
-> Parser
(Maybe Int
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan')
forall (f :: * -> *) a. Applicative f => a -> f a
GHC.Base.pure Maybe Int
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
PaymentIntentPaymentMethodOptionsCardInstallments'Plan' Parser
(Maybe Int
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan')
-> Parser (Maybe Int)
-> Parser PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object -> Text -> Parser (Maybe Int)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"count"))
mkPaymentIntentPaymentMethodOptionsCardInstallments'Plan' :: PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
mkPaymentIntentPaymentMethodOptionsCardInstallments'Plan' :: PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
mkPaymentIntentPaymentMethodOptionsCardInstallments'Plan' = PaymentIntentPaymentMethodOptionsCardInstallments'Plan' :: Maybe Int
-> PaymentIntentPaymentMethodOptionsCardInstallments'Plan'
PaymentIntentPaymentMethodOptionsCardInstallments'Plan' {paymentIntentPaymentMethodOptionsCardInstallments'Plan'Count :: Maybe Int
paymentIntentPaymentMethodOptionsCardInstallments'Plan'Count = Maybe Int
forall a. Maybe a
GHC.Maybe.Nothing}
data PaymentIntentPaymentMethodOptionsCardNetwork'
=
PaymentIntentPaymentMethodOptionsCardNetwork'Other Data.Aeson.Types.Internal.Value
|
PaymentIntentPaymentMethodOptionsCardNetwork'Typed Data.Text.Internal.Text
|
PaymentIntentPaymentMethodOptionsCardNetwork'EnumAmex
|
PaymentIntentPaymentMethodOptionsCardNetwork'EnumCartesBancaires
|
PaymentIntentPaymentMethodOptionsCardNetwork'EnumDiners
|
PaymentIntentPaymentMethodOptionsCardNetwork'EnumDiscover
|
PaymentIntentPaymentMethodOptionsCardNetwork'EnumInterac
|
PaymentIntentPaymentMethodOptionsCardNetwork'EnumJcb
|
PaymentIntentPaymentMethodOptionsCardNetwork'EnumMastercard
|
PaymentIntentPaymentMethodOptionsCardNetwork'EnumUnionpay
|
PaymentIntentPaymentMethodOptionsCardNetwork'EnumUnknown
|
PaymentIntentPaymentMethodOptionsCardNetwork'EnumVisa
deriving (Int -> PaymentIntentPaymentMethodOptionsCardNetwork' -> ShowS
[PaymentIntentPaymentMethodOptionsCardNetwork'] -> ShowS
PaymentIntentPaymentMethodOptionsCardNetwork' -> String
(Int -> PaymentIntentPaymentMethodOptionsCardNetwork' -> ShowS)
-> (PaymentIntentPaymentMethodOptionsCardNetwork' -> String)
-> ([PaymentIntentPaymentMethodOptionsCardNetwork'] -> ShowS)
-> Show PaymentIntentPaymentMethodOptionsCardNetwork'
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PaymentIntentPaymentMethodOptionsCardNetwork'] -> ShowS
$cshowList :: [PaymentIntentPaymentMethodOptionsCardNetwork'] -> ShowS
show :: PaymentIntentPaymentMethodOptionsCardNetwork' -> String
$cshow :: PaymentIntentPaymentMethodOptionsCardNetwork' -> String
showsPrec :: Int -> PaymentIntentPaymentMethodOptionsCardNetwork' -> ShowS
$cshowsPrec :: Int -> PaymentIntentPaymentMethodOptionsCardNetwork' -> ShowS
GHC.Show.Show, PaymentIntentPaymentMethodOptionsCardNetwork'
-> PaymentIntentPaymentMethodOptionsCardNetwork' -> Bool
(PaymentIntentPaymentMethodOptionsCardNetwork'
-> PaymentIntentPaymentMethodOptionsCardNetwork' -> Bool)
-> (PaymentIntentPaymentMethodOptionsCardNetwork'
-> PaymentIntentPaymentMethodOptionsCardNetwork' -> Bool)
-> Eq PaymentIntentPaymentMethodOptionsCardNetwork'
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PaymentIntentPaymentMethodOptionsCardNetwork'
-> PaymentIntentPaymentMethodOptionsCardNetwork' -> Bool
$c/= :: PaymentIntentPaymentMethodOptionsCardNetwork'
-> PaymentIntentPaymentMethodOptionsCardNetwork' -> Bool
== :: PaymentIntentPaymentMethodOptionsCardNetwork'
-> PaymentIntentPaymentMethodOptionsCardNetwork' -> Bool
$c== :: PaymentIntentPaymentMethodOptionsCardNetwork'
-> PaymentIntentPaymentMethodOptionsCardNetwork' -> Bool
GHC.Classes.Eq)
instance Data.Aeson.Types.ToJSON.ToJSON PaymentIntentPaymentMethodOptionsCardNetwork' where
toJSON :: PaymentIntentPaymentMethodOptionsCardNetwork' -> Value
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'Other Value
val) = Value
val
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'Typed Text
val) = Text -> Value
forall a. ToJSON a => a -> Value
Data.Aeson.Types.ToJSON.toJSON Text
val
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumAmex) = Value
"amex"
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumCartesBancaires) = Value
"cartes_bancaires"
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumDiners) = Value
"diners"
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumDiscover) = Value
"discover"
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumInterac) = Value
"interac"
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumJcb) = Value
"jcb"
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumMastercard) = Value
"mastercard"
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumUnionpay) = Value
"unionpay"
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumUnknown) = Value
"unknown"
toJSON (PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumVisa) = Value
"visa"
instance Data.Aeson.Types.FromJSON.FromJSON PaymentIntentPaymentMethodOptionsCardNetwork' where
parseJSON :: Value -> Parser PaymentIntentPaymentMethodOptionsCardNetwork'
parseJSON Value
val =
PaymentIntentPaymentMethodOptionsCardNetwork'
-> Parser PaymentIntentPaymentMethodOptionsCardNetwork'
forall (f :: * -> *) a. Applicative f => a -> f a
GHC.Base.pure
( if
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"amex" -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumAmex
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"cartes_bancaires" -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumCartesBancaires
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"diners" -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumDiners
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"discover" -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumDiscover
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"interac" -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumInterac
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"jcb" -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumJcb
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"mastercard" -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumMastercard
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"unionpay" -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumUnionpay
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"unknown" -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumUnknown
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"visa" -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'EnumVisa
| Bool
GHC.Base.otherwise -> Value -> PaymentIntentPaymentMethodOptionsCardNetwork'
PaymentIntentPaymentMethodOptionsCardNetwork'Other Value
val
)
data PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
=
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'Other Data.Aeson.Types.Internal.Value
|
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'Typed Data.Text.Internal.Text
|
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'EnumAny
|
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'EnumAutomatic
|
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'EnumChallengeOnly
deriving (Int
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> ShowS
[PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure']
-> ShowS
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure' -> String
(Int
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> ShowS)
-> (PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> String)
-> ([PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure']
-> ShowS)
-> Show PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure']
-> ShowS
$cshowList :: [PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure']
-> ShowS
show :: PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure' -> String
$cshow :: PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure' -> String
showsPrec :: Int
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> ShowS
$cshowsPrec :: Int
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> ShowS
GHC.Show.Show, PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> Bool
(PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> Bool)
-> (PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> Bool)
-> Eq PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> Bool
$c/= :: PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> Bool
== :: PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> Bool
$c== :: PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> Bool
GHC.Classes.Eq)
instance Data.Aeson.Types.ToJSON.ToJSON PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure' where
toJSON :: PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure' -> Value
toJSON (PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'Other Value
val) = Value
val
toJSON (PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'Typed Text
val) = Text -> Value
forall a. ToJSON a => a -> Value
Data.Aeson.Types.ToJSON.toJSON Text
val
toJSON (PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'EnumAny) = Value
"any"
toJSON (PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'EnumAutomatic) = Value
"automatic"
toJSON (PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'EnumChallengeOnly) = Value
"challenge_only"
instance Data.Aeson.Types.FromJSON.FromJSON PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure' where
parseJSON :: Value
-> Parser PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
parseJSON Value
val =
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
-> Parser PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
forall (f :: * -> *) a. Applicative f => a -> f a
GHC.Base.pure
( if
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"any" -> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'EnumAny
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"automatic" -> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'EnumAutomatic
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"challenge_only" -> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'EnumChallengeOnly
| Bool
GHC.Base.otherwise -> Value -> PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'
PaymentIntentPaymentMethodOptionsCardRequestThreeDSecure'Other Value
val
)