{-# 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.Athena.ListExecutors
-- 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, in descending order, the executors that have been submitted to a
-- session. Newer executors are listed first; older executors are listed
-- later. The result can be optionally filtered by state.
module Amazonka.Athena.ListExecutors
  ( -- * Creating a Request
    ListExecutors (..),
    newListExecutors,

    -- * Request Lenses
    listExecutors_executorStateFilter,
    listExecutors_maxResults,
    listExecutors_nextToken,
    listExecutors_sessionId,

    -- * Destructuring the Response
    ListExecutorsResponse (..),
    newListExecutorsResponse,

    -- * Response Lenses
    listExecutorsResponse_executorsSummary,
    listExecutorsResponse_nextToken,
    listExecutorsResponse_httpStatus,
    listExecutorsResponse_sessionId,
  )
where

import Amazonka.Athena.Types
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

-- | /See:/ 'newListExecutors' smart constructor.
data ListExecutors = ListExecutors'
  { -- | A filter for a specific executor state. A description of each state
    -- follows.
    --
    -- @CREATING@ - The executor is being started, including acquiring
    -- resources.
    --
    -- @CREATED@ - The executor has been started.
    --
    -- @REGISTERED@ - The executor has been registered.
    --
    -- @TERMINATING@ - The executor is in the process of shutting down.
    --
    -- @TERMINATED@ - The executor is no longer running.
    --
    -- @FAILED@ - Due to a failure, the executor is no longer running.
    ListExecutors -> Maybe ExecutorState
executorStateFilter :: Prelude.Maybe ExecutorState,
    -- | The maximum number of executors to return.
    ListExecutors -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
    -- | A token generated by the Athena service that specifies where to continue
    -- pagination if a previous request was truncated. To obtain the next set
    -- of pages, pass in the @NextToken@ from the response object of the
    -- previous page call.
    ListExecutors -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The session ID.
    ListExecutors -> Text
sessionId :: Prelude.Text
  }
  deriving (ListExecutors -> ListExecutors -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListExecutors -> ListExecutors -> Bool
$c/= :: ListExecutors -> ListExecutors -> Bool
== :: ListExecutors -> ListExecutors -> Bool
$c== :: ListExecutors -> ListExecutors -> Bool
Prelude.Eq, ReadPrec [ListExecutors]
ReadPrec ListExecutors
Int -> ReadS ListExecutors
ReadS [ListExecutors]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListExecutors]
$creadListPrec :: ReadPrec [ListExecutors]
readPrec :: ReadPrec ListExecutors
$creadPrec :: ReadPrec ListExecutors
readList :: ReadS [ListExecutors]
$creadList :: ReadS [ListExecutors]
readsPrec :: Int -> ReadS ListExecutors
$creadsPrec :: Int -> ReadS ListExecutors
Prelude.Read, Int -> ListExecutors -> ShowS
[ListExecutors] -> ShowS
ListExecutors -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListExecutors] -> ShowS
$cshowList :: [ListExecutors] -> ShowS
show :: ListExecutors -> String
$cshow :: ListExecutors -> String
showsPrec :: Int -> ListExecutors -> ShowS
$cshowsPrec :: Int -> ListExecutors -> ShowS
Prelude.Show, forall x. Rep ListExecutors x -> ListExecutors
forall x. ListExecutors -> Rep ListExecutors x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListExecutors x -> ListExecutors
$cfrom :: forall x. ListExecutors -> Rep ListExecutors x
Prelude.Generic)

-- |
-- Create a value of 'ListExecutors' 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:
--
-- 'executorStateFilter', 'listExecutors_executorStateFilter' - A filter for a specific executor state. A description of each state
-- follows.
--
-- @CREATING@ - The executor is being started, including acquiring
-- resources.
--
-- @CREATED@ - The executor has been started.
--
-- @REGISTERED@ - The executor has been registered.
--
-- @TERMINATING@ - The executor is in the process of shutting down.
--
-- @TERMINATED@ - The executor is no longer running.
--
-- @FAILED@ - Due to a failure, the executor is no longer running.
--
-- 'maxResults', 'listExecutors_maxResults' - The maximum number of executors to return.
--
-- 'nextToken', 'listExecutors_nextToken' - A token generated by the Athena service that specifies where to continue
-- pagination if a previous request was truncated. To obtain the next set
-- of pages, pass in the @NextToken@ from the response object of the
-- previous page call.
--
-- 'sessionId', 'listExecutors_sessionId' - The session ID.
newListExecutors ::
  -- | 'sessionId'
  Prelude.Text ->
  ListExecutors
newListExecutors :: Text -> ListExecutors
newListExecutors Text
pSessionId_ =
  ListExecutors'
    { $sel:executorStateFilter:ListExecutors' :: Maybe ExecutorState
executorStateFilter =
        forall a. Maybe a
Prelude.Nothing,
      $sel:maxResults:ListExecutors' :: Maybe Natural
maxResults = forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:ListExecutors' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:sessionId:ListExecutors' :: Text
sessionId = Text
pSessionId_
    }

-- | A filter for a specific executor state. A description of each state
-- follows.
--
-- @CREATING@ - The executor is being started, including acquiring
-- resources.
--
-- @CREATED@ - The executor has been started.
--
-- @REGISTERED@ - The executor has been registered.
--
-- @TERMINATING@ - The executor is in the process of shutting down.
--
-- @TERMINATED@ - The executor is no longer running.
--
-- @FAILED@ - Due to a failure, the executor is no longer running.
listExecutors_executorStateFilter :: Lens.Lens' ListExecutors (Prelude.Maybe ExecutorState)
listExecutors_executorStateFilter :: Lens' ListExecutors (Maybe ExecutorState)
listExecutors_executorStateFilter = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListExecutors' {Maybe ExecutorState
executorStateFilter :: Maybe ExecutorState
$sel:executorStateFilter:ListExecutors' :: ListExecutors -> Maybe ExecutorState
executorStateFilter} -> Maybe ExecutorState
executorStateFilter) (\s :: ListExecutors
s@ListExecutors' {} Maybe ExecutorState
a -> ListExecutors
s {$sel:executorStateFilter:ListExecutors' :: Maybe ExecutorState
executorStateFilter = Maybe ExecutorState
a} :: ListExecutors)

-- | The maximum number of executors to return.
listExecutors_maxResults :: Lens.Lens' ListExecutors (Prelude.Maybe Prelude.Natural)
listExecutors_maxResults :: Lens' ListExecutors (Maybe Natural)
listExecutors_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListExecutors' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:ListExecutors' :: ListExecutors -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: ListExecutors
s@ListExecutors' {} Maybe Natural
a -> ListExecutors
s {$sel:maxResults:ListExecutors' :: Maybe Natural
maxResults = Maybe Natural
a} :: ListExecutors)

-- | A token generated by the Athena service that specifies where to continue
-- pagination if a previous request was truncated. To obtain the next set
-- of pages, pass in the @NextToken@ from the response object of the
-- previous page call.
listExecutors_nextToken :: Lens.Lens' ListExecutors (Prelude.Maybe Prelude.Text)
listExecutors_nextToken :: Lens' ListExecutors (Maybe Text)
listExecutors_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListExecutors' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListExecutors' :: ListExecutors -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListExecutors
s@ListExecutors' {} Maybe Text
a -> ListExecutors
s {$sel:nextToken:ListExecutors' :: Maybe Text
nextToken = Maybe Text
a} :: ListExecutors)

-- | The session ID.
listExecutors_sessionId :: Lens.Lens' ListExecutors Prelude.Text
listExecutors_sessionId :: Lens' ListExecutors Text
listExecutors_sessionId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListExecutors' {Text
sessionId :: Text
$sel:sessionId:ListExecutors' :: ListExecutors -> Text
sessionId} -> Text
sessionId) (\s :: ListExecutors
s@ListExecutors' {} Text
a -> ListExecutors
s {$sel:sessionId:ListExecutors' :: Text
sessionId = Text
a} :: ListExecutors)

instance Core.AWSRequest ListExecutors where
  type
    AWSResponse ListExecutors =
      ListExecutorsResponse
  request :: (Service -> Service) -> ListExecutors -> Request ListExecutors
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 ListExecutors
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse ListExecutors)))
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 [ExecutorsSummary]
-> Maybe Text -> Int -> Text -> ListExecutorsResponse
ListExecutorsResponse'
            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
"ExecutorsSummary"
                            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))
            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
"SessionId")
      )

instance Prelude.Hashable ListExecutors where
  hashWithSalt :: Int -> ListExecutors -> Int
hashWithSalt Int
_salt ListExecutors' {Maybe Natural
Maybe Text
Maybe ExecutorState
Text
sessionId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
executorStateFilter :: Maybe ExecutorState
$sel:sessionId:ListExecutors' :: ListExecutors -> Text
$sel:nextToken:ListExecutors' :: ListExecutors -> Maybe Text
$sel:maxResults:ListExecutors' :: ListExecutors -> Maybe Natural
$sel:executorStateFilter:ListExecutors' :: ListExecutors -> Maybe ExecutorState
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ExecutorState
executorStateFilter
      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
sessionId

instance Prelude.NFData ListExecutors where
  rnf :: ListExecutors -> ()
rnf ListExecutors' {Maybe Natural
Maybe Text
Maybe ExecutorState
Text
sessionId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
executorStateFilter :: Maybe ExecutorState
$sel:sessionId:ListExecutors' :: ListExecutors -> Text
$sel:nextToken:ListExecutors' :: ListExecutors -> Maybe Text
$sel:maxResults:ListExecutors' :: ListExecutors -> Maybe Natural
$sel:executorStateFilter:ListExecutors' :: ListExecutors -> Maybe ExecutorState
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe ExecutorState
executorStateFilter
      seq :: forall a b. a -> b -> b
`Prelude.seq` 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
sessionId

instance Data.ToHeaders ListExecutors where
  toHeaders :: ListExecutors -> 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
"AmazonAthena.ListExecutors" :: 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 ListExecutors where
  toJSON :: ListExecutors -> Value
toJSON ListExecutors' {Maybe Natural
Maybe Text
Maybe ExecutorState
Text
sessionId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
executorStateFilter :: Maybe ExecutorState
$sel:sessionId:ListExecutors' :: ListExecutors -> Text
$sel:nextToken:ListExecutors' :: ListExecutors -> Maybe Text
$sel:maxResults:ListExecutors' :: ListExecutors -> Maybe Natural
$sel:executorStateFilter:ListExecutors' :: ListExecutors -> Maybe ExecutorState
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"ExecutorStateFilter" 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 ExecutorState
executorStateFilter,
            (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
"SessionId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
sessionId)
          ]
      )

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

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

-- | /See:/ 'newListExecutorsResponse' smart constructor.
data ListExecutorsResponse = ListExecutorsResponse'
  { -- | Contains summary information about the executor.
    ListExecutorsResponse -> Maybe [ExecutorsSummary]
executorsSummary :: Prelude.Maybe [ExecutorsSummary],
    -- | A token generated by the Athena service that specifies where to continue
    -- pagination if a previous request was truncated. To obtain the next set
    -- of pages, pass in the @NextToken@ from the response object of the
    -- previous page call.
    ListExecutorsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    ListExecutorsResponse -> Int
httpStatus :: Prelude.Int,
    -- | The session ID.
    ListExecutorsResponse -> Text
sessionId :: Prelude.Text
  }
  deriving (ListExecutorsResponse -> ListExecutorsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListExecutorsResponse -> ListExecutorsResponse -> Bool
$c/= :: ListExecutorsResponse -> ListExecutorsResponse -> Bool
== :: ListExecutorsResponse -> ListExecutorsResponse -> Bool
$c== :: ListExecutorsResponse -> ListExecutorsResponse -> Bool
Prelude.Eq, ReadPrec [ListExecutorsResponse]
ReadPrec ListExecutorsResponse
Int -> ReadS ListExecutorsResponse
ReadS [ListExecutorsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListExecutorsResponse]
$creadListPrec :: ReadPrec [ListExecutorsResponse]
readPrec :: ReadPrec ListExecutorsResponse
$creadPrec :: ReadPrec ListExecutorsResponse
readList :: ReadS [ListExecutorsResponse]
$creadList :: ReadS [ListExecutorsResponse]
readsPrec :: Int -> ReadS ListExecutorsResponse
$creadsPrec :: Int -> ReadS ListExecutorsResponse
Prelude.Read, Int -> ListExecutorsResponse -> ShowS
[ListExecutorsResponse] -> ShowS
ListExecutorsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListExecutorsResponse] -> ShowS
$cshowList :: [ListExecutorsResponse] -> ShowS
show :: ListExecutorsResponse -> String
$cshow :: ListExecutorsResponse -> String
showsPrec :: Int -> ListExecutorsResponse -> ShowS
$cshowsPrec :: Int -> ListExecutorsResponse -> ShowS
Prelude.Show, forall x. Rep ListExecutorsResponse x -> ListExecutorsResponse
forall x. ListExecutorsResponse -> Rep ListExecutorsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListExecutorsResponse x -> ListExecutorsResponse
$cfrom :: forall x. ListExecutorsResponse -> Rep ListExecutorsResponse x
Prelude.Generic)

