{-# 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.QuickSight.DeleteFolder
(
DeleteFolder (..),
newDeleteFolder,
deleteFolder_awsAccountId,
deleteFolder_folderId,
DeleteFolderResponse (..),
newDeleteFolderResponse,
deleteFolderResponse_arn,
deleteFolderResponse_folderId,
deleteFolderResponse_requestId,
deleteFolderResponse_status,
)
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 Amazonka.QuickSight.Types
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DeleteFolder = DeleteFolder'
{
DeleteFolder -> Text
awsAccountId :: Prelude.Text,
DeleteFolder -> Text
folderId :: Prelude.Text
}
deriving (DeleteFolder -> DeleteFolder -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteFolder -> DeleteFolder -> Bool
$c/= :: DeleteFolder -> DeleteFolder -> Bool
== :: DeleteFolder -> DeleteFolder -> Bool
$c== :: DeleteFolder -> DeleteFolder -> Bool
Prelude.Eq, ReadPrec [DeleteFolder]
ReadPrec DeleteFolder
Int -> ReadS DeleteFolder
ReadS [DeleteFolder]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteFolder]
$creadListPrec :: ReadPrec [DeleteFolder]
readPrec :: ReadPrec DeleteFolder
$creadPrec :: ReadPrec DeleteFolder
readList :: ReadS [DeleteFolder]
$creadList :: ReadS [DeleteFolder]
readsPrec :: Int -> ReadS DeleteFolder
$creadsPrec :: Int -> ReadS DeleteFolder
Prelude.Read, Int -> DeleteFolder -> ShowS
[DeleteFolder] -> ShowS
DeleteFolder -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteFolder] -> ShowS
$cshowList :: [DeleteFolder] -> ShowS
show :: DeleteFolder -> String
$cshow :: DeleteFolder -> String
showsPrec :: Int -> DeleteFolder -> ShowS
$cshowsPrec :: Int -> DeleteFolder -> ShowS
Prelude.Show, forall x. Rep DeleteFolder x -> DeleteFolder
forall x. DeleteFolder -> Rep DeleteFolder x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteFolder x -> DeleteFolder
$cfrom :: forall x. DeleteFolder -> Rep DeleteFolder x
Prelude.Generic)
newDeleteFolder ::
Prelude.Text ->
Prelude.Text ->
DeleteFolder
newDeleteFolder :: Text -> Text -> DeleteFolder
newDeleteFolder Text
pAwsAccountId_ Text
pFolderId_ =
DeleteFolder'
{ $sel:awsAccountId:DeleteFolder' :: Text
awsAccountId = Text
pAwsAccountId_,
$sel:folderId:DeleteFolder' :: Text
folderId = Text
pFolderId_
}
deleteFolder_awsAccountId :: Lens.Lens' DeleteFolder Prelude.Text
deleteFolder_awsAccountId :: Lens' DeleteFolder Text
deleteFolder_awsAccountId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFolder' {Text
awsAccountId :: Text
$sel:awsAccountId:DeleteFolder' :: DeleteFolder -> Text
awsAccountId} -> Text
awsAccountId) (\s :: DeleteFolder
s@DeleteFolder' {} Text
a -> DeleteFolder
s {$sel:awsAccountId:DeleteFolder' :: Text
awsAccountId = Text
a} :: DeleteFolder)
deleteFolder_folderId :: Lens.Lens' DeleteFolder Prelude.Text
deleteFolder_folderId :: Lens' DeleteFolder Text
deleteFolder_folderId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFolder' {Text
folderId :: Text
$sel:folderId:DeleteFolder' :: DeleteFolder -> Text
folderId} -> Text
folderId) (\s :: DeleteFolder
s@DeleteFolder' {} Text
a -> DeleteFolder
s {$sel:folderId:DeleteFolder' :: Text
folderId = Text
a} :: DeleteFolder)
instance Core.AWSRequest DeleteFolder where
type AWSResponse DeleteFolder = DeleteFolderResponse
request :: (Service -> Service) -> DeleteFolder -> Request DeleteFolder
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 DeleteFolder
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteFolder)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
( \Int
s ResponseHeaders
h Object
x ->
Maybe Text
-> Maybe Text -> Maybe Text -> Int -> DeleteFolderResponse
DeleteFolderResponse'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"Arn")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"FolderId")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"RequestId")
forall (f :: * -> *) a b. Applicative f => 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 DeleteFolder where
hashWithSalt :: Int -> DeleteFolder -> Int
hashWithSalt Int
_salt DeleteFolder' {Text
folderId :: Text
awsAccountId :: Text
$sel:folderId:DeleteFolder' :: DeleteFolder -> Text
$sel:awsAccountId:DeleteFolder' :: DeleteFolder -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
awsAccountId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
folderId
instance Prelude.NFData DeleteFolder where
rnf :: DeleteFolder -> ()
rnf DeleteFolder' {Text
folderId :: Text
awsAccountId :: Text
$sel:folderId:DeleteFolder' :: DeleteFolder -> Text
$sel:awsAccountId:DeleteFolder' :: DeleteFolder -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
awsAccountId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
folderId
instance Data.ToHeaders DeleteFolder where
toHeaders :: DeleteFolder -> 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.0" ::
Prelude.ByteString
)
]
)
instance Data.ToPath DeleteFolder where
toPath :: DeleteFolder -> ByteString
toPath DeleteFolder' {Text
folderId :: Text
awsAccountId :: Text
$sel:folderId:DeleteFolder' :: DeleteFolder -> Text
$sel:awsAccountId:DeleteFolder' :: DeleteFolder -> Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/accounts/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
awsAccountId,
ByteString
"/folders/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
folderId
]
instance Data.ToQuery DeleteFolder where
toQuery :: DeleteFolder -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteFolderResponse = DeleteFolderResponse'
{
DeleteFolderResponse -> Maybe Text
arn :: Prelude.Maybe Prelude.Text,
DeleteFolderResponse -> Maybe Text
folderId :: Prelude.Maybe Prelude.Text,
DeleteFolderResponse -> Maybe Text
requestId :: Prelude.Maybe Prelude.Text,
DeleteFolderResponse -> Int
status :: Prelude.Int
}
deriving (DeleteFolderResponse -> DeleteFolderResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteFolderResponse -> DeleteFolderResponse -> Bool
$c/= :: DeleteFolderResponse -> DeleteFolderResponse -> Bool
== :: DeleteFolderResponse -> DeleteFolderResponse -> Bool
$c== :: DeleteFolderResponse -> DeleteFolderResponse -> Bool
Prelude.Eq, ReadPrec [DeleteFolderResponse]
ReadPrec DeleteFolderResponse
Int -> ReadS DeleteFolderResponse
ReadS [DeleteFolderResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteFolderResponse]
$creadListPrec :: ReadPrec [DeleteFolderResponse]
readPrec :: ReadPrec DeleteFolderResponse
$creadPrec :: ReadPrec DeleteFolderResponse
readList :: ReadS [DeleteFolderResponse]
$creadList :: ReadS [DeleteFolderResponse]
readsPrec :: Int -> ReadS DeleteFolderResponse
$creadsPrec :: Int -> ReadS DeleteFolderResponse
Prelude.Read, Int -> DeleteFolderResponse -> ShowS
[DeleteFolderResponse] -> ShowS
DeleteFolderResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteFolderResponse] -> ShowS
$cshowList :: [DeleteFolderResponse] -> ShowS
show :: DeleteFolderResponse -> String
$cshow :: DeleteFolderResponse -> String
showsPrec :: Int -> DeleteFolderResponse -> ShowS
$cshowsPrec :: Int -> DeleteFolderResponse -> ShowS
Prelude.Show, forall x. Rep DeleteFolderResponse x -> DeleteFolderResponse
forall x. DeleteFolderResponse -> Rep DeleteFolderResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteFolderResponse x -> DeleteFolderResponse
$cfrom :: forall x. DeleteFolderResponse -> Rep DeleteFolderResponse x
Prelude.Generic)
newDeleteFolderResponse ::
Prelude.Int ->
DeleteFolderResponse
newDeleteFolderResponse :: Int -> DeleteFolderResponse
newDeleteFolderResponse Int
pStatus_ =
DeleteFolderResponse'
{ $sel:arn:DeleteFolderResponse' :: Maybe Text
arn = forall a. Maybe a
Prelude.Nothing,
$sel:folderId:DeleteFolderResponse' :: Maybe Text
folderId = forall a. Maybe a
Prelude.Nothing,
$sel:requestId:DeleteFolderResponse' :: Maybe Text
requestId = forall a. Maybe a
Prelude.Nothing,
$sel:status:DeleteFolderResponse' :: Int
status = Int
pStatus_
}
deleteFolderResponse_arn :: Lens.Lens' DeleteFolderResponse (Prelude.Maybe Prelude.Text)
deleteFolderResponse_arn :: Lens' DeleteFolderResponse (Maybe Text)
deleteFolderResponse_arn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFolderResponse' {Maybe Text
arn :: Maybe Text
$sel:arn:DeleteFolderResponse' :: DeleteFolderResponse -> Maybe Text
arn} -> Maybe Text
arn) (\s :: DeleteFolderResponse
s@DeleteFolderResponse' {} Maybe Text
a -> DeleteFolderResponse
s {$sel:arn:DeleteFolderResponse' :: Maybe Text
arn = Maybe Text
a} :: DeleteFolderResponse)
deleteFolderResponse_folderId :: Lens.Lens' DeleteFolderResponse (Prelude.Maybe Prelude.Text)
deleteFolderResponse_folderId :: Lens' DeleteFolderResponse (Maybe Text)
deleteFolderResponse_folderId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFolderResponse' {Maybe Text
folderId :: Maybe Text
$sel:folderId:DeleteFolderResponse' :: DeleteFolderResponse -> Maybe Text
folderId} -> Maybe Text
folderId) (\s :: DeleteFolderResponse
s@DeleteFolderResponse' {} Maybe Text
a -> DeleteFolderResponse
s {$sel:folderId:DeleteFolderResponse' :: Maybe Text
folderId = Maybe Text
a} :: DeleteFolderResponse)
deleteFolderResponse_requestId :: Lens.Lens' DeleteFolderResponse (Prelude.Maybe Prelude.Text)
deleteFolderResponse_requestId :: Lens' DeleteFolderResponse (Maybe Text)
deleteFolderResponse_requestId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFolderResponse' {Maybe Text
requestId :: Maybe Text
$sel:requestId:DeleteFolderResponse' :: DeleteFolderResponse -> Maybe Text
requestId} -> Maybe Text
requestId) (\s :: DeleteFolderResponse
s@DeleteFolderResponse' {} Maybe Text
a -> DeleteFolderResponse
s {$sel:requestId:DeleteFolderResponse' :: Maybe Text
requestId = Maybe Text
a} :: DeleteFolderResponse)
deleteFolderResponse_status :: Lens.Lens' DeleteFolderResponse Prelude.Int
deleteFolderResponse_status :: Lens' DeleteFolderResponse Int
deleteFolderResponse_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteFolderResponse' {Int
status :: Int
$sel:status:DeleteFolderResponse' :: DeleteFolderResponse -> Int
status} -> Int
status) (\s :: DeleteFolderResponse
s@DeleteFolderResponse' {} Int
a -> DeleteFolderResponse
s {$sel:status:DeleteFolderResponse' :: Int
status = Int
a} :: DeleteFolderResponse)
instance Prelude.NFData DeleteFolderResponse where
rnf :: DeleteFolderResponse -> ()
rnf DeleteFolderResponse' {Int
Maybe Text
status :: Int
requestId :: Maybe Text
folderId :: Maybe Text
arn :: Maybe Text
$sel:status:DeleteFolderResponse' :: DeleteFolderResponse -> Int
$sel:requestId:DeleteFolderResponse' :: DeleteFolderResponse -> Maybe Text
$sel:folderId:DeleteFolderResponse' :: DeleteFolderResponse -> Maybe Text
$sel:arn:DeleteFolderResponse' :: DeleteFolderResponse -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
arn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
folderId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
requestId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
status