{-# 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.IdentityStore.DeleteGroupMembership
(
DeleteGroupMembership (..),
newDeleteGroupMembership,
deleteGroupMembership_identityStoreId,
deleteGroupMembership_membershipId,
DeleteGroupMembershipResponse (..),
newDeleteGroupMembershipResponse,
deleteGroupMembershipResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.IdentityStore.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DeleteGroupMembership = DeleteGroupMembership'
{
DeleteGroupMembership -> Text
identityStoreId :: Prelude.Text,
DeleteGroupMembership -> Text
membershipId :: Prelude.Text
}
deriving (DeleteGroupMembership -> DeleteGroupMembership -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteGroupMembership -> DeleteGroupMembership -> Bool
$c/= :: DeleteGroupMembership -> DeleteGroupMembership -> Bool
== :: DeleteGroupMembership -> DeleteGroupMembership -> Bool
$c== :: DeleteGroupMembership -> DeleteGroupMembership -> Bool
Prelude.Eq, ReadPrec [DeleteGroupMembership]
ReadPrec DeleteGroupMembership
Int -> ReadS DeleteGroupMembership
ReadS [DeleteGroupMembership]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteGroupMembership]
$creadListPrec :: ReadPrec [DeleteGroupMembership]
readPrec :: ReadPrec DeleteGroupMembership
$creadPrec :: ReadPrec DeleteGroupMembership
readList :: ReadS [DeleteGroupMembership]
$creadList :: ReadS [DeleteGroupMembership]
readsPrec :: Int -> ReadS DeleteGroupMembership
$creadsPrec :: Int -> ReadS DeleteGroupMembership
Prelude.Read, Int -> DeleteGroupMembership -> ShowS
[DeleteGroupMembership] -> ShowS
DeleteGroupMembership -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteGroupMembership] -> ShowS
$cshowList :: [DeleteGroupMembership] -> ShowS
show :: DeleteGroupMembership -> String
$cshow :: DeleteGroupMembership -> String
showsPrec :: Int -> DeleteGroupMembership -> ShowS
$cshowsPrec :: Int -> DeleteGroupMembership -> ShowS
Prelude.Show, forall x. Rep DeleteGroupMembership x -> DeleteGroupMembership
forall x. DeleteGroupMembership -> Rep DeleteGroupMembership x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteGroupMembership x -> DeleteGroupMembership
$cfrom :: forall x. DeleteGroupMembership -> Rep DeleteGroupMembership x
Prelude.Generic)
newDeleteGroupMembership ::
Prelude.Text ->
Prelude.Text ->
DeleteGroupMembership
newDeleteGroupMembership :: Text -> Text -> DeleteGroupMembership
newDeleteGroupMembership
Text
pIdentityStoreId_
Text
pMembershipId_ =
DeleteGroupMembership'
{ $sel:identityStoreId:DeleteGroupMembership' :: Text
identityStoreId =
Text
pIdentityStoreId_,
$sel:membershipId:DeleteGroupMembership' :: Text
membershipId = Text
pMembershipId_
}
deleteGroupMembership_identityStoreId :: Lens.Lens' DeleteGroupMembership Prelude.Text
deleteGroupMembership_identityStoreId :: Lens' DeleteGroupMembership Text
deleteGroupMembership_identityStoreId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteGroupMembership' {Text
identityStoreId :: Text
$sel:identityStoreId:DeleteGroupMembership' :: DeleteGroupMembership -> Text
identityStoreId} -> Text
identityStoreId) (\s :: DeleteGroupMembership
s@DeleteGroupMembership' {} Text
a -> DeleteGroupMembership
s {$sel:identityStoreId:DeleteGroupMembership' :: Text
identityStoreId = Text
a} :: DeleteGroupMembership)
deleteGroupMembership_membershipId :: Lens.Lens' DeleteGroupMembership Prelude.Text
deleteGroupMembership_membershipId :: Lens' DeleteGroupMembership Text
deleteGroupMembership_membershipId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteGroupMembership' {Text
membershipId :: Text
$sel:membershipId:DeleteGroupMembership' :: DeleteGroupMembership -> Text
membershipId} -> Text
membershipId) (\s :: DeleteGroupMembership
s@DeleteGroupMembership' {} Text
a -> DeleteGroupMembership
s {$sel:membershipId:DeleteGroupMembership' :: Text
membershipId = Text
a} :: DeleteGroupMembership)
instance Core.AWSRequest DeleteGroupMembership where
type
AWSResponse DeleteGroupMembership =
DeleteGroupMembershipResponse
request :: (Service -> Service)
-> DeleteGroupMembership -> Request DeleteGroupMembership
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 DeleteGroupMembership
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse DeleteGroupMembership)))
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 -> DeleteGroupMembershipResponse
DeleteGroupMembershipResponse'
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 DeleteGroupMembership where
hashWithSalt :: Int -> DeleteGroupMembership -> Int
hashWithSalt Int
_salt DeleteGroupMembership' {Text
membershipId :: Text
identityStoreId :: Text
$sel:membershipId:DeleteGroupMembership' :: DeleteGroupMembership -> Text
$sel:identityStoreId:DeleteGroupMembership' :: DeleteGroupMembership -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
identityStoreId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
membershipId
instance Prelude.NFData DeleteGroupMembership where
rnf :: DeleteGroupMembership -> ()
rnf DeleteGroupMembership' {Text
membershipId :: Text
identityStoreId :: Text
$sel:membershipId:DeleteGroupMembership' :: DeleteGroupMembership -> Text
$sel:identityStoreId:DeleteGroupMembership' :: DeleteGroupMembership -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
identityStoreId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
membershipId
instance Data.ToHeaders DeleteGroupMembership where
toHeaders :: DeleteGroupMembership -> 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
"AWSIdentityStore.DeleteGroupMembership" ::
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 DeleteGroupMembership where
toJSON :: DeleteGroupMembership -> Value
toJSON DeleteGroupMembership' {Text
membershipId :: Text
identityStoreId :: Text
$sel:membershipId:DeleteGroupMembership' :: DeleteGroupMembership -> Text
$sel:identityStoreId:DeleteGroupMembership' :: DeleteGroupMembership -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just
(Key
"IdentityStoreId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
identityStoreId),
forall a. a -> Maybe a
Prelude.Just (Key
"MembershipId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
membershipId)
]
)
instance Data.ToPath DeleteGroupMembership where
toPath :: DeleteGroupMembership -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DeleteGroupMembership where
toQuery :: DeleteGroupMembership -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteGroupMembershipResponse = DeleteGroupMembershipResponse'
{
DeleteGroupMembershipResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DeleteGroupMembershipResponse
-> DeleteGroupMembershipResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteGroupMembershipResponse
-> DeleteGroupMembershipResponse -> Bool
$c/= :: DeleteGroupMembershipResponse
-> DeleteGroupMembershipResponse -> Bool
== :: DeleteGroupMembershipResponse
-> DeleteGroupMembershipResponse -> Bool
$c== :: DeleteGroupMembershipResponse
-> DeleteGroupMembershipResponse -> Bool
Prelude.Eq, ReadPrec [DeleteGroupMembershipResponse]
ReadPrec DeleteGroupMembershipResponse
Int -> ReadS DeleteGroupMembershipResponse
ReadS [DeleteGroupMembershipResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteGroupMembershipResponse]
$creadListPrec :: ReadPrec [DeleteGroupMembershipResponse]
readPrec :: ReadPrec DeleteGroupMembershipResponse
$creadPrec :: ReadPrec DeleteGroupMembershipResponse
readList :: ReadS [DeleteGroupMembershipResponse]
$creadList :: ReadS [DeleteGroupMembershipResponse]
readsPrec :: Int -> ReadS DeleteGroupMembershipResponse
$creadsPrec :: Int -> ReadS DeleteGroupMembershipResponse
Prelude.Read, Int -> DeleteGroupMembershipResponse -> ShowS
[DeleteGroupMembershipResponse] -> ShowS
DeleteGroupMembershipResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteGroupMembershipResponse] -> ShowS
$cshowList :: [DeleteGroupMembershipResponse] -> ShowS
show :: DeleteGroupMembershipResponse -> String
$cshow :: DeleteGroupMembershipResponse -> String
showsPrec :: Int -> DeleteGroupMembershipResponse -> ShowS
$cshowsPrec :: Int -> DeleteGroupMembershipResponse -> ShowS
Prelude.Show, forall x.
Rep DeleteGroupMembershipResponse x
-> DeleteGroupMembershipResponse
forall x.
DeleteGroupMembershipResponse
-> Rep DeleteGroupMembershipResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeleteGroupMembershipResponse x
-> DeleteGroupMembershipResponse
$cfrom :: forall x.
DeleteGroupMembershipResponse
-> Rep DeleteGroupMembershipResponse x
Prelude.Generic)
newDeleteGroupMembershipResponse ::
Prelude.Int ->
DeleteGroupMembershipResponse
newDeleteGroupMembershipResponse :: Int -> DeleteGroupMembershipResponse
newDeleteGroupMembershipResponse Int
pHttpStatus_ =
DeleteGroupMembershipResponse'
{ $sel:httpStatus:DeleteGroupMembershipResponse' :: Int
httpStatus =
Int
pHttpStatus_
}
deleteGroupMembershipResponse_httpStatus :: Lens.Lens' DeleteGroupMembershipResponse Prelude.Int
deleteGroupMembershipResponse_httpStatus :: Lens' DeleteGroupMembershipResponse Int
deleteGroupMembershipResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteGroupMembershipResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteGroupMembershipResponse' :: DeleteGroupMembershipResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteGroupMembershipResponse
s@DeleteGroupMembershipResponse' {} Int
a -> DeleteGroupMembershipResponse
s {$sel:httpStatus:DeleteGroupMembershipResponse' :: Int
httpStatus = Int
a} :: DeleteGroupMembershipResponse)
instance Prelude.NFData DeleteGroupMembershipResponse where
rnf :: DeleteGroupMembershipResponse -> ()
rnf DeleteGroupMembershipResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteGroupMembershipResponse' :: DeleteGroupMembershipResponse -> Int
..} =
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus