{-# 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.DescribeFolderPermissions
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Describes permissions for a folder.
module Amazonka.QuickSight.DescribeFolderPermissions
  ( -- * Creating a Request
    DescribeFolderPermissions (..),
    newDescribeFolderPermissions,

    -- * Request Lenses
    describeFolderPermissions_awsAccountId,
    describeFolderPermissions_folderId,

    -- * Destructuring the Response
    DescribeFolderPermissionsResponse (..),
    newDescribeFolderPermissionsResponse,

    -- * Response Lenses
    describeFolderPermissionsResponse_arn,
    describeFolderPermissionsResponse_folderId,
    describeFolderPermissionsResponse_permissions,
    describeFolderPermissionsResponse_requestId,
    describeFolderPermissionsResponse_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:/ 'newDescribeFolderPermissions' smart constructor.
data DescribeFolderPermissions = DescribeFolderPermissions'
  { -- | The ID for the Amazon Web Services account that contains the folder.
    DescribeFolderPermissions -> Text
awsAccountId :: Prelude.Text,
    -- | The ID of the folder.
    DescribeFolderPermissions -> Text
folderId :: Prelude.Text
  }
  deriving (DescribeFolderPermissions -> DescribeFolderPermissions -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeFolderPermissions -> DescribeFolderPermissions -> Bool
$c/= :: DescribeFolderPermissions -> DescribeFolderPermissions -> Bool
== :: DescribeFolderPermissions -> DescribeFolderPermissions -> Bool
$c== :: DescribeFolderPermissions -> DescribeFolderPermissions -> Bool
Prelude.Eq, ReadPrec [DescribeFolderPermissions]
ReadPrec DescribeFolderPermissions
Int -> ReadS DescribeFolderPermissions
ReadS [DescribeFolderPermissions]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeFolderPermissions]
$creadListPrec :: ReadPrec [DescribeFolderPermissions]
readPrec :: ReadPrec DescribeFolderPermissions
$creadPrec :: ReadPrec DescribeFolderPermissions
readList :: ReadS [DescribeFolderPermissions]
$creadList :: ReadS [DescribeFolderPermissions]
readsPrec :: Int -> ReadS DescribeFolderPermissions
$creadsPrec :: Int -> ReadS DescribeFolderPermissions
Prelude.Read, Int -> DescribeFolderPermissions -> ShowS
[DescribeFolderPermissions] -> ShowS
DescribeFolderPermissions -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeFolderPermissions] -> ShowS
$cshowList :: [DescribeFolderPermissions] -> ShowS
show :: DescribeFolderPermissions -> String
$cshow :: DescribeFolderPermissions -> String
showsPrec :: Int -> DescribeFolderPermissions -> ShowS
$cshowsPrec :: Int -> DescribeFolderPermissions -> ShowS
Prelude.Show, forall x.
Rep DescribeFolderPermissions x -> DescribeFolderPermissions
forall x.
DescribeFolderPermissions -> Rep DescribeFolderPermissions x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeFolderPermissions x -> DescribeFolderPermissions
$cfrom :: forall x.
DescribeFolderPermissions -> Rep DescribeFolderPermissions x
Prelude.Generic)

-- |
-- Create a value of 'DescribeFolderPermissions' 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', 'describeFolderPermissions_awsAccountId' - The ID for the Amazon Web Services account that contains the folder.
--
-- 'folderId', 'describeFolderPermissions_folderId' - The ID of the folder.
newDescribeFolderPermissions ::
  -- | 'awsAccountId'
  Prelude.Text ->
  -- | 'folderId'
  Prelude.Text ->
  DescribeFolderPermissions
newDescribeFolderPermissions :: Text -> Text -> DescribeFolderPermissions
newDescribeFolderPermissions
  Text
pAwsAccountId_
  Text
pFolderId_ =
    DescribeFolderPermissions'
      { $sel:awsAccountId:DescribeFolderPermissions' :: Text
awsAccountId =
          Text
pAwsAccountId_,
        $sel:folderId:DescribeFolderPermissions' :: Text
folderId = Text
pFolderId_
      }

-- | The ID for the Amazon Web Services account that contains the folder.
describeFolderPermissions_awsAccountId :: Lens.Lens' DescribeFolderPermissions Prelude.Text
describeFolderPermissions_awsAccountId :: Lens' DescribeFolderPermissions Text
describeFolderPermissions_awsAccountId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFolderPermissions' {Text
awsAccountId :: Text
$sel:awsAccountId:DescribeFolderPermissions' :: DescribeFolderPermissions -> Text
awsAccountId} -> Text
awsAccountId) (\s :: DescribeFolderPermissions
s@DescribeFolderPermissions' {} Text
a -> DescribeFolderPermissions
s {$sel:awsAccountId:DescribeFolderPermissions' :: Text
awsAccountId = Text
a} :: DescribeFolderPermissions)

-- | The ID of the folder.
describeFolderPermissions_folderId :: Lens.Lens' DescribeFolderPermissions Prelude.Text
describeFolderPermissions_folderId :: Lens' DescribeFolderPermissions Text
describeFolderPermissions_folderId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFolderPermissions' {Text
folderId :: Text
$sel:folderId:DescribeFolderPermissions' :: DescribeFolderPermissions -> Text
folderId} -> Text
folderId) (\s :: DescribeFolderPermissions
s@DescribeFolderPermissions' {} Text
a -> DescribeFolderPermissions
s {$sel:folderId:DescribeFolderPermissions' :: Text
folderId = Text
a} :: DescribeFolderPermissions)

instance Core.AWSRequest DescribeFolderPermissions where
  type
    AWSResponse DescribeFolderPermissions =
      DescribeFolderPermissionsResponse
  request :: (Service -> Service)
-> DescribeFolderPermissions -> Request DescribeFolderPermissions
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.get (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DescribeFolderPermissions
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DescribeFolderPermissions)))
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 (NonEmpty ResourcePermission)
-> Maybe Text
-> Int
-> DescribeFolderPermissionsResponse
DescribeFolderPermissionsResponse'
            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
"Permissions")
            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 DescribeFolderPermissions where
  hashWithSalt :: Int -> DescribeFolderPermissions -> Int
hashWithSalt Int
_salt DescribeFolderPermissions' {Text
folderId :: Text
awsAccountId :: Text
$sel:folderId:DescribeFolderPermissions' :: DescribeFolderPermissions -> Text
$sel:awsAccountId:DescribeFolderPermissions' :: DescribeFolderPermissions -> 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 DescribeFolderPermissions where
  rnf :: DescribeFolderPermissions -> ()
rnf DescribeFolderPermissions' {Text
folderId :: Text
awsAccountId :: Text
$sel:folderId:DescribeFolderPermissions' :: DescribeFolderPermissions -> Text
$sel:awsAccountId:DescribeFolderPermissions' :: DescribeFolderPermissions -> 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 DescribeFolderPermissions where
  toHeaders :: DescribeFolderPermissions -> 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 DescribeFolderPermissions where
  toPath :: DescribeFolderPermissions -> ByteString
toPath DescribeFolderPermissions' {Text
folderId :: Text
awsAccountId :: Text
$sel:folderId:DescribeFolderPermissions' :: DescribeFolderPermissions -> Text
$sel:awsAccountId:DescribeFolderPermissions' :: DescribeFolderPermissions -> 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,
        ByteString
"/permissions"
      ]

instance Data.ToQuery DescribeFolderPermissions where
  toQuery :: DescribeFolderPermissions -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newDescribeFolderPermissionsResponse' smart constructor.
data DescribeFolderPermissionsResponse = DescribeFolderPermissionsResponse'
  { -- | The Amazon Resource Name (ARN) for the folder.
    DescribeFolderPermissionsResponse -> Maybe Text
arn :: Prelude.Maybe Prelude.Text,
    -- | The ID of the folder.
    DescribeFolderPermissionsResponse -> Maybe Text
folderId :: Prelude.Maybe Prelude.Text,
    -- | Information about the permissions on the folder.
    DescribeFolderPermissionsResponse
-> Maybe (NonEmpty ResourcePermission)
permissions :: Prelude.Maybe (Prelude.NonEmpty ResourcePermission),
    -- | The Amazon Web Services request ID for this operation.
    DescribeFolderPermissionsResponse -> Maybe Text
requestId :: Prelude.Maybe Prelude.Text,
    -- | The HTTP status of the request.
    DescribeFolderPermissionsResponse -> Int
status :: Prelude.Int
  }
  deriving (DescribeFolderPermissionsResponse
-> DescribeFolderPermissionsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeFolderPermissionsResponse
-> DescribeFolderPermissionsResponse -> Bool
$c/= :: DescribeFolderPermissionsResponse
-> DescribeFolderPermissionsResponse -> Bool
== :: DescribeFolderPermissionsResponse
-> DescribeFolderPermissionsResponse -> Bool
$c== :: DescribeFolderPermissionsResponse
-> DescribeFolderPermissionsResponse -> Bool
Prelude.Eq, ReadPrec [DescribeFolderPermissionsResponse]
ReadPrec DescribeFolderPermissionsResponse
Int -> ReadS DescribeFolderPermissionsResponse
ReadS [DescribeFolderPermissionsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeFolderPermissionsResponse]
$creadListPrec :: ReadPrec [DescribeFolderPermissionsResponse]
readPrec :: ReadPrec DescribeFolderPermissionsResponse
$creadPrec :: ReadPrec DescribeFolderPermissionsResponse
readList :: ReadS [DescribeFolderPermissionsResponse]
$creadList :: ReadS [DescribeFolderPermissionsResponse]
readsPrec :: Int -> ReadS DescribeFolderPermissionsResponse
$creadsPrec :: Int -> ReadS DescribeFolderPermissionsResponse
Prelude.Read, Int -> DescribeFolderPermissionsResponse -> ShowS
[DescribeFolderPermissionsResponse] -> ShowS
DescribeFolderPermissionsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeFolderPermissionsResponse] -> ShowS
$cshowList :: [DescribeFolderPermissionsResponse] -> ShowS
show :: DescribeFolderPermissionsResponse -> String
$cshow :: DescribeFolderPermissionsResponse -> String
showsPrec :: Int -> DescribeFolderPermissionsResponse -> ShowS
$cshowsPrec :: Int -> DescribeFolderPermissionsResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeFolderPermissionsResponse x
-> DescribeFolderPermissionsResponse
forall x.
DescribeFolderPermissionsResponse
-> Rep DescribeFolderPermissionsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeFolderPermissionsResponse x
-> DescribeFolderPermissionsResponse
$cfrom :: forall x.
DescribeFolderPermissionsResponse
-> Rep DescribeFolderPermissionsResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeFolderPermissionsResponse' 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', 'describeFolderPermissionsResponse_arn' - The Amazon Resource Name (ARN) for the folder.
--
-- 'folderId', 'describeFolderPermissionsResponse_folderId' - The ID of the folder.
--
-- 'permissions', 'describeFolderPermissionsResponse_permissions' - Information about the permissions on the folder.
--
-- 'requestId', 'describeFolderPermissionsResponse_requestId' - The Amazon Web Services request ID for this operation.
--
-- 'status', 'describeFolderPermissionsResponse_status' - The HTTP status of the request.
newDescribeFolderPermissionsResponse ::
  -- | 'status'
  Prelude.Int ->
  DescribeFolderPermissionsResponse
newDescribeFolderPermissionsResponse :: Int -> DescribeFolderPermissionsResponse
newDescribeFolderPermissionsResponse Int
pStatus_ =
  DescribeFolderPermissionsResponse'
    { $sel:arn:DescribeFolderPermissionsResponse' :: Maybe Text
arn =
        forall a. Maybe a
Prelude.Nothing,
      $sel:folderId:DescribeFolderPermissionsResponse' :: Maybe Text
folderId = forall a. Maybe a
Prelude.Nothing,
      $sel:permissions:DescribeFolderPermissionsResponse' :: Maybe (NonEmpty ResourcePermission)
permissions = forall a. Maybe a
Prelude.Nothing,
      $sel:requestId:DescribeFolderPermissionsResponse' :: Maybe Text
requestId = forall a. Maybe a
Prelude.Nothing,
      $sel:status:DescribeFolderPermissionsResponse' :: Int
status = Int
pStatus_
    }

-- | The Amazon Resource Name (ARN) for the folder.
describeFolderPermissionsResponse_arn :: Lens.Lens' DescribeFolderPermissionsResponse (Prelude.Maybe Prelude.Text)
describeFolderPermissionsResponse_arn :: Lens' DescribeFolderPermissionsResponse (Maybe Text)
describeFolderPermissionsResponse_arn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFolderPermissionsResponse' {Maybe Text
arn :: Maybe Text
$sel:arn:DescribeFolderPermissionsResponse' :: DescribeFolderPermissionsResponse -> Maybe Text
arn} -> Maybe Text
arn) (\s :: DescribeFolderPermissionsResponse
s@DescribeFolderPermissionsResponse' {} Maybe Text
a -> DescribeFolderPermissionsResponse
s {$sel:arn:DescribeFolderPermissionsResponse' :: Maybe Text
arn = Maybe Text
a} :: DescribeFolderPermissionsResponse)

