{-# 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.Transfer.ListAccesses
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Lists the details for all the accesses you have on your server.
--
-- This operation returns paginated results.
module Amazonka.Transfer.ListAccesses
  ( -- * Creating a Request
    ListAccesses (..),
    newListAccesses,

    -- * Request Lenses
    listAccesses_maxResults,
    listAccesses_nextToken,
    listAccesses_serverId,

    -- * Destructuring the Response
    ListAccessesResponse (..),
    newListAccessesResponse,

    -- * Response Lenses
    listAccessesResponse_nextToken,
    listAccessesResponse_httpStatus,
    listAccessesResponse_serverId,
    listAccessesResponse_accesses,
  )
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.Transfer.Types

-- | /See:/ 'newListAccesses' smart constructor.
data ListAccesses = ListAccesses'
  { -- | Specifies the maximum number of access SIDs to return.
    ListAccesses -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
    -- | When you can get additional results from the @ListAccesses@ call, a
    -- @NextToken@ parameter is returned in the output. You can then pass in a
    -- subsequent command to the @NextToken@ parameter to continue listing
    -- additional accesses.
    ListAccesses -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | A system-assigned unique identifier for a server that has users assigned
    -- to it.
    ListAccesses -> Text
serverId :: Prelude.Text
  }
  deriving (ListAccesses -> ListAccesses -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListAccesses -> ListAccesses -> Bool
$c/= :: ListAccesses -> ListAccesses -> Bool
== :: ListAccesses -> ListAccesses -> Bool
$c== :: ListAccesses -> ListAccesses -> Bool
Prelude.Eq, ReadPrec [ListAccesses]
ReadPrec ListAccesses
Int -> ReadS ListAccesses
ReadS [ListAccesses]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListAccesses]
$creadListPrec :: ReadPrec [ListAccesses]
readPrec :: ReadPrec ListAccesses
$creadPrec :: ReadPrec ListAccesses
readList :: ReadS [ListAccesses]
$creadList :: ReadS [ListAccesses]
readsPrec :: Int -> ReadS ListAccesses
$creadsPrec :: Int -> ReadS ListAccesses
Prelude.Read, Int -> ListAccesses -> ShowS
[ListAccesses] -> ShowS
ListAccesses -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListAccesses] -> ShowS
$cshowList :: [ListAccesses] -> ShowS
show :: ListAccesses -> String
$cshow :: ListAccesses -> String
showsPrec :: Int -> ListAccesses -> ShowS
$cshowsPrec :: Int -> ListAccesses -> ShowS
Prelude.Show, forall x. Rep ListAccesses x -> ListAccesses
forall x. ListAccesses -> Rep ListAccesses x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListAccesses x -> ListAccesses
$cfrom :: forall x. ListAccesses -> Rep ListAccesses x
Prelude.Generic)

-- |
-- Create a value of 'ListAccesses' 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:
--
-- 'maxResults', 'listAccesses_maxResults' - Specifies the maximum number of access SIDs to return.
--
-- 'nextToken', 'listAccesses_nextToken' - When you can get additional results from the @ListAccesses@ call, a
-- @NextToken@ parameter is returned in the output. You can then pass in a
-- subsequent command to the @NextToken@ parameter to continue listing
-- additional accesses.
--
-- 'serverId', 'listAccesses_serverId' - A system-assigned unique identifier for a server that has users assigned
-- to it.
newListAccesses ::
  -- | 'serverId'
  Prelude.Text ->
  ListAccesses
newListAccesses :: Text -> ListAccesses
newListAccesses Text
pServerId_ =
  ListAccesses'
    { $sel:maxResults:ListAccesses' :: Maybe Natural
maxResults = forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:ListAccesses' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:serverId:ListAccesses' :: Text
serverId = Text
pServerId_
    }

-- | Specifies the maximum number of access SIDs to return.
listAccesses_maxResults :: Lens.Lens' ListAccesses (Prelude.Maybe Prelude.Natural)
listAccesses_maxResults :: Lens' ListAccesses (Maybe Natural)
listAccesses_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccesses' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:ListAccesses' :: ListAccesses -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: ListAccesses
s@ListAccesses' {} Maybe Natural
a -> ListAccesses
s {$sel:maxResults:ListAccesses' :: Maybe Natural
maxResults = Maybe Natural
a} :: ListAccesses)

-- | When you can get additional results from the @ListAccesses@ call, a
-- @NextToken@ parameter is returned in the output. You can then pass in a
-- subsequent command to the @NextToken@ parameter to continue listing
-- additional accesses.
listAccesses_nextToken :: Lens.Lens' ListAccesses (Prelude.Maybe Prelude.Text)
listAccesses_nextToken :: Lens' ListAccesses (Maybe Text)
listAccesses_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccesses' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListAccesses' :: ListAccesses -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListAccesses
s@ListAccesses' {} Maybe Text
a -> ListAccesses
s {$sel:nextToken:ListAccesses' :: Maybe Text
nextToken = Maybe Text
a} :: ListAccesses)

-- | A system-assigned unique identifier for a server that has users assigned
-- to it.
listAccesses_serverId :: Lens.Lens' ListAccesses Prelude.Text
listAccesses_serverId :: Lens' ListAccesses Text
listAccesses_serverId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccesses' {Text
serverId :: Text
$sel:serverId:ListAccesses' :: ListAccesses -> Text
serverId} -> Text
serverId) (\s :: ListAccesses
s@ListAccesses' {} Text
a -> ListAccesses
s {$sel:serverId:ListAccesses' :: Text
serverId = Text
a} :: ListAccesses)

instance Core.AWSPager ListAccesses where
  page :: ListAccesses -> AWSResponse ListAccesses -> Maybe ListAccesses
page ListAccesses
rq AWSResponse ListAccesses
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse ListAccesses
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListAccessesResponse (Maybe Text)
listAccessesResponse_nextToken
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        (AWSResponse ListAccesses
rs forall s a. s -> Getting a s a -> a
Lens.^. Lens' ListAccessesResponse [ListedAccess]
listAccessesResponse_accesses) =
        forall a. Maybe a
Prelude.Nothing
    | Bool
Prelude.otherwise =
        forall a. a -> Maybe a
Prelude.Just
          forall a b. (a -> b) -> a -> b
Prelude.$ ListAccesses
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' ListAccesses (Maybe Text)
listAccesses_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse ListAccesses
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListAccessesResponse (Maybe Text)
listAccessesResponse_nextToken
          forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just

instance Core.AWSRequest ListAccesses where
  type AWSResponse ListAccesses = ListAccessesResponse
  request :: (Service -> Service) -> ListAccesses -> Request ListAccesses
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 ListAccesses
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse ListAccesses)))
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 -> Int -> Text -> [ListedAccess] -> ListAccessesResponse
ListAccessesResponse'
            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
"NextToken")
            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))
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"ServerId")
            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
"Accesses" forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty)
      )

instance Prelude.Hashable ListAccesses where
  hashWithSalt :: Int -> ListAccesses -> Int
hashWithSalt Int
_salt ListAccesses' {Maybe Natural
Maybe Text
Text
serverId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:serverId:ListAccesses' :: ListAccesses -> Text
$sel:nextToken:ListAccesses' :: ListAccesses -> Maybe Text
$sel:maxResults:ListAccesses' :: ListAccesses -> Maybe Natural
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Natural
maxResults
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
serverId

instance Prelude.NFData ListAccesses where
  rnf :: ListAccesses -> ()
rnf ListAccesses' {Maybe Natural
Maybe Text
Text
serverId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:serverId:ListAccesses' :: ListAccesses -> Text
$sel:nextToken:ListAccesses' :: ListAccesses -> Maybe Text
$sel:maxResults:ListAccesses' :: ListAccesses -> Maybe Natural
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Natural
maxResults
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
serverId

instance Data.ToHeaders ListAccesses where
  toHeaders :: ListAccesses -> 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
"TransferService.ListAccesses" ::
                          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 ListAccesses where
  toJSON :: ListAccesses -> Value
toJSON ListAccesses' {Maybe Natural
Maybe Text
Text
serverId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:serverId:ListAccesses' :: ListAccesses -> Text
$sel:nextToken:ListAccesses' :: ListAccesses -> Maybe Text
$sel:maxResults:ListAccesses' :: ListAccesses -> Maybe Natural
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"MaxResults" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Natural
maxResults,
            (Key
"NextToken" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
nextToken,
            forall a. a -> Maybe a
Prelude.Just (Key
"ServerId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
serverId)
          ]
      )

instance Data.ToPath ListAccesses where
  toPath :: ListAccesses -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

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

-- | /See:/ 'newListAccessesResponse' smart constructor.
data ListAccessesResponse = ListAccessesResponse'
  { -- | When you can get additional results from the @ListAccesses@ call, a
    -- @NextToken@ parameter is returned in the output. You can then pass in a
    -- subsequent command to the @NextToken@ parameter to continue listing
    -- additional accesses.
    ListAccessesResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    ListAccessesResponse -> Int
httpStatus :: Prelude.Int,
    -- | A system-assigned unique identifier for a server that has users assigned
    -- to it.
    ListAccessesResponse -> Text
serverId :: Prelude.Text,
    -- | Returns the accesses and their properties for the @ServerId@ value that
    -- you specify.
    ListAccessesResponse -> [ListedAccess]
accesses :: [ListedAccess]
  }
  deriving (ListAccessesResponse -> ListAccessesResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListAccessesResponse -> ListAccessesResponse -> Bool
$c/= :: ListAccessesResponse -> ListAccessesResponse -> Bool
== :: ListAccessesResponse -> ListAccessesResponse -> Bool
$c== :: ListAccessesResponse -> ListAccessesResponse -> Bool
Prelude.Eq, ReadPrec [ListAccessesResponse]
ReadPrec ListAccessesResponse
Int -> ReadS ListAccessesResponse
ReadS [ListAccessesResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListAccessesResponse]
$creadListPrec :: ReadPrec [ListAccessesResponse]
readPrec :: ReadPrec ListAccessesResponse
$creadPrec :: ReadPrec ListAccessesResponse
readList :: ReadS [ListAccessesResponse]
$creadList :: ReadS [ListAccessesResponse]
readsPrec :: Int -> ReadS ListAccessesResponse
$creadsPrec :: Int -> ReadS ListAccessesResponse
Prelude.Read, Int -> ListAccessesResponse -> ShowS
[ListAccessesResponse] -> ShowS
ListAccessesResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListAccessesResponse] -> ShowS
$cshowList :: [ListAccessesResponse] -> ShowS
show :: ListAccessesResponse -> String
$cshow :: ListAccessesResponse -> String
showsPrec :: Int -> ListAccessesResponse -> ShowS
$cshowsPrec :: Int -> ListAccessesResponse -> ShowS
Prelude.Show, forall x. Rep ListAccessesResponse x -> ListAccessesResponse
forall x. ListAccessesResponse -> Rep ListAccessesResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListAccessesResponse x -> ListAccessesResponse
$cfrom :: forall x. ListAccessesResponse -> Rep ListAccessesResponse x
Prelude.Generic)

-- |
-- Create a value of 'ListAccessesResponse' 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:
--
-- 'nextToken', 'listAccessesResponse_nextToken' - When you can get additional results from the @ListAccesses@ call, a
-- @NextToken@ parameter is returned in the output. You can then pass in a
-- subsequent command to the @NextToken@ parameter to continue listing
-- additional accesses.
--
-- 'httpStatus', 'listAccessesResponse_httpStatus' - The response's http status code.
--
-- 'serverId', 'listAccessesResponse_serverId' - A system-assigned unique identifier for a server that has users assigned
-- to it.
--
-- 'accesses', 'listAccessesResponse_accesses' - Returns the accesses and their properties for the @ServerId@ value that
-- you specify.
newListAccessesResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'serverId'
  Prelude.Text ->
  ListAccessesResponse
newListAccessesResponse :: Int -> Text -> ListAccessesResponse
newListAccessesResponse Int
pHttpStatus_ Text
pServerId_ =
  ListAccessesResponse'
    { $sel:nextToken:ListAccessesResponse' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:ListAccessesResponse' :: Int
httpStatus = Int
pHttpStatus_,
      $sel:serverId:ListAccessesResponse' :: Text
serverId = Text
pServerId_,
      $sel:accesses:ListAccessesResponse' :: [ListedAccess]
accesses = forall a. Monoid a => a
Prelude.mempty
    }

-- | When you can get additional results from the @ListAccesses@ call, a
-- @NextToken@ parameter is returned in the output. You can then pass in a
-- subsequent command to the @NextToken@ parameter to continue listing
-- additional accesses.
listAccessesResponse_nextToken :: Lens.Lens' ListAccessesResponse (Prelude.Maybe Prelude.Text)
listAccessesResponse_nextToken :: Lens' ListAccessesResponse (Maybe Text)
listAccessesResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccessesResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListAccessesResponse' :: ListAccessesResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListAccessesResponse
s@ListAccessesResponse' {} Maybe Text
a -> ListAccessesResponse
s {$sel:nextToken:ListAccessesResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListAccessesResponse)

-- | The response's http status code.
listAccessesResponse_httpStatus :: Lens.Lens' ListAccessesResponse Prelude.Int
listAccessesResponse_httpStatus :: Lens' ListAccessesResponse Int
listAccessesResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccessesResponse' {Int
httpStatus :: Int
$sel:httpStatus:ListAccessesResponse' :: ListAccessesResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: ListAccessesResponse
s@ListAccessesResponse' {} Int
a -> ListAccessesResponse
s {$sel:httpStatus:ListAccessesResponse' :: Int
httpStatus = Int
a} :: ListAccessesResponse)

-- | A system-assigned unique identifier for a server that has users assigned
-- to it.
listAccessesResponse_serverId :: Lens.Lens' ListAccessesResponse Prelude.Text
listAccessesResponse_serverId :: Lens' ListAccessesResponse Text
listAccessesResponse_serverId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccessesResponse' {Text
serverId :: Text
$sel:serverId:ListAccessesResponse' :: ListAccessesResponse -> Text
serverId} -> Text
serverId) (\s :: ListAccessesResponse
s@ListAccessesResponse' {} Text
a -> ListAccessesResponse
s {$sel:serverId:ListAccessesResponse' :: Text
serverId = Text
a} :: ListAccessesResponse)

-- | Returns the accesses and their properties for the @ServerId@ value that
-- you specify.
listAccessesResponse_accesses :: Lens.Lens' ListAccessesResponse [ListedAccess]
listAccessesResponse_accesses :: Lens' ListAccessesResponse [ListedAccess]
listAccessesResponse_accesses = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccessesResponse' {[ListedAccess]
accesses :: [ListedAccess]
$sel:accesses:ListAccessesResponse' :: ListAccessesResponse -> [ListedAccess]
accesses} -> [ListedAccess]
accesses) (\s :: ListAccessesResponse
s@ListAccessesResponse' {} [ListedAccess]
a -> ListAccessesResponse
s {$sel:accesses:ListAccessesResponse' :: [ListedAccess]
accesses = [ListedAccess]
a} :: ListAccessesResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance Prelude.NFData ListAccessesResponse where
  rnf :: ListAccessesResponse -> ()
rnf ListAccessesResponse' {Int
[ListedAccess]
Maybe Text
Text
accesses :: [ListedAccess]
serverId :: Text
httpStatus :: Int
nextToken :: Maybe Text
$sel:accesses:ListAccessesResponse' :: ListAccessesResponse -> [ListedAccess]
$sel:serverId:ListAccessesResponse' :: ListAccessesResponse -> Text
$sel:httpStatus:ListAccessesResponse' :: ListAccessesResponse -> Int
$sel:nextToken:ListAccessesResponse' :: ListAccessesResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
serverId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [ListedAccess]
accesses