{-# 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.WorkSpaces.DisassociateIpGroups
(
DisassociateIpGroups (..),
newDisassociateIpGroups,
disassociateIpGroups_directoryId,
disassociateIpGroups_groupIds,
DisassociateIpGroupsResponse (..),
newDisassociateIpGroupsResponse,
disassociateIpGroupsResponse_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.WorkSpaces.Types
data DisassociateIpGroups = DisassociateIpGroups'
{
DisassociateIpGroups -> Text
directoryId :: Prelude.Text,
DisassociateIpGroups -> [Text]
groupIds :: [Prelude.Text]
}
deriving (DisassociateIpGroups -> DisassociateIpGroups -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DisassociateIpGroups -> DisassociateIpGroups -> Bool
$c/= :: DisassociateIpGroups -> DisassociateIpGroups -> Bool
== :: DisassociateIpGroups -> DisassociateIpGroups -> Bool
$c== :: DisassociateIpGroups -> DisassociateIpGroups -> Bool
Prelude.Eq, ReadPrec [DisassociateIpGroups]
ReadPrec DisassociateIpGroups
Int -> ReadS DisassociateIpGroups
ReadS [DisassociateIpGroups]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DisassociateIpGroups]
$creadListPrec :: ReadPrec [DisassociateIpGroups]
readPrec :: ReadPrec DisassociateIpGroups
$creadPrec :: ReadPrec DisassociateIpGroups
readList :: ReadS [DisassociateIpGroups]
$creadList :: ReadS [DisassociateIpGroups]
readsPrec :: Int -> ReadS DisassociateIpGroups
$creadsPrec :: Int -> ReadS DisassociateIpGroups
Prelude.Read, Int -> DisassociateIpGroups -> ShowS
[DisassociateIpGroups] -> ShowS
DisassociateIpGroups -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DisassociateIpGroups] -> ShowS
$cshowList :: [DisassociateIpGroups] -> ShowS
show :: DisassociateIpGroups -> String
$cshow :: DisassociateIpGroups -> String
showsPrec :: Int -> DisassociateIpGroups -> ShowS
$cshowsPrec :: Int -> DisassociateIpGroups -> ShowS
Prelude.Show, forall x. Rep DisassociateIpGroups x -> DisassociateIpGroups
forall x. DisassociateIpGroups -> Rep DisassociateIpGroups x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DisassociateIpGroups x -> DisassociateIpGroups
$cfrom :: forall x. DisassociateIpGroups -> Rep DisassociateIpGroups x
Prelude.Generic)
newDisassociateIpGroups ::
Prelude.Text ->
DisassociateIpGroups
newDisassociateIpGroups :: Text -> DisassociateIpGroups
newDisassociateIpGroups Text
pDirectoryId_ =
DisassociateIpGroups'
{ $sel:directoryId:DisassociateIpGroups' :: Text
directoryId = Text
pDirectoryId_,
$sel:groupIds:DisassociateIpGroups' :: [Text]
groupIds = forall a. Monoid a => a
Prelude.mempty
}
disassociateIpGroups_directoryId :: Lens.Lens' DisassociateIpGroups Prelude.Text
disassociateIpGroups_directoryId :: Lens' DisassociateIpGroups Text
disassociateIpGroups_directoryId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DisassociateIpGroups' {Text
directoryId :: Text
$sel:directoryId:DisassociateIpGroups' :: DisassociateIpGroups -> Text
directoryId} -> Text
directoryId) (\s :: DisassociateIpGroups
s@DisassociateIpGroups' {} Text
a -> DisassociateIpGroups
s {$sel:directoryId:DisassociateIpGroups' :: Text
directoryId = Text
a} :: DisassociateIpGroups)
disassociateIpGroups_groupIds :: Lens.Lens' DisassociateIpGroups [Prelude.Text]
disassociateIpGroups_groupIds :: Lens' DisassociateIpGroups [Text]
disassociateIpGroups_groupIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DisassociateIpGroups' {[Text]
groupIds :: [Text]
$sel:groupIds:DisassociateIpGroups' :: DisassociateIpGroups -> [Text]
groupIds} -> [Text]
groupIds) (\s :: DisassociateIpGroups
s@DisassociateIpGroups' {} [Text]
a -> DisassociateIpGroups
s {$sel:groupIds:DisassociateIpGroups' :: [Text]
groupIds = [Text]
a} :: DisassociateIpGroups) 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 DisassociateIpGroups where
type
AWSResponse DisassociateIpGroups =
DisassociateIpGroupsResponse
request :: (Service -> Service)
-> DisassociateIpGroups -> Request DisassociateIpGroups
request Service -> Service
overrides =
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DisassociateIpGroups
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse DisassociateIpGroups)))
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 -> DisassociateIpGroupsResponse
DisassociateIpGroupsResponse'
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 DisassociateIpGroups where
hashWithSalt :: Int -> DisassociateIpGroups -> Int
hashWithSalt Int
_salt DisassociateIpGroups' {[Text]
Text
groupIds :: [Text]
directoryId :: Text
$sel:groupIds:DisassociateIpGroups' :: DisassociateIpGroups -> [Text]
$sel:directoryId:DisassociateIpGroups' :: DisassociateIpGroups -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
directoryId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [Text]
groupIds
instance Prelude.NFData DisassociateIpGroups where
rnf :: DisassociateIpGroups -> ()
rnf DisassociateIpGroups' {[Text]
Text
groupIds :: [Text]
directoryId :: Text
$sel:groupIds:DisassociateIpGroups' :: DisassociateIpGroups -> [Text]
$sel:directoryId:DisassociateIpGroups' :: DisassociateIpGroups -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
directoryId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [Text]
groupIds
instance Data.ToHeaders DisassociateIpGroups where
toHeaders :: DisassociateIpGroups -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"X-Amz-Target"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"WorkspacesService.DisassociateIpGroups" ::
Prelude.ByteString
),
HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON DisassociateIpGroups where
toJSON :: DisassociateIpGroups -> Value
toJSON DisassociateIpGroups' {[Text]
Text
groupIds :: [Text]
directoryId :: Text
$sel:groupIds:DisassociateIpGroups' :: DisassociateIpGroups -> [Text]
$sel:directoryId:DisassociateIpGroups' :: DisassociateIpGroups -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just (Key
"DirectoryId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
directoryId),
forall a. a -> Maybe a
Prelude.Just (Key
"GroupIds" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= [Text]
groupIds)
]
)
instance Data.ToPath DisassociateIpGroups where
toPath :: DisassociateIpGroups -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DisassociateIpGroups where
toQuery :: DisassociateIpGroups -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DisassociateIpGroupsResponse = DisassociateIpGroupsResponse'
{
DisassociateIpGroupsResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DisassociateIpGroupsResponse
-> DisassociateIpGroupsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DisassociateIpGroupsResponse
-> DisassociateIpGroupsResponse -> Bool
$c/= :: DisassociateIpGroupsResponse
-> DisassociateIpGroupsResponse -> Bool
== :: DisassociateIpGroupsResponse
-> DisassociateIpGroupsResponse -> Bool
$c== :: DisassociateIpGroupsResponse
-> DisassociateIpGroupsResponse -> Bool
Prelude.Eq, ReadPrec [DisassociateIpGroupsResponse]
ReadPrec DisassociateIpGroupsResponse
Int -> ReadS DisassociateIpGroupsResponse
ReadS [DisassociateIpGroupsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DisassociateIpGroupsResponse]
$creadListPrec :: ReadPrec [DisassociateIpGroupsResponse]
readPrec :: ReadPrec DisassociateIpGroupsResponse
$creadPrec :: ReadPrec DisassociateIpGroupsResponse
readList :: ReadS [DisassociateIpGroupsResponse]
$creadList :: ReadS [DisassociateIpGroupsResponse]
readsPrec :: Int -> ReadS DisassociateIpGroupsResponse
$creadsPrec :: Int -> ReadS DisassociateIpGroupsResponse
Prelude.Read, Int -> DisassociateIpGroupsResponse -> ShowS
[DisassociateIpGroupsResponse] -> ShowS
DisassociateIpGroupsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DisassociateIpGroupsResponse] -> ShowS
$cshowList :: [DisassociateIpGroupsResponse] -> ShowS
show :: DisassociateIpGroupsResponse -> String
$cshow :: DisassociateIpGroupsResponse -> String
showsPrec :: Int -> DisassociateIpGroupsResponse -> ShowS
$cshowsPrec :: Int -> DisassociateIpGroupsResponse -> ShowS
Prelude.Show, forall x.
Rep DisassociateIpGroupsResponse x -> DisassociateIpGroupsResponse
forall x.
DisassociateIpGroupsResponse -> Rep DisassociateIpGroupsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DisassociateIpGroupsResponse x -> DisassociateIpGroupsResponse
$cfrom :: forall x.
DisassociateIpGroupsResponse -> Rep DisassociateIpGroupsResponse x
Prelude.Generic)
newDisassociateIpGroupsResponse ::
Prelude.Int ->
DisassociateIpGroupsResponse
newDisassociateIpGroupsResponse :: Int -> DisassociateIpGroupsResponse
newDisassociateIpGroupsResponse Int
pHttpStatus_ =
DisassociateIpGroupsResponse'
{ $sel:httpStatus:DisassociateIpGroupsResponse' :: Int
httpStatus =
Int
pHttpStatus_
}
disassociateIpGroupsResponse_httpStatus :: Lens.Lens' DisassociateIpGroupsResponse Prelude.Int
disassociateIpGroupsResponse_httpStatus :: Lens' DisassociateIpGroupsResponse Int
disassociateIpGroupsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DisassociateIpGroupsResponse' {Int
httpStatus :: Int
$sel:httpStatus:DisassociateIpGroupsResponse' :: DisassociateIpGroupsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DisassociateIpGroupsResponse
s@DisassociateIpGroupsResponse' {} Int
a -> DisassociateIpGroupsResponse
s {$sel:httpStatus:DisassociateIpGroupsResponse' :: Int
httpStatus = Int
a} :: DisassociateIpGroupsResponse)
instance Prelude.NFData DisassociateIpGroupsResponse where
rnf :: DisassociateIpGroupsResponse -> ()
rnf DisassociateIpGroupsResponse' {Int
httpStatus :: Int
$sel:httpStatus:DisassociateIpGroupsResponse' :: DisassociateIpGroupsResponse -> Int
..} =
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus