{-# 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.SESV2.DeleteContact
(
DeleteContact (..),
newDeleteContact,
deleteContact_contactListName,
deleteContact_emailAddress,
DeleteContactResponse (..),
newDeleteContactResponse,
deleteContactResponse_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.SESV2.Types
data DeleteContact = DeleteContact'
{
DeleteContact -> Text
contactListName :: Prelude.Text,
DeleteContact -> Text
emailAddress :: Prelude.Text
}
deriving (DeleteContact -> DeleteContact -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteContact -> DeleteContact -> Bool
$c/= :: DeleteContact -> DeleteContact -> Bool
== :: DeleteContact -> DeleteContact -> Bool
$c== :: DeleteContact -> DeleteContact -> Bool
Prelude.Eq, ReadPrec [DeleteContact]
ReadPrec DeleteContact
Int -> ReadS DeleteContact
ReadS [DeleteContact]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteContact]
$creadListPrec :: ReadPrec [DeleteContact]
readPrec :: ReadPrec DeleteContact
$creadPrec :: ReadPrec DeleteContact
readList :: ReadS [DeleteContact]
$creadList :: ReadS [DeleteContact]
readsPrec :: Int -> ReadS DeleteContact
$creadsPrec :: Int -> ReadS DeleteContact
Prelude.Read, Int -> DeleteContact -> ShowS
[DeleteContact] -> ShowS
DeleteContact -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteContact] -> ShowS
$cshowList :: [DeleteContact] -> ShowS
show :: DeleteContact -> String
$cshow :: DeleteContact -> String
showsPrec :: Int -> DeleteContact -> ShowS
$cshowsPrec :: Int -> DeleteContact -> ShowS
Prelude.Show, forall x. Rep DeleteContact x -> DeleteContact
forall x. DeleteContact -> Rep DeleteContact x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteContact x -> DeleteContact
$cfrom :: forall x. DeleteContact -> Rep DeleteContact x
Prelude.Generic)
newDeleteContact ::
Prelude.Text ->
Prelude.Text ->
DeleteContact
newDeleteContact :: Text -> Text -> DeleteContact
newDeleteContact Text
pContactListName_ Text
pEmailAddress_ =
DeleteContact'
{ $sel:contactListName:DeleteContact' :: Text
contactListName = Text
pContactListName_,
$sel:emailAddress:DeleteContact' :: Text
emailAddress = Text
pEmailAddress_
}
deleteContact_contactListName :: Lens.Lens' DeleteContact Prelude.Text
deleteContact_contactListName :: Lens' DeleteContact Text
deleteContact_contactListName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteContact' {Text
contactListName :: Text
$sel:contactListName:DeleteContact' :: DeleteContact -> Text
contactListName} -> Text
contactListName) (\s :: DeleteContact
s@DeleteContact' {} Text
a -> DeleteContact
s {$sel:contactListName:DeleteContact' :: Text
contactListName = Text
a} :: DeleteContact)
deleteContact_emailAddress :: Lens.Lens' DeleteContact Prelude.Text
deleteContact_emailAddress :: Lens' DeleteContact Text
deleteContact_emailAddress = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteContact' {Text
emailAddress :: Text
$sel:emailAddress:DeleteContact' :: DeleteContact -> Text
emailAddress} -> Text
emailAddress) (\s :: DeleteContact
s@DeleteContact' {} Text
a -> DeleteContact
s {$sel:emailAddress:DeleteContact' :: Text
emailAddress = Text
a} :: DeleteContact)
instance Core.AWSRequest DeleteContact where
type
AWSResponse DeleteContact =
DeleteContactResponse
request :: (Service -> Service) -> DeleteContact -> Request DeleteContact
request Service -> Service
overrides =
forall a. ToRequest a => Service -> a -> Request a
Request.delete (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DeleteContact
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteContact)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> () -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveEmpty
( \Int
s ResponseHeaders
h ()
x ->
Int -> DeleteContactResponse
DeleteContactResponse'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
)
instance Prelude.Hashable DeleteContact where
hashWithSalt :: Int -> DeleteContact -> Int
hashWithSalt Int
_salt DeleteContact' {Text
emailAddress :: Text
contactListName :: Text
$sel:emailAddress:DeleteContact' :: DeleteContact -> Text
$sel:contactListName:DeleteContact' :: DeleteContact -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
contactListName
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
emailAddress
instance Prelude.NFData DeleteContact where
rnf :: DeleteContact -> ()
rnf DeleteContact' {Text
emailAddress :: Text
contactListName :: Text
$sel:emailAddress:DeleteContact' :: DeleteContact -> Text
$sel:contactListName:DeleteContact' :: DeleteContact -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
contactListName
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
emailAddress
instance Data.ToHeaders DeleteContact where
toHeaders :: DeleteContact -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToPath DeleteContact where
toPath :: DeleteContact -> ByteString
toPath DeleteContact' {Text
emailAddress :: Text
contactListName :: Text
$sel:emailAddress:DeleteContact' :: DeleteContact -> Text
$sel:contactListName:DeleteContact' :: DeleteContact -> Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/v2/email/contact-lists/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
contactListName,
ByteString
"/contacts/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
emailAddress
]
instance Data.ToQuery DeleteContact where
toQuery :: DeleteContact -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteContactResponse = DeleteContactResponse'
{
DeleteContactResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DeleteContactResponse -> DeleteContactResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteContactResponse -> DeleteContactResponse -> Bool
$c/= :: DeleteContactResponse -> DeleteContactResponse -> Bool
== :: DeleteContactResponse -> DeleteContactResponse -> Bool
$c== :: DeleteContactResponse -> DeleteContactResponse -> Bool
Prelude.Eq, ReadPrec [DeleteContactResponse]
ReadPrec DeleteContactResponse
Int -> ReadS DeleteContactResponse
ReadS [DeleteContactResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteContactResponse]
$creadListPrec :: ReadPrec [DeleteContactResponse]
readPrec :: ReadPrec DeleteContactResponse
$creadPrec :: ReadPrec DeleteContactResponse
readList :: ReadS [DeleteContactResponse]
$creadList :: ReadS [DeleteContactResponse]
readsPrec :: Int -> ReadS DeleteContactResponse
$creadsPrec :: Int -> ReadS DeleteContactResponse
Prelude.Read, Int -> DeleteContactResponse -> ShowS
[DeleteContactResponse] -> ShowS
DeleteContactResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteContactResponse] -> ShowS
$cshowList :: [DeleteContactResponse] -> ShowS
show :: DeleteContactResponse -> String
$cshow :: DeleteContactResponse -> String
showsPrec :: Int -> DeleteContactResponse -> ShowS
$cshowsPrec :: Int -> DeleteContactResponse -> ShowS
Prelude.Show, forall x. Rep DeleteContactResponse x -> DeleteContactResponse
forall x. DeleteContactResponse -> Rep DeleteContactResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteContactResponse x -> DeleteContactResponse
$cfrom :: forall x. DeleteContactResponse -> Rep DeleteContactResponse x
Prelude.Generic)
newDeleteContactResponse ::
Prelude.Int ->
DeleteContactResponse
newDeleteContactResponse :: Int -> DeleteContactResponse
newDeleteContactResponse Int
pHttpStatus_ =
DeleteContactResponse' {$sel:httpStatus:DeleteContactResponse' :: Int
httpStatus = Int
pHttpStatus_}
deleteContactResponse_httpStatus :: Lens.Lens' DeleteContactResponse Prelude.Int
deleteContactResponse_httpStatus :: Lens' DeleteContactResponse Int
deleteContactResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteContactResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteContactResponse' :: DeleteContactResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteContactResponse
s@DeleteContactResponse' {} Int
a -> DeleteContactResponse
s {$sel:httpStatus:DeleteContactResponse' :: Int
httpStatus = Int
a} :: DeleteContactResponse)
instance Prelude.NFData DeleteContactResponse where
rnf :: DeleteContactResponse -> ()
rnf DeleteContactResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteContactResponse' :: DeleteContactResponse -> Int
..} =
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus