{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Amazonka.SESV2.Types.DeliveryOptions where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
import Amazonka.SESV2.Types.TlsPolicy
data DeliveryOptions = DeliveryOptions'
{
DeliveryOptions -> Maybe Text
sendingPoolName :: Prelude.Maybe Prelude.Text,
DeliveryOptions -> Maybe TlsPolicy
tlsPolicy :: Prelude.Maybe TlsPolicy
}
deriving (DeliveryOptions -> DeliveryOptions -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeliveryOptions -> DeliveryOptions -> Bool
$c/= :: DeliveryOptions -> DeliveryOptions -> Bool
== :: DeliveryOptions -> DeliveryOptions -> Bool
$c== :: DeliveryOptions -> DeliveryOptions -> Bool
Prelude.Eq, ReadPrec [DeliveryOptions]
ReadPrec DeliveryOptions
Int -> ReadS DeliveryOptions
ReadS [DeliveryOptions]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeliveryOptions]
$creadListPrec :: ReadPrec [DeliveryOptions]
readPrec :: ReadPrec DeliveryOptions
$creadPrec :: ReadPrec DeliveryOptions
readList :: ReadS [DeliveryOptions]
$creadList :: ReadS [DeliveryOptions]
readsPrec :: Int -> ReadS DeliveryOptions
$creadsPrec :: Int -> ReadS DeliveryOptions
Prelude.Read, Int -> DeliveryOptions -> ShowS
[DeliveryOptions] -> ShowS
DeliveryOptions -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeliveryOptions] -> ShowS
$cshowList :: [DeliveryOptions] -> ShowS
show :: DeliveryOptions -> String
$cshow :: DeliveryOptions -> String
showsPrec :: Int -> DeliveryOptions -> ShowS
$cshowsPrec :: Int -> DeliveryOptions -> ShowS
Prelude.Show, forall x. Rep DeliveryOptions x -> DeliveryOptions
forall x. DeliveryOptions -> Rep DeliveryOptions x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeliveryOptions x -> DeliveryOptions
$cfrom :: forall x. DeliveryOptions -> Rep DeliveryOptions x
Prelude.Generic)
newDeliveryOptions ::
DeliveryOptions
newDeliveryOptions :: DeliveryOptions
newDeliveryOptions =
DeliveryOptions'
{ $sel:sendingPoolName:DeliveryOptions' :: Maybe Text
sendingPoolName = forall a. Maybe a
Prelude.Nothing,
$sel:tlsPolicy:DeliveryOptions' :: Maybe TlsPolicy
tlsPolicy = forall a. Maybe a
Prelude.Nothing
}
deliveryOptions_sendingPoolName :: Lens.Lens' DeliveryOptions (Prelude.Maybe Prelude.Text)
deliveryOptions_sendingPoolName :: Lens' DeliveryOptions (Maybe Text)
deliveryOptions_sendingPoolName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeliveryOptions' {Maybe Text
sendingPoolName :: Maybe Text
$sel:sendingPoolName:DeliveryOptions' :: DeliveryOptions -> Maybe Text
sendingPoolName} -> Maybe Text
sendingPoolName) (\s :: DeliveryOptions
s@DeliveryOptions' {} Maybe Text
a -> DeliveryOptions
s {$sel:sendingPoolName:DeliveryOptions' :: Maybe Text
sendingPoolName = Maybe Text
a} :: DeliveryOptions)
deliveryOptions_tlsPolicy :: Lens.Lens' DeliveryOptions (Prelude.Maybe TlsPolicy)
deliveryOptions_tlsPolicy :: Lens' DeliveryOptions (Maybe TlsPolicy)
deliveryOptions_tlsPolicy = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeliveryOptions' {Maybe TlsPolicy
tlsPolicy :: Maybe TlsPolicy
$sel:tlsPolicy:DeliveryOptions' :: DeliveryOptions -> Maybe TlsPolicy
tlsPolicy} -> Maybe TlsPolicy
tlsPolicy) (\s :: DeliveryOptions
s@DeliveryOptions' {} Maybe TlsPolicy
a -> DeliveryOptions
s {$sel:tlsPolicy:DeliveryOptions' :: Maybe TlsPolicy
tlsPolicy = Maybe TlsPolicy
a} :: DeliveryOptions)
instance Data.FromJSON DeliveryOptions where
parseJSON :: Value -> Parser DeliveryOptions
parseJSON =
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
String
"DeliveryOptions"
( \Object
x ->
Maybe Text -> Maybe TlsPolicy -> DeliveryOptions
DeliveryOptions'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"SendingPoolName")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"TlsPolicy")
)
instance Prelude.Hashable DeliveryOptions where
hashWithSalt :: Int -> DeliveryOptions -> Int
hashWithSalt Int
_salt DeliveryOptions' {Maybe Text
Maybe TlsPolicy
tlsPolicy :: Maybe TlsPolicy
sendingPoolName :: Maybe Text
$sel:tlsPolicy:DeliveryOptions' :: DeliveryOptions -> Maybe TlsPolicy
$sel:sendingPoolName:DeliveryOptions' :: DeliveryOptions -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
sendingPoolName
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe TlsPolicy
tlsPolicy
instance Prelude.NFData DeliveryOptions where
rnf :: DeliveryOptions -> ()
rnf DeliveryOptions' {Maybe Text
Maybe TlsPolicy
tlsPolicy :: Maybe TlsPolicy
sendingPoolName :: Maybe Text
$sel:tlsPolicy:DeliveryOptions' :: DeliveryOptions -> Maybe TlsPolicy
$sel:sendingPoolName:DeliveryOptions' :: DeliveryOptions -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
sendingPoolName
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe TlsPolicy
tlsPolicy
instance Data.ToJSON DeliveryOptions where
toJSON :: DeliveryOptions -> Value
toJSON DeliveryOptions' {Maybe Text
Maybe TlsPolicy
tlsPolicy :: Maybe TlsPolicy
sendingPoolName :: Maybe Text
$sel:tlsPolicy:DeliveryOptions' :: DeliveryOptions -> Maybe TlsPolicy
$sel:sendingPoolName:DeliveryOptions' :: DeliveryOptions -> Maybe Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"SendingPoolName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
sendingPoolName,
(Key
"TlsPolicy" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe TlsPolicy
tlsPolicy
]
)