{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Amazonka.SES.ListVerifiedEmailAddresses
(
ListVerifiedEmailAddresses (..),
newListVerifiedEmailAddresses,
ListVerifiedEmailAddressesResponse (..),
newListVerifiedEmailAddressesResponse,
listVerifiedEmailAddressesResponse_verifiedEmailAddresses,
listVerifiedEmailAddressesResponse_httpStatus,
)
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 qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
import Amazonka.SES.Types
data ListVerifiedEmailAddresses = ListVerifiedEmailAddresses'
{
}
deriving (ListVerifiedEmailAddresses -> ListVerifiedEmailAddresses -> Bool
(ListVerifiedEmailAddresses -> ListVerifiedEmailAddresses -> Bool)
-> (ListVerifiedEmailAddresses
-> ListVerifiedEmailAddresses -> Bool)
-> Eq ListVerifiedEmailAddresses
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: ListVerifiedEmailAddresses -> ListVerifiedEmailAddresses -> Bool
== :: ListVerifiedEmailAddresses -> ListVerifiedEmailAddresses -> Bool
$c/= :: ListVerifiedEmailAddresses -> ListVerifiedEmailAddresses -> Bool
/= :: ListVerifiedEmailAddresses -> ListVerifiedEmailAddresses -> Bool
Prelude.Eq, ReadPrec [ListVerifiedEmailAddresses]
ReadPrec ListVerifiedEmailAddresses
Int -> ReadS ListVerifiedEmailAddresses
ReadS [ListVerifiedEmailAddresses]
(Int -> ReadS ListVerifiedEmailAddresses)
-> ReadS [ListVerifiedEmailAddresses]
-> ReadPrec ListVerifiedEmailAddresses
-> ReadPrec [ListVerifiedEmailAddresses]
-> Read ListVerifiedEmailAddresses
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
$creadsPrec :: Int -> ReadS ListVerifiedEmailAddresses
readsPrec :: Int -> ReadS ListVerifiedEmailAddresses
$creadList :: ReadS [ListVerifiedEmailAddresses]
readList :: ReadS [ListVerifiedEmailAddresses]
$creadPrec :: ReadPrec ListVerifiedEmailAddresses
readPrec :: ReadPrec ListVerifiedEmailAddresses
$creadListPrec :: ReadPrec [ListVerifiedEmailAddresses]
readListPrec :: ReadPrec [ListVerifiedEmailAddresses]
Prelude.Read, Int -> ListVerifiedEmailAddresses -> ShowS
[ListVerifiedEmailAddresses] -> ShowS
ListVerifiedEmailAddresses -> String
(Int -> ListVerifiedEmailAddresses -> ShowS)
-> (ListVerifiedEmailAddresses -> String)
-> ([ListVerifiedEmailAddresses] -> ShowS)
-> Show ListVerifiedEmailAddresses
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> ListVerifiedEmailAddresses -> ShowS
showsPrec :: Int -> ListVerifiedEmailAddresses -> ShowS
$cshow :: ListVerifiedEmailAddresses -> String
show :: ListVerifiedEmailAddresses -> String
$cshowList :: [ListVerifiedEmailAddresses] -> ShowS
showList :: [ListVerifiedEmailAddresses] -> ShowS
Prelude.Show, (forall x.
ListVerifiedEmailAddresses -> Rep ListVerifiedEmailAddresses x)
-> (forall x.
Rep ListVerifiedEmailAddresses x -> ListVerifiedEmailAddresses)
-> Generic ListVerifiedEmailAddresses
forall x.
Rep ListVerifiedEmailAddresses x -> ListVerifiedEmailAddresses
forall x.
ListVerifiedEmailAddresses -> Rep ListVerifiedEmailAddresses x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x.
ListVerifiedEmailAddresses -> Rep ListVerifiedEmailAddresses x
from :: forall x.
ListVerifiedEmailAddresses -> Rep ListVerifiedEmailAddresses x
$cto :: forall x.
Rep ListVerifiedEmailAddresses x -> ListVerifiedEmailAddresses
to :: forall x.
Rep ListVerifiedEmailAddresses x -> ListVerifiedEmailAddresses
Prelude.Generic)
newListVerifiedEmailAddresses ::
ListVerifiedEmailAddresses
newListVerifiedEmailAddresses :: ListVerifiedEmailAddresses
newListVerifiedEmailAddresses =
ListVerifiedEmailAddresses
ListVerifiedEmailAddresses'
instance Core.AWSRequest ListVerifiedEmailAddresses where
type
AWSResponse ListVerifiedEmailAddresses =
ListVerifiedEmailAddressesResponse
request :: (Service -> Service)
-> ListVerifiedEmailAddresses -> Request ListVerifiedEmailAddresses
request Service -> Service
overrides =
Service
-> ListVerifiedEmailAddresses -> Request ListVerifiedEmailAddresses
forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy ListVerifiedEmailAddresses
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse ListVerifiedEmailAddresses)))
response =
Text
-> (Int
-> ResponseHeaders
-> [Node]
-> Either String (AWSResponse ListVerifiedEmailAddresses))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy ListVerifiedEmailAddresses
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse ListVerifiedEmailAddresses)))
forall (m :: * -> *) a.
MonadResource m =>
Text
-> (Int
-> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXMLWrapper
Text
"ListVerifiedEmailAddressesResult"
( \Int
s ResponseHeaders
h [Node]
x ->
Maybe [Text] -> Int -> ListVerifiedEmailAddressesResponse
ListVerifiedEmailAddressesResponse'
(Maybe [Text] -> Int -> ListVerifiedEmailAddressesResponse)
-> Either String (Maybe [Text])
-> Either String (Int -> ListVerifiedEmailAddressesResponse)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ( [Node]
x
[Node] -> Text -> Either String (Maybe [Node])
forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"VerifiedEmailAddresses"
Either String (Maybe [Node]) -> [Node] -> Either String [Node]
forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ [Node]
forall a. Monoid a => a
Prelude.mempty
Either String [Node]
-> ([Node] -> Either String (Maybe [Text]))
-> Either String (Maybe [Text])
forall a b.
Either String a -> (a -> Either String b) -> Either String b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
Prelude.>>= ([Node] -> Either String [Text])
-> [Node] -> Either String (Maybe [Text])
forall (f :: * -> *) a b.
Applicative f =>
([a] -> f b) -> [a] -> f (Maybe b)
Core.may (Text -> [Node] -> Either String [Text]
forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"member")
)
Either String (Int -> ListVerifiedEmailAddressesResponse)
-> Either String Int
-> Either String ListVerifiedEmailAddressesResponse
forall a b.
Either String (a -> b) -> Either String a -> Either String b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Int -> Either String Int
forall a. a -> Either String a
forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (Int -> Int
forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
)
instance Prelude.Hashable ListVerifiedEmailAddresses where
hashWithSalt :: Int -> ListVerifiedEmailAddresses -> Int
hashWithSalt Int
_salt ListVerifiedEmailAddresses
_ =
Int
_salt Int -> () -> Int
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` ()
instance Prelude.NFData ListVerifiedEmailAddresses where
rnf :: ListVerifiedEmailAddresses -> ()
rnf ListVerifiedEmailAddresses
_ = ()
instance Data.ToHeaders ListVerifiedEmailAddresses where
toHeaders :: ListVerifiedEmailAddresses -> ResponseHeaders
toHeaders = ResponseHeaders -> ListVerifiedEmailAddresses -> ResponseHeaders
forall a b. a -> b -> a
Prelude.const ResponseHeaders
forall a. Monoid a => a
Prelude.mempty
instance Data.ToPath ListVerifiedEmailAddresses where
toPath :: ListVerifiedEmailAddresses -> ByteString
toPath = ByteString -> ListVerifiedEmailAddresses -> ByteString
forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery ListVerifiedEmailAddresses where
toQuery :: ListVerifiedEmailAddresses -> QueryString
toQuery =
QueryString -> ListVerifiedEmailAddresses -> QueryString
forall a b. a -> b -> a
Prelude.const
( [QueryString] -> QueryString
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"Action"
ByteString -> ByteString -> QueryString
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"ListVerifiedEmailAddresses" :: Prelude.ByteString),
ByteString
"Version"
ByteString -> ByteString -> QueryString
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2010-12-01" :: Prelude.ByteString)
]
)
data ListVerifiedEmailAddressesResponse = ListVerifiedEmailAddressesResponse'
{
ListVerifiedEmailAddressesResponse -> Maybe [Text]
verifiedEmailAddresses :: Prelude.Maybe [Prelude.Text],
ListVerifiedEmailAddressesResponse -> Int
httpStatus :: Prelude.Int
}
deriving (ListVerifiedEmailAddressesResponse
-> ListVerifiedEmailAddressesResponse -> Bool
(ListVerifiedEmailAddressesResponse
-> ListVerifiedEmailAddressesResponse -> Bool)
-> (ListVerifiedEmailAddressesResponse
-> ListVerifiedEmailAddressesResponse -> Bool)
-> Eq ListVerifiedEmailAddressesResponse
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: ListVerifiedEmailAddressesResponse
-> ListVerifiedEmailAddressesResponse -> Bool
== :: ListVerifiedEmailAddressesResponse
-> ListVerifiedEmailAddressesResponse -> Bool
$c/= :: ListVerifiedEmailAddressesResponse
-> ListVerifiedEmailAddressesResponse -> Bool
/= :: ListVerifiedEmailAddressesResponse
-> ListVerifiedEmailAddressesResponse -> Bool
Prelude.Eq, ReadPrec [ListVerifiedEmailAddressesResponse]
ReadPrec ListVerifiedEmailAddressesResponse
Int -> ReadS ListVerifiedEmailAddressesResponse
ReadS [ListVerifiedEmailAddressesResponse]
(Int -> ReadS ListVerifiedEmailAddressesResponse)
-> ReadS [ListVerifiedEmailAddressesResponse]
-> ReadPrec ListVerifiedEmailAddressesResponse
-> ReadPrec [ListVerifiedEmailAddressesResponse]
-> Read ListVerifiedEmailAddressesResponse
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
$creadsPrec :: Int -> ReadS ListVerifiedEmailAddressesResponse
readsPrec :: Int -> ReadS ListVerifiedEmailAddressesResponse
$creadList :: ReadS [ListVerifiedEmailAddressesResponse]
readList :: ReadS [ListVerifiedEmailAddressesResponse]
$creadPrec :: ReadPrec ListVerifiedEmailAddressesResponse
readPrec :: ReadPrec ListVerifiedEmailAddressesResponse
$creadListPrec :: ReadPrec [ListVerifiedEmailAddressesResponse]
readListPrec :: ReadPrec [ListVerifiedEmailAddressesResponse]
Prelude.Read, Int -> ListVerifiedEmailAddressesResponse -> ShowS
[ListVerifiedEmailAddressesResponse] -> ShowS
ListVerifiedEmailAddressesResponse -> String
(Int -> ListVerifiedEmailAddressesResponse -> ShowS)
-> (ListVerifiedEmailAddressesResponse -> String)
-> ([ListVerifiedEmailAddressesResponse] -> ShowS)
-> Show ListVerifiedEmailAddressesResponse
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> ListVerifiedEmailAddressesResponse -> ShowS
showsPrec :: Int -> ListVerifiedEmailAddressesResponse -> ShowS
$cshow :: ListVerifiedEmailAddressesResponse -> String
show :: ListVerifiedEmailAddressesResponse -> String
$cshowList :: [ListVerifiedEmailAddressesResponse] -> ShowS
showList :: [ListVerifiedEmailAddressesResponse] -> ShowS
Prelude.Show, (forall x.
ListVerifiedEmailAddressesResponse
-> Rep ListVerifiedEmailAddressesResponse x)
-> (forall x.
Rep ListVerifiedEmailAddressesResponse x
-> ListVerifiedEmailAddressesResponse)
-> Generic ListVerifiedEmailAddressesResponse
forall x.
Rep ListVerifiedEmailAddressesResponse x
-> ListVerifiedEmailAddressesResponse
forall x.
ListVerifiedEmailAddressesResponse
-> Rep ListVerifiedEmailAddressesResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x.
ListVerifiedEmailAddressesResponse
-> Rep ListVerifiedEmailAddressesResponse x
from :: forall x.
ListVerifiedEmailAddressesResponse
-> Rep ListVerifiedEmailAddressesResponse x
$cto :: forall x.
Rep ListVerifiedEmailAddressesResponse x
-> ListVerifiedEmailAddressesResponse
to :: forall x.
Rep ListVerifiedEmailAddressesResponse x
-> ListVerifiedEmailAddressesResponse
Prelude.Generic)
newListVerifiedEmailAddressesResponse ::
Prelude.Int ->
ListVerifiedEmailAddressesResponse
newListVerifiedEmailAddressesResponse :: Int -> ListVerifiedEmailAddressesResponse
newListVerifiedEmailAddressesResponse Int
pHttpStatus_ =
ListVerifiedEmailAddressesResponse'
{ $sel:verifiedEmailAddresses:ListVerifiedEmailAddressesResponse' :: Maybe [Text]
verifiedEmailAddresses =
Maybe [Text]
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:ListVerifiedEmailAddressesResponse' :: Int
httpStatus = Int
pHttpStatus_
}
listVerifiedEmailAddressesResponse_verifiedEmailAddresses :: Lens.Lens' ListVerifiedEmailAddressesResponse (Prelude.Maybe [Prelude.Text])
listVerifiedEmailAddressesResponse_verifiedEmailAddresses :: Lens' ListVerifiedEmailAddressesResponse (Maybe [Text])
listVerifiedEmailAddressesResponse_verifiedEmailAddresses = (ListVerifiedEmailAddressesResponse -> Maybe [Text])
-> (ListVerifiedEmailAddressesResponse
-> Maybe [Text] -> ListVerifiedEmailAddressesResponse)
-> Lens' ListVerifiedEmailAddressesResponse (Maybe [Text])
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListVerifiedEmailAddressesResponse' {Maybe [Text]
$sel:verifiedEmailAddresses:ListVerifiedEmailAddressesResponse' :: ListVerifiedEmailAddressesResponse -> Maybe [Text]
verifiedEmailAddresses :: Maybe [Text]
verifiedEmailAddresses} -> Maybe [Text]
verifiedEmailAddresses) (\s :: ListVerifiedEmailAddressesResponse
s@ListVerifiedEmailAddressesResponse' {} Maybe [Text]
a -> ListVerifiedEmailAddressesResponse
s {verifiedEmailAddresses = a} :: ListVerifiedEmailAddressesResponse) ((Maybe [Text] -> f (Maybe [Text]))
-> ListVerifiedEmailAddressesResponse
-> f ListVerifiedEmailAddressesResponse)
-> ((Maybe [Text] -> f (Maybe [Text]))
-> Maybe [Text] -> f (Maybe [Text]))
-> (Maybe [Text] -> f (Maybe [Text]))
-> ListVerifiedEmailAddressesResponse
-> f ListVerifiedEmailAddressesResponse
forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. AnIso [Text] [Text] [Text] [Text]
-> Iso (Maybe [Text]) (Maybe [Text]) (Maybe [Text]) (Maybe [Text])
forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping AnIso [Text] [Text] [Text] [Text]
forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Iso [Text] [Text] [Text] [Text]
Lens.coerced
listVerifiedEmailAddressesResponse_httpStatus :: Lens.Lens' ListVerifiedEmailAddressesResponse Prelude.Int
listVerifiedEmailAddressesResponse_httpStatus :: Lens' ListVerifiedEmailAddressesResponse Int
listVerifiedEmailAddressesResponse_httpStatus = (ListVerifiedEmailAddressesResponse -> Int)
-> (ListVerifiedEmailAddressesResponse
-> Int -> ListVerifiedEmailAddressesResponse)
-> Lens' ListVerifiedEmailAddressesResponse Int
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListVerifiedEmailAddressesResponse' {Int
$sel:httpStatus:ListVerifiedEmailAddressesResponse' :: ListVerifiedEmailAddressesResponse -> Int
httpStatus :: Int
httpStatus} -> Int
httpStatus) (\s :: ListVerifiedEmailAddressesResponse
s@ListVerifiedEmailAddressesResponse' {} Int
a -> ListVerifiedEmailAddressesResponse
s {httpStatus = a} :: ListVerifiedEmailAddressesResponse)
instance
Prelude.NFData
ListVerifiedEmailAddressesResponse
where
rnf :: ListVerifiedEmailAddressesResponse -> ()
rnf ListVerifiedEmailAddressesResponse' {Int
Maybe [Text]
$sel:verifiedEmailAddresses:ListVerifiedEmailAddressesResponse' :: ListVerifiedEmailAddressesResponse -> Maybe [Text]
$sel:httpStatus:ListVerifiedEmailAddressesResponse' :: ListVerifiedEmailAddressesResponse -> Int
verifiedEmailAddresses :: Maybe [Text]
httpStatus :: Int
..} =
Maybe [Text] -> ()
forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
verifiedEmailAddresses
() -> () -> ()
forall a b. a -> b -> b
`Prelude.seq` Int -> ()
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus