{-# LANGUAGE ExplicitForAll #-}
{-# LANGUAGE MultiWayIf #-}
{-# LANGUAGE OverloadedStrings #-}
module StripeAPI.Operations.PostAccountExternalAccounts where
import qualified Control.Monad.Fail
import qualified Control.Monad.Trans.Reader
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.Either
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 Data.Vector
import qualified GHC.Base
import qualified GHC.Classes
import qualified GHC.Int
import qualified GHC.Show
import qualified GHC.Types
import qualified Network.HTTP.Client
import qualified Network.HTTP.Client as Network.HTTP.Client.Request
import qualified Network.HTTP.Client as Network.HTTP.Client.Types
import qualified Network.HTTP.Simple
import qualified Network.HTTP.Types
import qualified Network.HTTP.Types as Network.HTTP.Types.Status
import qualified Network.HTTP.Types as Network.HTTP.Types.URI
import qualified StripeAPI.Common
import StripeAPI.Types
import qualified Prelude as GHC.Integer.Type
import qualified Prelude as GHC.Maybe
postAccountExternalAccounts ::
forall m.
StripeAPI.Common.MonadHTTP m =>
GHC.Maybe.Maybe PostAccountExternalAccountsRequestBody ->
StripeAPI.Common.ClientT m (Network.HTTP.Client.Types.Response PostAccountExternalAccountsResponse)
postAccountExternalAccounts :: Maybe PostAccountExternalAccountsRequestBody
-> ClientT m (Response PostAccountExternalAccountsResponse)
postAccountExternalAccounts Maybe PostAccountExternalAccountsRequestBody
body =
(Response ByteString
-> Response PostAccountExternalAccountsResponse)
-> ClientT m (Response ByteString)
-> ClientT m (Response PostAccountExternalAccountsResponse)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
GHC.Base.fmap
( \Response ByteString
response_0 ->
(ByteString -> PostAccountExternalAccountsResponse)
-> Response ByteString
-> Response PostAccountExternalAccountsResponse
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
GHC.Base.fmap
( (String -> PostAccountExternalAccountsResponse)
-> (PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse)
-> Either String PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse
forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
Data.Either.either String -> PostAccountExternalAccountsResponse
PostAccountExternalAccountsResponseError PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse
forall a. a -> a
GHC.Base.id
(Either String PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse)
-> (ByteString
-> Either String PostAccountExternalAccountsResponse)
-> ByteString
-> PostAccountExternalAccountsResponse
forall b c a. (b -> c) -> (a -> b) -> a -> c
GHC.Base.. ( \Response ByteString
response ByteString
body ->
if
| (\Status
status_1 -> Status -> Int
Network.HTTP.Types.Status.statusCode Status
status_1 Int -> Int -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Int
200) (Response ByteString -> Status
forall body. Response body -> Status
Network.HTTP.Client.Types.responseStatus Response ByteString
response) ->
ExternalAccount -> PostAccountExternalAccountsResponse
PostAccountExternalAccountsResponse200
(ExternalAccount -> PostAccountExternalAccountsResponse)
-> Either String ExternalAccount
-> Either String PostAccountExternalAccountsResponse
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Data.Functor.<$> ( ByteString -> Either String ExternalAccount
forall a. FromJSON a => ByteString -> Either String a
Data.Aeson.eitherDecodeStrict ByteString
body ::
Data.Either.Either
GHC.Base.String
ExternalAccount
)
| Bool -> Status -> Bool
forall a b. a -> b -> a
GHC.Base.const Bool
GHC.Types.True (Response ByteString -> Status
forall body. Response body -> Status
Network.HTTP.Client.Types.responseStatus Response ByteString
response) ->
Error -> PostAccountExternalAccountsResponse
PostAccountExternalAccountsResponseDefault
(Error -> PostAccountExternalAccountsResponse)
-> Either String Error
-> Either String PostAccountExternalAccountsResponse
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Data.Functor.<$> ( ByteString -> Either String Error
forall a. FromJSON a => ByteString -> Either String a
Data.Aeson.eitherDecodeStrict ByteString
body ::
Data.Either.Either
GHC.Base.String
Error
)
| Bool
GHC.Base.otherwise -> String -> Either String PostAccountExternalAccountsResponse
forall a b. a -> Either a b
Data.Either.Left String
"Missing default response type"
)
Response ByteString
response_0
)
Response ByteString
response_0
)
(Text
-> Text
-> [QueryParameter]
-> Maybe PostAccountExternalAccountsRequestBody
-> RequestBodyEncoding
-> ClientT m (Response ByteString)
forall (m :: * -> *) body.
(MonadHTTP m, ToJSON body) =>
Text
-> Text
-> [QueryParameter]
-> Maybe body
-> RequestBodyEncoding
-> ClientT m (Response ByteString)
StripeAPI.Common.doBodyCallWithConfigurationM (Text -> Text
Data.Text.toUpper (Text -> Text) -> Text -> Text
forall a b. (a -> b) -> a -> b
GHC.Base.$ String -> Text
Data.Text.pack String
"POST") (String -> Text
Data.Text.pack String
"/v1/account/external_accounts") [QueryParameter]
forall a. Monoid a => a
GHC.Base.mempty Maybe PostAccountExternalAccountsRequestBody
body RequestBodyEncoding
StripeAPI.Common.RequestBodyEncodingFormData)
data PostAccountExternalAccountsRequestBody = PostAccountExternalAccountsRequestBody
{
PostAccountExternalAccountsRequestBody
-> Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
postAccountExternalAccountsRequestBodyBankAccount :: (GHC.Maybe.Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants),
PostAccountExternalAccountsRequestBody -> Maybe Bool
postAccountExternalAccountsRequestBodyDefaultForCurrency :: (GHC.Maybe.Maybe GHC.Types.Bool),
PostAccountExternalAccountsRequestBody -> Maybe [Text]
postAccountExternalAccountsRequestBodyExpand :: (GHC.Maybe.Maybe ([Data.Text.Internal.Text])),
PostAccountExternalAccountsRequestBody -> Maybe Text
postAccountExternalAccountsRequestBodyExternalAccount :: (GHC.Maybe.Maybe Data.Text.Internal.Text),
PostAccountExternalAccountsRequestBody -> Maybe Object
postAccountExternalAccountsRequestBodyMetadata :: (GHC.Maybe.Maybe Data.Aeson.Types.Internal.Object)
}
deriving
( Int -> PostAccountExternalAccountsRequestBody -> ShowS
[PostAccountExternalAccountsRequestBody] -> ShowS
PostAccountExternalAccountsRequestBody -> String
(Int -> PostAccountExternalAccountsRequestBody -> ShowS)
-> (PostAccountExternalAccountsRequestBody -> String)
-> ([PostAccountExternalAccountsRequestBody] -> ShowS)
-> Show PostAccountExternalAccountsRequestBody
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PostAccountExternalAccountsRequestBody] -> ShowS
$cshowList :: [PostAccountExternalAccountsRequestBody] -> ShowS
show :: PostAccountExternalAccountsRequestBody -> String
$cshow :: PostAccountExternalAccountsRequestBody -> String
showsPrec :: Int -> PostAccountExternalAccountsRequestBody -> ShowS
$cshowsPrec :: Int -> PostAccountExternalAccountsRequestBody -> ShowS
GHC.Show.Show,
PostAccountExternalAccountsRequestBody
-> PostAccountExternalAccountsRequestBody -> Bool
(PostAccountExternalAccountsRequestBody
-> PostAccountExternalAccountsRequestBody -> Bool)
-> (PostAccountExternalAccountsRequestBody
-> PostAccountExternalAccountsRequestBody -> Bool)
-> Eq PostAccountExternalAccountsRequestBody
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PostAccountExternalAccountsRequestBody
-> PostAccountExternalAccountsRequestBody -> Bool
$c/= :: PostAccountExternalAccountsRequestBody
-> PostAccountExternalAccountsRequestBody -> Bool
== :: PostAccountExternalAccountsRequestBody
-> PostAccountExternalAccountsRequestBody -> Bool
$c== :: PostAccountExternalAccountsRequestBody
-> PostAccountExternalAccountsRequestBody -> Bool
GHC.Classes.Eq
)
instance Data.Aeson.Types.ToJSON.ToJSON PostAccountExternalAccountsRequestBody where
toJSON :: PostAccountExternalAccountsRequestBody -> Value
toJSON PostAccountExternalAccountsRequestBody
obj = [Pair] -> Value
Data.Aeson.Types.Internal.object (Text
"bank_account" Text
-> Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBody
-> Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
postAccountExternalAccountsRequestBodyBankAccount PostAccountExternalAccountsRequestBody
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"default_for_currency" Text -> Maybe Bool -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBody -> Maybe Bool
postAccountExternalAccountsRequestBodyDefaultForCurrency PostAccountExternalAccountsRequestBody
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"expand" Text -> Maybe [Text] -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBody -> Maybe [Text]
postAccountExternalAccountsRequestBodyExpand PostAccountExternalAccountsRequestBody
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"external_account" Text -> Maybe Text -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBody -> Maybe Text
postAccountExternalAccountsRequestBodyExternalAccount PostAccountExternalAccountsRequestBody
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"metadata" Text -> Maybe Object -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBody -> Maybe Object
postAccountExternalAccountsRequestBodyMetadata PostAccountExternalAccountsRequestBody
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: [Pair]
forall a. Monoid a => a
GHC.Base.mempty)
toEncoding :: PostAccountExternalAccountsRequestBody -> Encoding
toEncoding PostAccountExternalAccountsRequestBody
obj = Series -> Encoding
Data.Aeson.Encoding.Internal.pairs ((Text
"bank_account" Text
-> Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBody
-> Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
postAccountExternalAccountsRequestBodyBankAccount PostAccountExternalAccountsRequestBody
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"default_for_currency" Text -> Maybe Bool -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBody -> Maybe Bool
postAccountExternalAccountsRequestBodyDefaultForCurrency PostAccountExternalAccountsRequestBody
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"expand" Text -> Maybe [Text] -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBody -> Maybe [Text]
postAccountExternalAccountsRequestBodyExpand PostAccountExternalAccountsRequestBody
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"external_account" Text -> Maybe Text -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBody -> Maybe Text
postAccountExternalAccountsRequestBodyExternalAccount PostAccountExternalAccountsRequestBody
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> (Text
"metadata" Text -> Maybe Object -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBody -> Maybe Object
postAccountExternalAccountsRequestBodyMetadata PostAccountExternalAccountsRequestBody
obj)))))
instance Data.Aeson.Types.FromJSON.FromJSON PostAccountExternalAccountsRequestBody where
parseJSON :: Value -> Parser PostAccountExternalAccountsRequestBody
parseJSON = String
-> (Object -> Parser PostAccountExternalAccountsRequestBody)
-> Value
-> Parser PostAccountExternalAccountsRequestBody
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.Aeson.Types.FromJSON.withObject String
"PostAccountExternalAccountsRequestBody" (\Object
obj -> (((((Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Maybe Bool
-> Maybe [Text]
-> Maybe Text
-> Maybe Object
-> PostAccountExternalAccountsRequestBody)
-> Parser
(Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Maybe Bool
-> Maybe [Text]
-> Maybe Text
-> Maybe Object
-> PostAccountExternalAccountsRequestBody)
forall (f :: * -> *) a. Applicative f => a -> f a
GHC.Base.pure Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Maybe Bool
-> Maybe [Text]
-> Maybe Text
-> Maybe Object
-> PostAccountExternalAccountsRequestBody
PostAccountExternalAccountsRequestBody Parser
(Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Maybe Bool
-> Maybe [Text]
-> Maybe Text
-> Maybe Object
-> PostAccountExternalAccountsRequestBody)
-> Parser
(Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants)
-> Parser
(Maybe Bool
-> Maybe [Text]
-> Maybe Text
-> Maybe Object
-> PostAccountExternalAccountsRequestBody)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object
-> Text
-> Parser
(Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"bank_account")) Parser
(Maybe Bool
-> Maybe [Text]
-> Maybe Text
-> Maybe Object
-> PostAccountExternalAccountsRequestBody)
-> Parser (Maybe Bool)
-> Parser
(Maybe [Text]
-> Maybe Text
-> Maybe Object
-> PostAccountExternalAccountsRequestBody)
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
"default_for_currency")) Parser
(Maybe [Text]
-> Maybe Text
-> Maybe Object
-> PostAccountExternalAccountsRequestBody)
-> Parser (Maybe [Text])
-> Parser
(Maybe Text
-> Maybe Object -> PostAccountExternalAccountsRequestBody)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object -> Text -> Parser (Maybe [Text])
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"expand")) Parser
(Maybe Text
-> Maybe Object -> PostAccountExternalAccountsRequestBody)
-> Parser (Maybe Text)
-> Parser (Maybe Object -> PostAccountExternalAccountsRequestBody)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object -> Text -> Parser (Maybe Text)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"external_account")) Parser (Maybe Object -> PostAccountExternalAccountsRequestBody)
-> Parser (Maybe Object)
-> Parser PostAccountExternalAccountsRequestBody
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object -> Text -> Parser (Maybe Object)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"metadata"))
mkPostAccountExternalAccountsRequestBody :: PostAccountExternalAccountsRequestBody
mkPostAccountExternalAccountsRequestBody :: PostAccountExternalAccountsRequestBody
mkPostAccountExternalAccountsRequestBody =
PostAccountExternalAccountsRequestBody :: Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Maybe Bool
-> Maybe [Text]
-> Maybe Text
-> Maybe Object
-> PostAccountExternalAccountsRequestBody
PostAccountExternalAccountsRequestBody
{ postAccountExternalAccountsRequestBodyBankAccount :: Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
postAccountExternalAccountsRequestBodyBankAccount = Maybe PostAccountExternalAccountsRequestBodyBankAccount'Variants
forall a. Maybe a
GHC.Maybe.Nothing,
postAccountExternalAccountsRequestBodyDefaultForCurrency :: Maybe Bool
postAccountExternalAccountsRequestBodyDefaultForCurrency = Maybe Bool
forall a. Maybe a
GHC.Maybe.Nothing,
postAccountExternalAccountsRequestBodyExpand :: Maybe [Text]
postAccountExternalAccountsRequestBodyExpand = Maybe [Text]
forall a. Maybe a
GHC.Maybe.Nothing,
postAccountExternalAccountsRequestBodyExternalAccount :: Maybe Text
postAccountExternalAccountsRequestBodyExternalAccount = Maybe Text
forall a. Maybe a
GHC.Maybe.Nothing,
postAccountExternalAccountsRequestBodyMetadata :: Maybe Object
postAccountExternalAccountsRequestBodyMetadata = Maybe Object
forall a. Maybe a
GHC.Maybe.Nothing
}
data PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 = PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
{
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderName :: (GHC.Maybe.Maybe Data.Text.Internal.Text),
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType :: (GHC.Maybe.Maybe PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'),
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountNumber :: Data.Text.Internal.Text,
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Country :: Data.Text.Internal.Text,
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Currency :: (GHC.Maybe.Maybe Data.Text.Internal.Text),
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Object :: (GHC.Maybe.Maybe PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'),
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1RoutingNumber :: (GHC.Maybe.Maybe Data.Text.Internal.Text)
}
deriving
( Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> ShowS
[PostAccountExternalAccountsRequestBodyBankAccount'OneOf1] -> ShowS
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> String
(Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> ShowS)
-> (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> String)
-> ([PostAccountExternalAccountsRequestBodyBankAccount'OneOf1]
-> ShowS)
-> Show PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PostAccountExternalAccountsRequestBodyBankAccount'OneOf1] -> ShowS
$cshowList :: [PostAccountExternalAccountsRequestBodyBankAccount'OneOf1] -> ShowS
show :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> String
$cshow :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> String
showsPrec :: Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> ShowS
$cshowsPrec :: Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> ShowS
GHC.Show.Show,
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Bool
(PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Bool)
-> (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Bool)
-> Eq PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Bool
$c/= :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Bool
== :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Bool
$c== :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Bool
GHC.Classes.Eq
)
instance Data.Aeson.Types.ToJSON.ToJSON PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 where
toJSON :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Value
toJSON PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj = [Pair] -> Value
Data.Aeson.Types.Internal.object (Text
"account_holder_name" Text -> Maybe Text -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderName PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"account_holder_type" Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"account_number" Text -> Text -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountNumber PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"country" Text -> Text -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Country PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"currency" Text -> Maybe Text -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Currency PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"object" Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Object PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: Text
"routing_number" Text -> Maybe Text -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1RoutingNumber PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj Pair -> [Pair] -> [Pair]
forall a. a -> [a] -> [a]
: [Pair]
forall a. Monoid a => a
GHC.Base.mempty)
toEncoding :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Encoding
toEncoding PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj = Series -> Encoding
Data.Aeson.Encoding.Internal.pairs ((Text
"account_holder_name" Text -> Maybe Text -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderName PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"account_holder_type" Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"account_number" Text -> Text -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountNumber PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"country" Text -> Text -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Country PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"currency" Text -> Maybe Text -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Currency PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> ((Text
"object" Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Object PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj) Series -> Series -> Series
forall a. Semigroup a => a -> a -> a
GHC.Base.<> (Text
"routing_number" Text -> Maybe Text -> Series
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Data.Aeson.Types.ToJSON..= PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1RoutingNumber PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
obj)))))))
instance Data.Aeson.Types.FromJSON.FromJSON PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 where
parseJSON :: Value
-> Parser PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
parseJSON = String
-> (Object
-> Parser PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
-> Value
-> Parser PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.Aeson.Types.FromJSON.withObject String
"PostAccountExternalAccountsRequestBodyBankAccount'OneOf1" (\Object
obj -> (((((((Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Text
-> Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
-> Parser
(Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Text
-> Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
forall (f :: * -> *) a. Applicative f => a -> f a
GHC.Base.pure Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Text
-> Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 Parser
(Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Text
-> Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
-> Parser (Maybe Text)
-> Parser
(Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Text
-> Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object -> Text -> Parser (Maybe Text)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"account_holder_name")) Parser
(Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Text
-> Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
-> Parser
(Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType')
-> Parser
(Text
-> Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object
-> Text
-> Parser
(Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType')
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"account_holder_type")) Parser
(Text
-> Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
-> Parser Text
-> Parser
(Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object -> Text -> Parser Text
forall a. FromJSON a => Object -> Text -> Parser a
Data.Aeson.Types.FromJSON..: Text
"account_number")) Parser
(Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
-> Parser Text
-> Parser
(Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object -> Text -> Parser Text
forall a. FromJSON a => Object -> Text -> Parser a
Data.Aeson.Types.FromJSON..: Text
"country")) Parser
(Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
-> Parser (Maybe Text)
-> Parser
(Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object -> Text -> Parser (Maybe Text)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"currency")) Parser
(Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
-> Parser
(Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object')
-> Parser
(Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object
-> Text
-> Parser
(Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object')
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"object")) Parser
(Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1)
-> Parser (Maybe Text)
-> Parser PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
GHC.Base.<*> (Object
obj Object -> Text -> Parser (Maybe Text)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Data.Aeson.Types.FromJSON..:? Text
"routing_number"))
mkPostAccountExternalAccountsRequestBodyBankAccount'OneOf1 ::
Data.Text.Internal.Text ->
Data.Text.Internal.Text ->
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
mkPostAccountExternalAccountsRequestBodyBankAccount'OneOf1 :: Text
-> Text -> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
mkPostAccountExternalAccountsRequestBodyBankAccount'OneOf1 Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountNumber Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Country =
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 :: Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Text
-> Text
-> Maybe Text
-> Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Maybe Text
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
{ postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderName :: Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderName = Maybe Text
forall a. Maybe a
GHC.Maybe.Nothing,
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType :: Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType = Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
forall a. Maybe a
GHC.Maybe.Nothing,
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountNumber :: Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountNumber = Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountNumber,
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Country :: Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Country = Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Country,
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Currency :: Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Currency = Maybe Text
forall a. Maybe a
GHC.Maybe.Nothing,
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Object :: Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
postAccountExternalAccountsRequestBodyBankAccount'OneOf1Object = Maybe
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
forall a. Maybe a
GHC.Maybe.Nothing,
postAccountExternalAccountsRequestBodyBankAccount'OneOf1RoutingNumber :: Maybe Text
postAccountExternalAccountsRequestBodyBankAccount'OneOf1RoutingNumber = Maybe Text
forall a. Maybe a
GHC.Maybe.Nothing
}
data PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
=
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'Other Data.Aeson.Types.Internal.Value
|
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'Typed Data.Text.Internal.Text
|
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'EnumCompany
|
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'EnumIndividual
deriving (Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> ShowS
[PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType']
-> ShowS
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> String
(Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> ShowS)
-> (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> String)
-> ([PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType']
-> ShowS)
-> Show
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType']
-> ShowS
$cshowList :: [PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType']
-> ShowS
show :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> String
$cshow :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> String
showsPrec :: Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> ShowS
$cshowsPrec :: Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> ShowS
GHC.Show.Show, PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Bool
(PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Bool)
-> (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Bool)
-> Eq
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Bool
$c/= :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Bool
== :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Bool
$c== :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Bool
GHC.Classes.Eq)
instance Data.Aeson.Types.ToJSON.ToJSON PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType' where
toJSON :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Value
toJSON (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'Other Value
val) = Value
val
toJSON (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'Typed Text
val) = Text -> Value
forall a. ToJSON a => a -> Value
Data.Aeson.Types.ToJSON.toJSON Text
val
toJSON (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'EnumCompany) = Value
"company"
toJSON (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'EnumIndividual) = Value
"individual"
instance Data.Aeson.Types.FromJSON.FromJSON PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType' where
parseJSON :: Value
-> Parser
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
parseJSON Value
val =
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
-> Parser
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
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
"company" -> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'EnumCompany
| Value
val Value -> Value -> Bool
forall a. Eq a => a -> a -> Bool
GHC.Classes.== Value
"individual" -> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'EnumIndividual
| Bool
GHC.Base.otherwise -> Value
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1AccountHolderType'Other Value
val
)
data PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
=
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'Other Data.Aeson.Types.Internal.Value
|
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'Typed Data.Text.Internal.Text
|
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'EnumBankAccount
deriving (Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> ShowS
[PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object']
-> ShowS
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> String
(Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> ShowS)
-> (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> String)
-> ([PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object']
-> ShowS)
-> Show
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object']
-> ShowS
$cshowList :: [PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object']
-> ShowS
show :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> String
$cshow :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> String
showsPrec :: Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> ShowS
$cshowsPrec :: Int
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> ShowS
GHC.Show.Show, PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Bool
(PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Bool)
-> (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Bool)
-> Eq
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Bool
$c/= :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Bool
== :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Bool
$c== :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Bool
GHC.Classes.Eq)
instance Data.Aeson.Types.ToJSON.ToJSON PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object' where
toJSON :: PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Value
toJSON (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'Other Value
val) = Value
val
toJSON (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'Typed Text
val) = Text -> Value
forall a. ToJSON a => a -> Value
Data.Aeson.Types.ToJSON.toJSON Text
val
toJSON (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'EnumBankAccount) = Value
"bank_account"
instance Data.Aeson.Types.FromJSON.FromJSON PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object' where
parseJSON :: Value
-> Parser
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
parseJSON Value
val =
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
-> Parser
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
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
"bank_account" -> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'EnumBankAccount
| Bool
GHC.Base.otherwise -> Value
-> PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'
PostAccountExternalAccountsRequestBodyBankAccount'OneOf1Object'Other Value
val
)
data PostAccountExternalAccountsRequestBodyBankAccount'Variants
= PostAccountExternalAccountsRequestBodyBankAccount'PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
| PostAccountExternalAccountsRequestBodyBankAccount'Text Data.Text.Internal.Text
deriving (Int
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> ShowS
[PostAccountExternalAccountsRequestBodyBankAccount'Variants]
-> ShowS
PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> String
(Int
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> ShowS)
-> (PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> String)
-> ([PostAccountExternalAccountsRequestBodyBankAccount'Variants]
-> ShowS)
-> Show PostAccountExternalAccountsRequestBodyBankAccount'Variants
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PostAccountExternalAccountsRequestBodyBankAccount'Variants]
-> ShowS
$cshowList :: [PostAccountExternalAccountsRequestBodyBankAccount'Variants]
-> ShowS
show :: PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> String
$cshow :: PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> String
showsPrec :: Int
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> ShowS
$cshowsPrec :: Int
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> ShowS
GHC.Show.Show, PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Bool
(PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Bool)
-> (PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Bool)
-> Eq PostAccountExternalAccountsRequestBodyBankAccount'Variants
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Bool
$c/= :: PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Bool
== :: PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Bool
$c== :: PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Bool
GHC.Classes.Eq)
instance Data.Aeson.Types.ToJSON.ToJSON PostAccountExternalAccountsRequestBodyBankAccount'Variants where
toJSON :: PostAccountExternalAccountsRequestBodyBankAccount'Variants -> Value
toJSON (PostAccountExternalAccountsRequestBodyBankAccount'PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
a) = PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 -> Value
forall a. ToJSON a => a -> Value
Data.Aeson.Types.ToJSON.toJSON PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
a
toJSON (PostAccountExternalAccountsRequestBodyBankAccount'Text Text
a) = Text -> Value
forall a. ToJSON a => a -> Value
Data.Aeson.Types.ToJSON.toJSON Text
a
instance Data.Aeson.Types.FromJSON.FromJSON PostAccountExternalAccountsRequestBodyBankAccount'Variants where
parseJSON :: Value
-> Parser
PostAccountExternalAccountsRequestBodyBankAccount'Variants
parseJSON Value
val = case (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants
PostAccountExternalAccountsRequestBodyBankAccount'PostAccountExternalAccountsRequestBodyBankAccount'OneOf1 (PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants)
-> Result PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
-> Result
PostAccountExternalAccountsRequestBodyBankAccount'Variants
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Data.Functor.<$> Value
-> Result PostAccountExternalAccountsRequestBodyBankAccount'OneOf1
forall a. FromJSON a => Value -> Result a
Data.Aeson.Types.FromJSON.fromJSON Value
val) Result PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Result
PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Result
PostAccountExternalAccountsRequestBodyBankAccount'Variants
forall (f :: * -> *) a. Alternative f => f a -> f a -> f a
GHC.Base.<|> ((Text -> PostAccountExternalAccountsRequestBodyBankAccount'Variants
PostAccountExternalAccountsRequestBodyBankAccount'Text (Text
-> PostAccountExternalAccountsRequestBodyBankAccount'Variants)
-> Result Text
-> Result
PostAccountExternalAccountsRequestBodyBankAccount'Variants
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Data.Functor.<$> Value -> Result Text
forall a. FromJSON a => Value -> Result a
Data.Aeson.Types.FromJSON.fromJSON Value
val) Result PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Result
PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Result
PostAccountExternalAccountsRequestBodyBankAccount'Variants
forall (f :: * -> *) a. Alternative f => f a -> f a -> f a
GHC.Base.<|> String
-> Result
PostAccountExternalAccountsRequestBodyBankAccount'Variants
forall a. String -> Result a
Data.Aeson.Types.Internal.Error String
"No variant matched") of
Data.Aeson.Types.Internal.Success PostAccountExternalAccountsRequestBodyBankAccount'Variants
a -> PostAccountExternalAccountsRequestBodyBankAccount'Variants
-> Parser
PostAccountExternalAccountsRequestBodyBankAccount'Variants
forall (f :: * -> *) a. Applicative f => a -> f a
GHC.Base.pure PostAccountExternalAccountsRequestBodyBankAccount'Variants
a
Data.Aeson.Types.Internal.Error String
a -> String
-> Parser
PostAccountExternalAccountsRequestBodyBankAccount'Variants
forall (m :: * -> *) a. MonadFail m => String -> m a
Control.Monad.Fail.fail String
a
data PostAccountExternalAccountsResponse
=
PostAccountExternalAccountsResponseError GHC.Base.String
|
PostAccountExternalAccountsResponse200 ExternalAccount
|
PostAccountExternalAccountsResponseDefault Error
deriving (Int -> PostAccountExternalAccountsResponse -> ShowS
[PostAccountExternalAccountsResponse] -> ShowS
PostAccountExternalAccountsResponse -> String
(Int -> PostAccountExternalAccountsResponse -> ShowS)
-> (PostAccountExternalAccountsResponse -> String)
-> ([PostAccountExternalAccountsResponse] -> ShowS)
-> Show PostAccountExternalAccountsResponse
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PostAccountExternalAccountsResponse] -> ShowS
$cshowList :: [PostAccountExternalAccountsResponse] -> ShowS
show :: PostAccountExternalAccountsResponse -> String
$cshow :: PostAccountExternalAccountsResponse -> String
showsPrec :: Int -> PostAccountExternalAccountsResponse -> ShowS
$cshowsPrec :: Int -> PostAccountExternalAccountsResponse -> ShowS
GHC.Show.Show, PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse -> Bool
(PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse -> Bool)
-> (PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse -> Bool)
-> Eq PostAccountExternalAccountsResponse
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse -> Bool
$c/= :: PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse -> Bool
== :: PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse -> Bool
$c== :: PostAccountExternalAccountsResponse
-> PostAccountExternalAccountsResponse -> Bool
GHC.Classes.Eq)