{-# 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.ELBV2.RemoveTags
(
RemoveTags (..),
newRemoveTags,
removeTags_resourceArns,
removeTags_tagKeys,
RemoveTagsResponse (..),
newRemoveTagsResponse,
removeTagsResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.ELBV2.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data RemoveTags = RemoveTags'
{
RemoveTags -> [Text]
resourceArns :: [Prelude.Text],
RemoveTags -> [Text]
tagKeys :: [Prelude.Text]
}
deriving (RemoveTags -> RemoveTags -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: RemoveTags -> RemoveTags -> Bool
$c/= :: RemoveTags -> RemoveTags -> Bool
== :: RemoveTags -> RemoveTags -> Bool
$c== :: RemoveTags -> RemoveTags -> Bool
Prelude.Eq, ReadPrec [RemoveTags]
ReadPrec RemoveTags
Int -> ReadS RemoveTags
ReadS [RemoveTags]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [RemoveTags]
$creadListPrec :: ReadPrec [RemoveTags]
readPrec :: ReadPrec RemoveTags
$creadPrec :: ReadPrec RemoveTags
readList :: ReadS [RemoveTags]
$creadList :: ReadS [RemoveTags]
readsPrec :: Int -> ReadS RemoveTags
$creadsPrec :: Int -> ReadS RemoveTags
Prelude.Read, Int -> RemoveTags -> ShowS
[RemoveTags] -> ShowS
RemoveTags -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [RemoveTags] -> ShowS
$cshowList :: [RemoveTags] -> ShowS
show :: RemoveTags -> String
$cshow :: RemoveTags -> String
showsPrec :: Int -> RemoveTags -> ShowS
$cshowsPrec :: Int -> RemoveTags -> ShowS
Prelude.Show, forall x. Rep RemoveTags x -> RemoveTags
forall x. RemoveTags -> Rep RemoveTags x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep RemoveTags x -> RemoveTags
$cfrom :: forall x. RemoveTags -> Rep RemoveTags x
Prelude.Generic)
newRemoveTags ::
RemoveTags
newRemoveTags :: RemoveTags
newRemoveTags =
RemoveTags'
{ $sel:resourceArns:RemoveTags' :: [Text]
resourceArns = forall a. Monoid a => a
Prelude.mempty,
$sel:tagKeys:RemoveTags' :: [Text]
tagKeys = forall a. Monoid a => a
Prelude.mempty
}
removeTags_resourceArns :: Lens.Lens' RemoveTags [Prelude.Text]
removeTags_resourceArns :: Lens' RemoveTags [Text]
removeTags_resourceArns = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RemoveTags' {[Text]
resourceArns :: [Text]
$sel:resourceArns:RemoveTags' :: RemoveTags -> [Text]
resourceArns} -> [Text]
resourceArns) (\s :: RemoveTags
s@RemoveTags' {} [Text]
a -> RemoveTags
s {$sel:resourceArns:RemoveTags' :: [Text]
resourceArns = [Text]
a} :: RemoveTags) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
removeTags_tagKeys :: Lens.Lens' RemoveTags [Prelude.Text]
removeTags_tagKeys :: Lens' RemoveTags [Text]
removeTags_tagKeys = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RemoveTags' {[Text]
tagKeys :: [Text]
$sel:tagKeys:RemoveTags' :: RemoveTags -> [Text]
tagKeys} -> [Text]
tagKeys) (\s :: RemoveTags
s@RemoveTags' {} [Text]
a -> RemoveTags
s {$sel:tagKeys:RemoveTags' :: [Text]
tagKeys = [Text]
a} :: RemoveTags) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
instance Core.AWSRequest RemoveTags where
type AWSResponse RemoveTags = RemoveTagsResponse
request :: (Service -> Service) -> RemoveTags -> Request RemoveTags
request Service -> Service
overrides =
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 RemoveTags
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse RemoveTags)))
response =
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
"RemoveTagsResult"
( \Int
s ResponseHeaders
h [Node]
x ->
Int -> RemoveTagsResponse
RemoveTagsResponse'
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 RemoveTags where
hashWithSalt :: Int -> RemoveTags -> Int
hashWithSalt Int
_salt RemoveTags' {[Text]
tagKeys :: [Text]
resourceArns :: [Text]
$sel:tagKeys:RemoveTags' :: RemoveTags -> [Text]
$sel:resourceArns:RemoveTags' :: RemoveTags -> [Text]
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [Text]
resourceArns
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [Text]
tagKeys
instance Prelude.NFData RemoveTags where
rnf :: RemoveTags -> ()
rnf RemoveTags' {[Text]
tagKeys :: [Text]
resourceArns :: [Text]
$sel:tagKeys:RemoveTags' :: RemoveTags -> [Text]
$sel:resourceArns:RemoveTags' :: RemoveTags -> [Text]
..} =
forall a. NFData a => a -> ()
Prelude.rnf [Text]
resourceArns
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [Text]
tagKeys
instance Data.ToHeaders RemoveTags where
toHeaders :: RemoveTags -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
instance Data.ToPath RemoveTags where
toPath :: RemoveTags -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery RemoveTags where
toQuery :: RemoveTags -> QueryString
toQuery RemoveTags' {[Text]
tagKeys :: [Text]
resourceArns :: [Text]
$sel:tagKeys:RemoveTags' :: RemoveTags -> [Text]
$sel:resourceArns:RemoveTags' :: RemoveTags -> [Text]
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"Action"
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"RemoveTags" :: Prelude.ByteString),
ByteString
"Version"
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2015-12-01" :: Prelude.ByteString),
ByteString
"ResourceArns"
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"member" [Text]
resourceArns,
ByteString
"TagKeys" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"member" [Text]
tagKeys
]
data RemoveTagsResponse = RemoveTagsResponse'
{
RemoveTagsResponse -> Int
httpStatus :: Prelude.Int
}
deriving (RemoveTagsResponse -> RemoveTagsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: RemoveTagsResponse -> RemoveTagsResponse -> Bool
$c/= :: RemoveTagsResponse -> RemoveTagsResponse -> Bool
== :: RemoveTagsResponse -> RemoveTagsResponse -> Bool
$c== :: RemoveTagsResponse -> RemoveTagsResponse -> Bool
Prelude.Eq, ReadPrec [RemoveTagsResponse]
ReadPrec RemoveTagsResponse
Int -> ReadS RemoveTagsResponse
ReadS [RemoveTagsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [RemoveTagsResponse]
$creadListPrec :: ReadPrec [RemoveTagsResponse]
readPrec :: ReadPrec RemoveTagsResponse
$creadPrec :: ReadPrec RemoveTagsResponse
readList :: ReadS [RemoveTagsResponse]
$creadList :: ReadS [RemoveTagsResponse]
readsPrec :: Int -> ReadS RemoveTagsResponse
$creadsPrec :: Int -> ReadS RemoveTagsResponse
Prelude.Read, Int -> RemoveTagsResponse -> ShowS
[RemoveTagsResponse] -> ShowS
RemoveTagsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [RemoveTagsResponse] -> ShowS
$cshowList :: [RemoveTagsResponse] -> ShowS
show :: RemoveTagsResponse -> String
$cshow :: RemoveTagsResponse -> String
showsPrec :: Int -> RemoveTagsResponse -> ShowS
$cshowsPrec :: Int -> RemoveTagsResponse -> ShowS
Prelude.Show, forall x. Rep RemoveTagsResponse x -> RemoveTagsResponse
forall x. RemoveTagsResponse -> Rep RemoveTagsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep RemoveTagsResponse x -> RemoveTagsResponse
$cfrom :: forall x. RemoveTagsResponse -> Rep RemoveTagsResponse x
Prelude.Generic)
newRemoveTagsResponse ::
Prelude.Int ->
RemoveTagsResponse
newRemoveTagsResponse :: Int -> RemoveTagsResponse
newRemoveTagsResponse Int
pHttpStatus_ =
RemoveTagsResponse' {$sel:httpStatus:RemoveTagsResponse' :: Int
httpStatus = Int
pHttpStatus_}
removeTagsResponse_httpStatus :: Lens.Lens' RemoveTagsResponse Prelude.Int
removeTagsResponse_httpStatus :: Lens' RemoveTagsResponse Int
removeTagsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RemoveTagsResponse' {Int
httpStatus :: Int
$sel:httpStatus:RemoveTagsResponse' :: RemoveTagsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: RemoveTagsResponse
s@RemoveTagsResponse' {} Int
a -> RemoveTagsResponse
s {$sel:httpStatus:RemoveTagsResponse' :: Int
httpStatus = Int
a} :: RemoveTagsResponse)
instance Prelude.NFData RemoveTagsResponse where
rnf :: RemoveTagsResponse -> ()
rnf RemoveTagsResponse' {Int
httpStatus :: Int
$sel:httpStatus:RemoveTagsResponse' :: RemoveTagsResponse -> Int
..} = forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus