{-# 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.SSOAdmin.DetachManagedPolicyFromPermissionSet
(
DetachManagedPolicyFromPermissionSet (..),
newDetachManagedPolicyFromPermissionSet,
detachManagedPolicyFromPermissionSet_instanceArn,
detachManagedPolicyFromPermissionSet_permissionSetArn,
detachManagedPolicyFromPermissionSet_managedPolicyArn,
DetachManagedPolicyFromPermissionSetResponse (..),
newDetachManagedPolicyFromPermissionSetResponse,
detachManagedPolicyFromPermissionSetResponse_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.SSOAdmin.Types
data DetachManagedPolicyFromPermissionSet = DetachManagedPolicyFromPermissionSet'
{
DetachManagedPolicyFromPermissionSet -> Text
instanceArn :: Prelude.Text,
DetachManagedPolicyFromPermissionSet -> Text
permissionSetArn :: Prelude.Text,
DetachManagedPolicyFromPermissionSet -> Text
managedPolicyArn :: Prelude.Text
}
deriving (DetachManagedPolicyFromPermissionSet
-> DetachManagedPolicyFromPermissionSet -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DetachManagedPolicyFromPermissionSet
-> DetachManagedPolicyFromPermissionSet -> Bool
$c/= :: DetachManagedPolicyFromPermissionSet
-> DetachManagedPolicyFromPermissionSet -> Bool
== :: DetachManagedPolicyFromPermissionSet
-> DetachManagedPolicyFromPermissionSet -> Bool
$c== :: DetachManagedPolicyFromPermissionSet
-> DetachManagedPolicyFromPermissionSet -> Bool
Prelude.Eq, ReadPrec [DetachManagedPolicyFromPermissionSet]
ReadPrec DetachManagedPolicyFromPermissionSet
Int -> ReadS DetachManagedPolicyFromPermissionSet
ReadS [DetachManagedPolicyFromPermissionSet]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DetachManagedPolicyFromPermissionSet]
$creadListPrec :: ReadPrec [DetachManagedPolicyFromPermissionSet]
readPrec :: ReadPrec DetachManagedPolicyFromPermissionSet
$creadPrec :: ReadPrec DetachManagedPolicyFromPermissionSet
readList :: ReadS [DetachManagedPolicyFromPermissionSet]
$creadList :: ReadS [DetachManagedPolicyFromPermissionSet]
readsPrec :: Int -> ReadS DetachManagedPolicyFromPermissionSet
$creadsPrec :: Int -> ReadS DetachManagedPolicyFromPermissionSet
Prelude.Read, Int -> DetachManagedPolicyFromPermissionSet -> ShowS
[DetachManagedPolicyFromPermissionSet] -> ShowS
DetachManagedPolicyFromPermissionSet -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DetachManagedPolicyFromPermissionSet] -> ShowS
$cshowList :: [DetachManagedPolicyFromPermissionSet] -> ShowS
show :: DetachManagedPolicyFromPermissionSet -> String
$cshow :: DetachManagedPolicyFromPermissionSet -> String
showsPrec :: Int -> DetachManagedPolicyFromPermissionSet -> ShowS
$cshowsPrec :: Int -> DetachManagedPolicyFromPermissionSet -> ShowS
Prelude.Show, forall x.
Rep DetachManagedPolicyFromPermissionSet x
-> DetachManagedPolicyFromPermissionSet
forall x.
DetachManagedPolicyFromPermissionSet
-> Rep DetachManagedPolicyFromPermissionSet x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DetachManagedPolicyFromPermissionSet x
-> DetachManagedPolicyFromPermissionSet
$cfrom :: forall x.
DetachManagedPolicyFromPermissionSet
-> Rep DetachManagedPolicyFromPermissionSet x
Prelude.Generic)
newDetachManagedPolicyFromPermissionSet ::
Prelude.Text ->
Prelude.Text ->
Prelude.Text ->
DetachManagedPolicyFromPermissionSet
newDetachManagedPolicyFromPermissionSet :: Text -> Text -> Text -> DetachManagedPolicyFromPermissionSet
newDetachManagedPolicyFromPermissionSet
Text
pInstanceArn_
Text
pPermissionSetArn_
Text
pManagedPolicyArn_ =
DetachManagedPolicyFromPermissionSet'
{ $sel:instanceArn:DetachManagedPolicyFromPermissionSet' :: Text
instanceArn =
Text
pInstanceArn_,
$sel:permissionSetArn:DetachManagedPolicyFromPermissionSet' :: Text
permissionSetArn = Text
pPermissionSetArn_,
$sel:managedPolicyArn:DetachManagedPolicyFromPermissionSet' :: Text
managedPolicyArn = Text
pManagedPolicyArn_
}
detachManagedPolicyFromPermissionSet_instanceArn :: Lens.Lens' DetachManagedPolicyFromPermissionSet Prelude.Text
detachManagedPolicyFromPermissionSet_instanceArn :: Lens' DetachManagedPolicyFromPermissionSet Text
detachManagedPolicyFromPermissionSet_instanceArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachManagedPolicyFromPermissionSet' {Text
instanceArn :: Text
$sel:instanceArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
instanceArn} -> Text
instanceArn) (\s :: DetachManagedPolicyFromPermissionSet
s@DetachManagedPolicyFromPermissionSet' {} Text
a -> DetachManagedPolicyFromPermissionSet
s {$sel:instanceArn:DetachManagedPolicyFromPermissionSet' :: Text
instanceArn = Text
a} :: DetachManagedPolicyFromPermissionSet)
detachManagedPolicyFromPermissionSet_permissionSetArn :: Lens.Lens' DetachManagedPolicyFromPermissionSet Prelude.Text
detachManagedPolicyFromPermissionSet_permissionSetArn :: Lens' DetachManagedPolicyFromPermissionSet Text
detachManagedPolicyFromPermissionSet_permissionSetArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachManagedPolicyFromPermissionSet' {Text
permissionSetArn :: Text
$sel:permissionSetArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
permissionSetArn} -> Text
permissionSetArn) (\s :: DetachManagedPolicyFromPermissionSet
s@DetachManagedPolicyFromPermissionSet' {} Text
a -> DetachManagedPolicyFromPermissionSet
s {$sel:permissionSetArn:DetachManagedPolicyFromPermissionSet' :: Text
permissionSetArn = Text
a} :: DetachManagedPolicyFromPermissionSet)
detachManagedPolicyFromPermissionSet_managedPolicyArn :: Lens.Lens' DetachManagedPolicyFromPermissionSet Prelude.Text
detachManagedPolicyFromPermissionSet_managedPolicyArn :: Lens' DetachManagedPolicyFromPermissionSet Text
detachManagedPolicyFromPermissionSet_managedPolicyArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachManagedPolicyFromPermissionSet' {Text
managedPolicyArn :: Text
$sel:managedPolicyArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
managedPolicyArn} -> Text
managedPolicyArn) (\s :: DetachManagedPolicyFromPermissionSet
s@DetachManagedPolicyFromPermissionSet' {} Text
a -> DetachManagedPolicyFromPermissionSet
s {$sel:managedPolicyArn:DetachManagedPolicyFromPermissionSet' :: Text
managedPolicyArn = Text
a} :: DetachManagedPolicyFromPermissionSet)
instance
Core.AWSRequest
DetachManagedPolicyFromPermissionSet
where
type
AWSResponse DetachManagedPolicyFromPermissionSet =
DetachManagedPolicyFromPermissionSetResponse
request :: (Service -> Service)
-> DetachManagedPolicyFromPermissionSet
-> Request DetachManagedPolicyFromPermissionSet
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 DetachManagedPolicyFromPermissionSet
-> ClientResponse ClientBody
-> m (Either
Error
(ClientResponse
(AWSResponse DetachManagedPolicyFromPermissionSet)))
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 -> DetachManagedPolicyFromPermissionSetResponse
DetachManagedPolicyFromPermissionSetResponse'
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
DetachManagedPolicyFromPermissionSet
where
hashWithSalt :: Int -> DetachManagedPolicyFromPermissionSet -> Int
hashWithSalt
Int
_salt
DetachManagedPolicyFromPermissionSet' {Text
managedPolicyArn :: Text
permissionSetArn :: Text
instanceArn :: Text
$sel:managedPolicyArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
$sel:permissionSetArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
$sel:instanceArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
instanceArn
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
permissionSetArn
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
managedPolicyArn
instance
Prelude.NFData
DetachManagedPolicyFromPermissionSet
where
rnf :: DetachManagedPolicyFromPermissionSet -> ()
rnf DetachManagedPolicyFromPermissionSet' {Text
managedPolicyArn :: Text
permissionSetArn :: Text
instanceArn :: Text
$sel:managedPolicyArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
$sel:permissionSetArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
$sel:instanceArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
instanceArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
permissionSetArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
managedPolicyArn
instance
Data.ToHeaders
DetachManagedPolicyFromPermissionSet
where
toHeaders :: DetachManagedPolicyFromPermissionSet -> 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
"SWBExternalService.DetachManagedPolicyFromPermissionSet" ::
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
DetachManagedPolicyFromPermissionSet
where
toJSON :: DetachManagedPolicyFromPermissionSet -> Value
toJSON DetachManagedPolicyFromPermissionSet' {Text
managedPolicyArn :: Text
permissionSetArn :: Text
instanceArn :: Text
$sel:managedPolicyArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
$sel:permissionSetArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
$sel:instanceArn:DetachManagedPolicyFromPermissionSet' :: DetachManagedPolicyFromPermissionSet -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just (Key
"InstanceArn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
instanceArn),
forall a. a -> Maybe a
Prelude.Just
(Key
"PermissionSetArn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
permissionSetArn),
forall a. a -> Maybe a
Prelude.Just
(Key
"ManagedPolicyArn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
managedPolicyArn)
]
)
instance
Data.ToPath
DetachManagedPolicyFromPermissionSet
where
toPath :: DetachManagedPolicyFromPermissionSet -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance
Data.ToQuery
DetachManagedPolicyFromPermissionSet
where
toQuery :: DetachManagedPolicyFromPermissionSet -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DetachManagedPolicyFromPermissionSetResponse = DetachManagedPolicyFromPermissionSetResponse'
{
DetachManagedPolicyFromPermissionSetResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DetachManagedPolicyFromPermissionSetResponse
-> DetachManagedPolicyFromPermissionSetResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DetachManagedPolicyFromPermissionSetResponse
-> DetachManagedPolicyFromPermissionSetResponse -> Bool
$c/= :: DetachManagedPolicyFromPermissionSetResponse
-> DetachManagedPolicyFromPermissionSetResponse -> Bool
== :: DetachManagedPolicyFromPermissionSetResponse
-> DetachManagedPolicyFromPermissionSetResponse -> Bool
$c== :: DetachManagedPolicyFromPermissionSetResponse
-> DetachManagedPolicyFromPermissionSetResponse -> Bool
Prelude.Eq, ReadPrec [DetachManagedPolicyFromPermissionSetResponse]
ReadPrec DetachManagedPolicyFromPermissionSetResponse
Int -> ReadS DetachManagedPolicyFromPermissionSetResponse
ReadS [DetachManagedPolicyFromPermissionSetResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DetachManagedPolicyFromPermissionSetResponse]
$creadListPrec :: ReadPrec [DetachManagedPolicyFromPermissionSetResponse]
readPrec :: ReadPrec DetachManagedPolicyFromPermissionSetResponse
$creadPrec :: ReadPrec DetachManagedPolicyFromPermissionSetResponse
readList :: ReadS [DetachManagedPolicyFromPermissionSetResponse]
$creadList :: ReadS [DetachManagedPolicyFromPermissionSetResponse]
readsPrec :: Int -> ReadS DetachManagedPolicyFromPermissionSetResponse
$creadsPrec :: Int -> ReadS DetachManagedPolicyFromPermissionSetResponse
Prelude.Read, Int -> DetachManagedPolicyFromPermissionSetResponse -> ShowS
[DetachManagedPolicyFromPermissionSetResponse] -> ShowS
DetachManagedPolicyFromPermissionSetResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DetachManagedPolicyFromPermissionSetResponse] -> ShowS
$cshowList :: [DetachManagedPolicyFromPermissionSetResponse] -> ShowS
show :: DetachManagedPolicyFromPermissionSetResponse -> String
$cshow :: DetachManagedPolicyFromPermissionSetResponse -> String
showsPrec :: Int -> DetachManagedPolicyFromPermissionSetResponse -> ShowS
$cshowsPrec :: Int -> DetachManagedPolicyFromPermissionSetResponse -> ShowS
Prelude.Show, forall x.
Rep DetachManagedPolicyFromPermissionSetResponse x
-> DetachManagedPolicyFromPermissionSetResponse
forall x.
DetachManagedPolicyFromPermissionSetResponse
-> Rep DetachManagedPolicyFromPermissionSetResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DetachManagedPolicyFromPermissionSetResponse x
-> DetachManagedPolicyFromPermissionSetResponse
$cfrom :: forall x.
DetachManagedPolicyFromPermissionSetResponse
-> Rep DetachManagedPolicyFromPermissionSetResponse x
Prelude.Generic)
newDetachManagedPolicyFromPermissionSetResponse ::
Prelude.Int ->
DetachManagedPolicyFromPermissionSetResponse
newDetachManagedPolicyFromPermissionSetResponse :: Int -> DetachManagedPolicyFromPermissionSetResponse
newDetachManagedPolicyFromPermissionSetResponse
Int
pHttpStatus_ =
DetachManagedPolicyFromPermissionSetResponse'
{ $sel:httpStatus:DetachManagedPolicyFromPermissionSetResponse' :: Int
httpStatus =
Int
pHttpStatus_
}
detachManagedPolicyFromPermissionSetResponse_httpStatus :: Lens.Lens' DetachManagedPolicyFromPermissionSetResponse Prelude.Int
detachManagedPolicyFromPermissionSetResponse_httpStatus :: Lens' DetachManagedPolicyFromPermissionSetResponse Int
detachManagedPolicyFromPermissionSetResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachManagedPolicyFromPermissionSetResponse' {Int
httpStatus :: Int
$sel:httpStatus:DetachManagedPolicyFromPermissionSetResponse' :: DetachManagedPolicyFromPermissionSetResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DetachManagedPolicyFromPermissionSetResponse
s@DetachManagedPolicyFromPermissionSetResponse' {} Int
a -> DetachManagedPolicyFromPermissionSetResponse
s {$sel:httpStatus:DetachManagedPolicyFromPermissionSetResponse' :: Int
httpStatus = Int
a} :: DetachManagedPolicyFromPermissionSetResponse)
instance
Prelude.NFData
DetachManagedPolicyFromPermissionSetResponse
where
rnf :: DetachManagedPolicyFromPermissionSetResponse -> ()
rnf DetachManagedPolicyFromPermissionSetResponse' {Int
httpStatus :: Int
$sel:httpStatus:DetachManagedPolicyFromPermissionSetResponse' :: DetachManagedPolicyFromPermissionSetResponse -> Int
..} =
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus