{-# 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.FMS.ListMemberAccounts
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Returns a @MemberAccounts@ object that lists the member accounts in the
-- administrator\'s Amazon Web Services organization.
--
-- The @ListMemberAccounts@ must be submitted by the account that is set as
-- the Firewall Manager administrator.
--
-- This operation returns paginated results.
module Amazonka.FMS.ListMemberAccounts
  ( -- * Creating a Request
    ListMemberAccounts (..),
    newListMemberAccounts,

    -- * Request Lenses
    listMemberAccounts_maxResults,
    listMemberAccounts_nextToken,

    -- * Destructuring the Response
    ListMemberAccountsResponse (..),
    newListMemberAccountsResponse,

    -- * Response Lenses
    listMemberAccountsResponse_memberAccounts,
    listMemberAccountsResponse_nextToken,
    listMemberAccountsResponse_httpStatus,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.FMS.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newListMemberAccounts' smart constructor.
data ListMemberAccounts = ListMemberAccounts'
  { -- | Specifies the number of member account IDs that you want Firewall
    -- Manager to return for this request. If you have more IDs than the number
    -- that you specify for @MaxResults@, the response includes a @NextToken@
    -- value that you can use to get another batch of member account IDs.
    ListMemberAccounts -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
    -- | If you specify a value for @MaxResults@ and you have more account IDs
    -- than the number that you specify for @MaxResults@, Firewall Manager
    -- returns a @NextToken@ value in the response that allows you to list
    -- another group of IDs. For the second and subsequent
    -- @ListMemberAccountsRequest@ requests, specify the value of @NextToken@
    -- from the previous response to get information about another batch of
    -- member account IDs.
    ListMemberAccounts -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text
  }
  deriving (ListMemberAccounts -> ListMemberAccounts -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListMemberAccounts -> ListMemberAccounts -> Bool
$c/= :: ListMemberAccounts -> ListMemberAccounts -> Bool
== :: ListMemberAccounts -> ListMemberAccounts -> Bool
$c== :: ListMemberAccounts -> ListMemberAccounts -> Bool
Prelude.Eq, ReadPrec [ListMemberAccounts]
ReadPrec ListMemberAccounts
Int -> ReadS ListMemberAccounts
ReadS [ListMemberAccounts]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListMemberAccounts]
$creadListPrec :: ReadPrec [ListMemberAccounts]
readPrec :: ReadPrec ListMemberAccounts
$creadPrec :: ReadPrec ListMemberAccounts
readList :: ReadS [ListMemberAccounts]
$creadList :: ReadS [ListMemberAccounts]
readsPrec :: Int -> ReadS ListMemberAccounts
$creadsPrec :: Int -> ReadS ListMemberAccounts
Prelude.Read, Int -> ListMemberAccounts -> ShowS
[ListMemberAccounts] -> ShowS
ListMemberAccounts -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListMemberAccounts] -> ShowS
$cshowList :: [ListMemberAccounts] -> ShowS
show :: ListMemberAccounts -> String
$cshow :: ListMemberAccounts -> String
showsPrec :: Int -> ListMemberAccounts -> ShowS
$cshowsPrec :: Int -> ListMemberAccounts -> ShowS
Prelude.Show, forall x. Rep ListMemberAccounts x -> ListMemberAccounts
forall x. ListMemberAccounts -> Rep ListMemberAccounts x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListMemberAccounts x -> ListMemberAccounts
$cfrom :: forall x. ListMemberAccounts -> Rep ListMemberAccounts x
Prelude.Generic)

-- |
-- Create a value of 'ListMemberAccounts' 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', 'listMemberAccounts_maxResults' - Specifies the number of member account IDs that you want Firewall
-- Manager to return for this request. If you have more IDs than the number
-- that you specify for @MaxResults@, the response includes a @NextToken@
-- value that you can use to get another batch of member account IDs.
--
-- 'nextToken', 'listMemberAccounts_nextToken' - If you specify a value for @MaxResults@ and you have more account IDs
-- than the number that you specify for @MaxResults@, Firewall Manager
-- returns a @NextToken@ value in the response that allows you to list
-- another group of IDs. For the second and subsequent
-- @ListMemberAccountsRequest@ requests, specify the value of @NextToken@
-- from the previous response to get information about another batch of
-- member account IDs.
newListMemberAccounts ::
  ListMemberAccounts
newListMemberAccounts :: ListMemberAccounts
newListMemberAccounts =
  ListMemberAccounts'
    { $sel:maxResults:ListMemberAccounts' :: Maybe Natural
maxResults = forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:ListMemberAccounts' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing
    }

-- | Specifies the number of member account IDs that you want Firewall
-- Manager to return for this request. If you have more IDs than the number
-- that you specify for @MaxResults@, the response includes a @NextToken@
-- value that you can use to get another batch of member account IDs.
listMemberAccounts_maxResults :: Lens.Lens' ListMemberAccounts (Prelude.Maybe Prelude.Natural)
listMemberAccounts_maxResults :: Lens' ListMemberAccounts (Maybe Natural)
listMemberAccounts_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListMemberAccounts' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:ListMemberAccounts' :: ListMemberAccounts -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: ListMemberAccounts
s@ListMemberAccounts' {} Maybe Natural
a -> ListMemberAccounts
s {$sel:maxResults:ListMemberAccounts' :: Maybe Natural
maxResults = Maybe Natural
a} :: ListMemberAccounts)

-- | If you specify a value for @MaxResults@ and you have more account IDs
-- than the number that you specify for @MaxResults@, Firewall Manager
-- returns a @NextToken@ value in the response that allows you to list
-- another group of IDs. For the second and subsequent
-- @ListMemberAccountsRequest@ requests, specify the value of @NextToken@
-- from the previous response to get information about another batch of
-- member account IDs.
listMemberAccounts_nextToken :: Lens.Lens' ListMemberAccounts (Prelude.Maybe Prelude.Text)
listMemberAccounts_nextToken :: Lens' ListMemberAccounts (Maybe Text)
listMemberAccounts_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListMemberAccounts' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListMemberAccounts' :: ListMemberAccounts -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListMemberAccounts
s@ListMemberAccounts' {} Maybe Text
a -> ListMemberAccounts
s {$sel:nextToken:ListMemberAccounts' :: Maybe Text
nextToken = Maybe Text
a} :: ListMemberAccounts)

instance Core.AWSPager ListMemberAccounts where
  page :: ListMemberAccounts
-> AWSResponse ListMemberAccounts -> Maybe ListMemberAccounts
page ListMemberAccounts
rq AWSResponse ListMemberAccounts
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse ListMemberAccounts
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListMemberAccountsResponse (Maybe Text)
listMemberAccountsResponse_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 ListMemberAccounts
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListMemberAccountsResponse (Maybe [Text])
listMemberAccountsResponse_memberAccounts
            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
    | Bool
Prelude.otherwise =
        forall a. a -> Maybe a
Prelude.Just
          forall a b. (a -> b) -> a -> b
Prelude.$ ListMemberAccounts
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' ListMemberAccounts (Maybe Text)
listMemberAccounts_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse ListMemberAccounts
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListMemberAccountsResponse (Maybe Text)
listMemberAccountsResponse_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 ListMemberAccounts where
  type
    AWSResponse ListMemberAccounts =
      ListMemberAccountsResponse
  request :: (Service -> Service)
-> ListMemberAccounts -> Request ListMemberAccounts
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 ListMemberAccounts
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse ListMemberAccounts)))
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 -> Int -> ListMemberAccountsResponse
ListMemberAccountsResponse'
            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
"MemberAccounts" forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty)
            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
"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))
      )

instance Prelude.Hashable ListMemberAccounts where
  hashWithSalt :: Int -> ListMemberAccounts -> Int
hashWithSalt Int
_salt ListMemberAccounts' {Maybe Natural
Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:nextToken:ListMemberAccounts' :: ListMemberAccounts -> Maybe Text
$sel:maxResults:ListMemberAccounts' :: ListMemberAccounts -> 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

instance Prelude.NFData ListMemberAccounts where
  rnf :: ListMemberAccounts -> ()
rnf ListMemberAccounts' {Maybe Natural
Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:nextToken:ListMemberAccounts' :: ListMemberAccounts -> Maybe Text
$sel:maxResults:ListMemberAccounts' :: ListMemberAccounts -> 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

instance Data.ToHeaders ListMemberAccounts where
  toHeaders :: ListMemberAccounts -> 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
"AWSFMS_20180101.ListMemberAccounts" ::
                          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 ListMemberAccounts where
  toJSON :: ListMemberAccounts -> Value
toJSON ListMemberAccounts' {Maybe Natural
Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:nextToken:ListMemberAccounts' :: ListMemberAccounts -> Maybe Text
$sel:maxResults:ListMemberAccounts' :: ListMemberAccounts -> 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
          ]
      )

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

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

