{-# 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 #-}
module Amazonka.Athena.ListExecutors
(
ListExecutors (..),
newListExecutors,
listExecutors_executorStateFilter,
listExecutors_maxResults,
listExecutors_nextToken,
listExecutors_sessionId,
ListExecutorsResponse (..),
newListExecutorsResponse,
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
data ListExecutors = ListExecutors'
{
ListExecutors -> Maybe ExecutorState
executorStateFilter :: Prelude.Maybe ExecutorState,
ListExecutors -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
ListExecutors -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
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)
newListExecutors ::
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_
}
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)
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)
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)
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
data ListExecutorsResponse = ListExecutorsResponse'
{
:: Prelude.Maybe [ExecutorsSummary],
ListExecutorsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
ListExecutorsResponse -> Int
httpStatus :: Prelude.Int,
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)
newListExecutorsResponse ::
Prelude.Int ->
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_
}
listExecutorsResponse_executorsSummary :: Lens.Lens' ListExecutorsResponse (Prelude.Maybe [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
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)
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)
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