{-# 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 #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.QuickSight.DeleteFolder
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Deletes an empty folder.
module Amazonka.QuickSight.DeleteFolder
  ( -- * Creating a Request
    DeleteFolder (..),
    newDeleteFolder,

    -- * Request Lenses
    deleteFolder_awsAccountId,
    deleteFolder_folderId,

    -- * Destructuring the Response
    DeleteFolderResponse (..),
    newDeleteFolderResponse,

    -- * Response Lenses
    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

-- | /See:/ 'newDeleteFolder' smart constructor.
data DeleteFolder = DeleteFolder'
  { -- | The ID for the Amazon Web Services account that contains the folder.
    DeleteFolder -> Text
awsAccountId :: Prelude.Text,
    -- | The ID of the folder.
    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)

-- |
-- Create a value of 'DeleteFolder' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'awsAccountId', 'deleteFolder_awsAccountId' - The ID for the Amazon Web Services account that contains the folder.
--
-- 'folderId', 'deleteFolder_folderId' - The ID of the folder.
newDeleteFolder ::
  -- | 'awsAccountId'
  Prelude.Text ->
  -- | 'folderId'
  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_
    }

-- | The ID for the Amazon Web Services account that contains the folder.
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)

-- | The ID of the folder.
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

-- | /See:/ 'newDeleteFolderResponse' smart constructor.
data DeleteFolderResponse = DeleteFolderResponse'
  { -- | The Amazon Resource Name of the deleted folder.
    DeleteFolderResponse -> Maybe Text
arn :: Prelude.Maybe Prelude.Text,
    -- | The ID of the folder.
    DeleteFolderResponse -> Maybe Text
folderId :: Prelude.Maybe Prelude.Text,
    -- | The Amazon Web Services request ID for this operation.
    DeleteFolderResponse -> Maybe Text
requestId :: Prelude.Maybe Prelude.Text,
    -- | The HTTP status of the request.
    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)

-- |
-- Create a value of 'DeleteFolderResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'arn', 'deleteFolderResponse_arn' - The Amazon Resource Name of the deleted folder.
--
-- 'folderId', 'deleteFolderResponse_folderId' - The ID of the folder.
--
-- 'requestId', 'deleteFolderResponse_requestId' - The Amazon Web Services request ID for this operation.
--
-- 'status', 'deleteFolderResponse_status' - The HTTP status of the request.
newDeleteFolderResponse ::
  -- | 'status'
  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_
    }

-- | The Amazon Resource Name of the deleted folder.
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)

-- | The ID of the folder.
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)

-- | The Amazon Web Services request ID for this operation.
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)

-- | The HTTP status of the request.
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