-- | /See:/ 'newListMemberAccountsResponse' smart constructor.
data ListMemberAccountsResponse = ListMemberAccountsResponse'
  { -- | An array of account IDs.
    ListMemberAccountsResponse -> Maybe [Text]
memberAccounts :: Prelude.Maybe [Prelude.Text],
    -- | If you have more member account IDs than the number that you specified
    -- for @MaxResults@ in the request, the response includes a @NextToken@
    -- value. To list more IDs, submit another @ListMemberAccounts@ request,
    -- and specify the @NextToken@ value from the response in the @NextToken@
    -- value in the next request.
    ListMemberAccountsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    ListMemberAccountsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (ListMemberAccountsResponse -> ListMemberAccountsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListMemberAccountsResponse -> ListMemberAccountsResponse -> Bool
$c/= :: ListMemberAccountsResponse -> ListMemberAccountsResponse -> Bool
== :: ListMemberAccountsResponse -> ListMemberAccountsResponse -> Bool
$c== :: ListMemberAccountsResponse -> ListMemberAccountsResponse -> Bool
Prelude.Eq, ReadPrec [ListMemberAccountsResponse]
ReadPrec ListMemberAccountsResponse
Int -> ReadS ListMemberAccountsResponse
ReadS [ListMemberAccountsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListMemberAccountsResponse]
$creadListPrec :: ReadPrec [ListMemberAccountsResponse]
readPrec :: ReadPrec ListMemberAccountsResponse
$creadPrec :: ReadPrec ListMemberAccountsResponse
readList :: ReadS [ListMemberAccountsResponse]
$creadList :: ReadS [ListMemberAccountsResponse]
readsPrec :: Int -> ReadS ListMemberAccountsResponse
$creadsPrec :: Int -> ReadS ListMemberAccountsResponse
Prelude.Read, Int -> ListMemberAccountsResponse -> ShowS
[ListMemberAccountsResponse] -> ShowS
ListMemberAccountsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListMemberAccountsResponse] -> ShowS
$cshowList :: [ListMemberAccountsResponse] -> ShowS
show :: ListMemberAccountsResponse -> String
$cshow :: ListMemberAccountsResponse -> String
showsPrec :: Int -> ListMemberAccountsResponse -> ShowS
$cshowsPrec :: Int -> ListMemberAccountsResponse -> ShowS
Prelude.Show, forall x.
Rep ListMemberAccountsResponse x -> ListMemberAccountsResponse
forall x.
ListMemberAccountsResponse -> Rep ListMemberAccountsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ListMemberAccountsResponse x -> ListMemberAccountsResponse
$cfrom :: forall x.
ListMemberAccountsResponse -> Rep ListMemberAccountsResponse x
Prelude.Generic)

-- |
-- Create a value of 'ListMemberAccountsResponse' 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:
--
-- 'memberAccounts', 'listMemberAccountsResponse_memberAccounts' - An array of account IDs.
--
-- 'nextToken', 'listMemberAccountsResponse_nextToken' - If you have more member account IDs than the number that you specified
-- for @MaxResults@ in the request, the response includes a @NextToken@
-- value. To list more IDs, submit another @ListMemberAccounts@ request,
-- and specify the @NextToken@ value from the response in the @NextToken@
-- value in the next request.
--
-- 'httpStatus', 'listMemberAccountsResponse_httpStatus' - The response's http status code.
newListMemberAccountsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  ListMemberAccountsResponse
newListMemberAccountsResponse :: Int -> ListMemberAccountsResponse
newListMemberAccountsResponse Int
pHttpStatus_ =
  ListMemberAccountsResponse'
    { $sel:memberAccounts:ListMemberAccountsResponse' :: Maybe [Text]
memberAccounts =
        forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:ListMemberAccountsResponse' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:ListMemberAccountsResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | An array of account IDs.
listMemberAccountsResponse_memberAccounts :: Lens.Lens' ListMemberAccountsResponse (Prelude.Maybe [Prelude.Text])
listMemberAccountsResponse_memberAccounts :: Lens' ListMemberAccountsResponse (Maybe [Text])
listMemberAccountsResponse_memberAccounts = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListMemberAccountsResponse' {Maybe [Text]
memberAccounts :: Maybe [Text]
$sel:memberAccounts:ListMemberAccountsResponse' :: ListMemberAccountsResponse -> Maybe [Text]
memberAccounts} -> Maybe [Text]
memberAccounts) (\s :: ListMemberAccountsResponse
s@ListMemberAccountsResponse' {} Maybe [Text]
a -> ListMemberAccountsResponse
s {$sel:memberAccounts:ListMemberAccountsResponse' :: Maybe [Text]
memberAccounts = Maybe [Text]
a} :: ListMemberAccountsResponse) 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

-- | If you have more member account IDs than the number that you specified
-- for @MaxResults@ in the request, the response includes a @NextToken@
-- value. To list more IDs, submit another @ListMemberAccounts@ request,
-- and specify the @NextToken@ value from the response in the @NextToken@
-- value in the next request.
listMemberAccountsResponse_nextToken :: Lens.Lens' ListMemberAccountsResponse (Prelude.Maybe Prelude.Text)
listMemberAccountsResponse_nextToken :: Lens' ListMemberAccountsResponse (Maybe Text)
listMemberAccountsResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListMemberAccountsResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListMemberAccountsResponse' :: ListMemberAccountsResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListMemberAccountsResponse
s@ListMemberAccountsResponse' {} Maybe Text
a -> ListMemberAccountsResponse
s {$sel:nextToken:ListMemberAccountsResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListMemberAccountsResponse)

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

instance Prelude.NFData ListMemberAccountsResponse where
  rnf :: ListMemberAccountsResponse -> ()
rnf ListMemberAccountsResponse' {Int
Maybe [Text]
Maybe Text
httpStatus :: Int
nextToken :: Maybe Text
memberAccounts :: Maybe [Text]
$sel:httpStatus:ListMemberAccountsResponse' :: ListMemberAccountsResponse -> Int
$sel:nextToken:ListMemberAccountsResponse' :: ListMemberAccountsResponse -> Maybe Text
$sel:memberAccounts:ListMemberAccountsResponse' :: ListMemberAccountsResponse -> Maybe [Text]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
memberAccounts
      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 Int
httpStatus