-- |
-- Create a value of 'ListExecutorsResponse' 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:
--
-- 'executorsSummary', 'listExecutorsResponse_executorsSummary' - Contains summary information about the executor.
--
-- 'nextToken', 'listExecutorsResponse_nextToken' - A token generated by the Athena service that specifies where to continue
-- pagination if a previous request was truncated. To obtain the next set
-- of pages, pass in the @NextToken@ from the response object of the
-- previous page call.
--
-- 'httpStatus', 'listExecutorsResponse_httpStatus' - The response's http status code.
--
-- 'sessionId', 'listExecutorsResponse_sessionId' - The session ID.
newListExecutorsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'sessionId'
  Prelude.Text ->
  ListExecutorsResponse
newListExecutorsResponse :: Int -> Text -> ListExecutorsResponse
newListExecutorsResponse Int
pHttpStatus_ Text
pSessionId_ =
  ListExecutorsResponse'
    { $sel:executorsSummary:ListExecutorsResponse' :: Maybe [ExecutorsSummary]
executorsSummary =
        forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:ListExecutorsResponse' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:ListExecutorsResponse' :: Int
httpStatus = Int
pHttpStatus_,
      $sel:sessionId:ListExecutorsResponse' :: Text
sessionId = Text
pSessionId_
    }

-- | Contains summary information about the executor.
listExecutorsResponse_executorsSummary :: Lens.Lens' ListExecutorsResponse (Prelude.Maybe [ExecutorsSummary])
listExecutorsResponse_executorsSummary :: Lens' ListExecutorsResponse (Maybe [ExecutorsSummary])
listExecutorsResponse_executorsSummary = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListExecutorsResponse' {Maybe [ExecutorsSummary]
executorsSummary :: Maybe [ExecutorsSummary]
$sel:executorsSummary:ListExecutorsResponse' :: ListExecutorsResponse -> Maybe [ExecutorsSummary]
executorsSummary} -> Maybe [ExecutorsSummary]
executorsSummary) (\s :: ListExecutorsResponse
s@ListExecutorsResponse' {} Maybe [ExecutorsSummary]
a -> ListExecutorsResponse
s {$sel:executorsSummary:ListExecutorsResponse' :: Maybe [ExecutorsSummary]
executorsSummary = Maybe [ExecutorsSummary]
a} :: ListExecutorsResponse) 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

-- | A token generated by the Athena service that specifies where to continue
-- pagination if a previous request was truncated. To obtain the next set
-- of pages, pass in the @NextToken@ from the response object of the
-- previous page call.
listExecutorsResponse_nextToken :: Lens.Lens' ListExecutorsResponse (Prelude.Maybe Prelude.Text)
listExecutorsResponse_nextToken :: Lens' ListExecutorsResponse (Maybe Text)
listExecutorsResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListExecutorsResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListExecutorsResponse' :: ListExecutorsResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListExecutorsResponse
s@ListExecutorsResponse' {} Maybe Text
a -> ListExecutorsResponse
s {$sel:nextToken:ListExecutorsResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListExecutorsResponse)

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

-- | The session ID.
listExecutorsResponse_sessionId :: Lens.Lens' ListExecutorsResponse Prelude.Text
listExecutorsResponse_sessionId :: Lens' ListExecutorsResponse Text
listExecutorsResponse_sessionId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListExecutorsResponse' {Text
sessionId :: Text
$sel:sessionId:ListExecutorsResponse' :: ListExecutorsResponse -> Text
sessionId} -> Text
sessionId) (\s :: ListExecutorsResponse
s@ListExecutorsResponse' {} Text
a -> ListExecutorsResponse
s {$sel:sessionId:ListExecutorsResponse' :: Text
sessionId = Text
a} :: ListExecutorsResponse)

instance Prelude.NFData ListExecutorsResponse where
  rnf :: ListExecutorsResponse -> ()
rnf ListExecutorsResponse' {Int
Maybe [ExecutorsSummary]
Maybe Text
Text
sessionId :: Text
httpStatus :: Int
nextToken :: Maybe Text
executorsSummary :: Maybe [ExecutorsSummary]
$sel:sessionId:ListExecutorsResponse' :: ListExecutorsResponse -> Text
$sel:httpStatus:ListExecutorsResponse' :: ListExecutorsResponse -> Int
$sel:nextToken:ListExecutorsResponse' :: ListExecutorsResponse -> Maybe Text
$sel:executorsSummary:ListExecutorsResponse' :: ListExecutorsResponse -> Maybe [ExecutorsSummary]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [ExecutorsSummary]
executorsSummary
      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
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
sessionId