-- | The ID of the folder.
describeFolderPermissionsResponse_folderId :: Lens.Lens' DescribeFolderPermissionsResponse (Prelude.Maybe Prelude.Text)
describeFolderPermissionsResponse_folderId :: Lens' DescribeFolderPermissionsResponse (Maybe Text)
describeFolderPermissionsResponse_folderId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFolderPermissionsResponse' {Maybe Text
folderId :: Maybe Text
$sel:folderId:DescribeFolderPermissionsResponse' :: DescribeFolderPermissionsResponse -> Maybe Text
folderId} -> Maybe Text
folderId) (\s :: DescribeFolderPermissionsResponse
s@DescribeFolderPermissionsResponse' {} Maybe Text
a -> DescribeFolderPermissionsResponse
s {$sel:folderId:DescribeFolderPermissionsResponse' :: Maybe Text
folderId = Maybe Text
a} :: DescribeFolderPermissionsResponse)

-- | Information about the permissions on the folder.
describeFolderPermissionsResponse_permissions :: Lens.Lens' DescribeFolderPermissionsResponse (Prelude.Maybe (Prelude.NonEmpty ResourcePermission))
describeFolderPermissionsResponse_permissions :: Lens'
  DescribeFolderPermissionsResponse
  (Maybe (NonEmpty ResourcePermission))
describeFolderPermissionsResponse_permissions = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFolderPermissionsResponse' {Maybe (NonEmpty ResourcePermission)
permissions :: Maybe (NonEmpty ResourcePermission)
$sel:permissions:DescribeFolderPermissionsResponse' :: DescribeFolderPermissionsResponse
-> Maybe (NonEmpty ResourcePermission)
permissions} -> Maybe (NonEmpty ResourcePermission)
permissions) (\s :: DescribeFolderPermissionsResponse
s@DescribeFolderPermissionsResponse' {} Maybe (NonEmpty ResourcePermission)
a -> DescribeFolderPermissionsResponse
s {$sel:permissions:DescribeFolderPermissionsResponse' :: Maybe (NonEmpty ResourcePermission)
permissions = Maybe (NonEmpty ResourcePermission)
a} :: DescribeFolderPermissionsResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | The Amazon Web Services request ID for this operation.
describeFolderPermissionsResponse_requestId :: Lens.Lens' DescribeFolderPermissionsResponse (Prelude.Maybe Prelude.Text)
describeFolderPermissionsResponse_requestId :: Lens' DescribeFolderPermissionsResponse (Maybe Text)
describeFolderPermissionsResponse_requestId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFolderPermissionsResponse' {Maybe Text
requestId :: Maybe Text
$sel:requestId:DescribeFolderPermissionsResponse' :: DescribeFolderPermissionsResponse -> Maybe Text
requestId} -> Maybe Text
requestId) (\s :: DescribeFolderPermissionsResponse
s@DescribeFolderPermissionsResponse' {} Maybe Text
a -> DescribeFolderPermissionsResponse
s {$sel:requestId:DescribeFolderPermissionsResponse' :: Maybe Text
requestId = Maybe Text
a} :: DescribeFolderPermissionsResponse)

-- | The HTTP status of the request.
describeFolderPermissionsResponse_status :: Lens.Lens' DescribeFolderPermissionsResponse Prelude.Int
describeFolderPermissionsResponse_status :: Lens' DescribeFolderPermissionsResponse Int
describeFolderPermissionsResponse_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeFolderPermissionsResponse' {Int
status :: Int
$sel:status:DescribeFolderPermissionsResponse' :: DescribeFolderPermissionsResponse -> Int
status} -> Int
status) (\s :: DescribeFolderPermissionsResponse
s@DescribeFolderPermissionsResponse' {} Int
a -> DescribeFolderPermissionsResponse
s {$sel:status:DescribeFolderPermissionsResponse' :: Int
status = Int
a} :: DescribeFolderPermissionsResponse)

instance
  Prelude.NFData
    DescribeFolderPermissionsResponse
  where
  rnf :: DescribeFolderPermissionsResponse -> ()
rnf DescribeFolderPermissionsResponse' {Int
Maybe (NonEmpty ResourcePermission)
Maybe Text
status :: Int
requestId :: Maybe Text
permissions :: Maybe (NonEmpty ResourcePermission)
folderId :: Maybe Text
arn :: Maybe Text
$sel:status:DescribeFolderPermissionsResponse' :: DescribeFolderPermissionsResponse -> Int
$sel:requestId:DescribeFolderPermissionsResponse' :: DescribeFolderPermissionsResponse -> Maybe Text
$sel:permissions:DescribeFolderPermissionsResponse' :: DescribeFolderPermissionsResponse
-> Maybe (NonEmpty ResourcePermission)
$sel:folderId:DescribeFolderPermissionsResponse' :: DescribeFolderPermissionsResponse -> Maybe Text
$sel:arn:DescribeFolderPermissionsResponse' :: DescribeFolderPermissionsResponse -> 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 (NonEmpty ResourcePermission)
permissions
      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