{-# 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.Glue.ListStatements
-- 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 statements for the session.
module Amazonka.Glue.ListStatements
  ( -- * Creating a Request
    ListStatements (..),
    newListStatements,

    -- * Request Lenses
    listStatements_nextToken,
    listStatements_requestOrigin,
    listStatements_sessionId,

    -- * Destructuring the Response
    ListStatementsResponse (..),
    newListStatementsResponse,

    -- * Response Lenses
    listStatementsResponse_nextToken,
    listStatementsResponse_statements,
    listStatementsResponse_httpStatus,
  )
where

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

-- | /See:/ 'newListStatements' smart constructor.
data ListStatements = ListStatements'
  { -- | A continuation token, if this is a continuation call.
    ListStatements -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The origin of the request to list statements.
    ListStatements -> Maybe Text
requestOrigin :: Prelude.Maybe Prelude.Text,
    -- | The Session ID of the statements.
    ListStatements -> Text
sessionId :: Prelude.Text
  }
  deriving (ListStatements -> ListStatements -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListStatements -> ListStatements -> Bool
$c/= :: ListStatements -> ListStatements -> Bool
== :: ListStatements -> ListStatements -> Bool
$c== :: ListStatements -> ListStatements -> Bool
Prelude.Eq, ReadPrec [ListStatements]
ReadPrec ListStatements
Int -> ReadS ListStatements
ReadS [ListStatements]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListStatements]
$creadListPrec :: ReadPrec [ListStatements]
readPrec :: ReadPrec ListStatements
$creadPrec :: ReadPrec ListStatements
readList :: ReadS [ListStatements]
$creadList :: ReadS [ListStatements]
readsPrec :: Int -> ReadS ListStatements
$creadsPrec :: Int -> ReadS ListStatements
Prelude.Read, Int -> ListStatements -> ShowS
[ListStatements] -> ShowS
ListStatements -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListStatements] -> ShowS
$cshowList :: [ListStatements] -> ShowS
show :: ListStatements -> String
$cshow :: ListStatements -> String
showsPrec :: Int -> ListStatements -> ShowS
$cshowsPrec :: Int -> ListStatements -> ShowS
Prelude.Show, forall x. Rep ListStatements x -> ListStatements
forall x. ListStatements -> Rep ListStatements x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListStatements x -> ListStatements
$cfrom :: forall x. ListStatements -> Rep ListStatements x
Prelude.Generic)

-- |
-- Create a value of 'ListStatements' 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', 'listStatements_nextToken' - A continuation token, if this is a continuation call.
--
-- 'requestOrigin', 'listStatements_requestOrigin' - The origin of the request to list statements.
--
-- 'sessionId', 'listStatements_sessionId' - The Session ID of the statements.
newListStatements ::
  -- | 'sessionId'
  Prelude.Text ->
  ListStatements
newListStatements :: Text -> ListStatements
newListStatements Text
pSessionId_ =
  ListStatements'
    { $sel:nextToken:ListStatements' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:requestOrigin:ListStatements' :: Maybe Text
requestOrigin = forall a. Maybe a
Prelude.Nothing,
      $sel:sessionId:ListStatements' :: Text
sessionId = Text
pSessionId_
    }

-- | A continuation token, if this is a continuation call.
listStatements_nextToken :: Lens.Lens' ListStatements (Prelude.Maybe Prelude.Text)
listStatements_nextToken :: Lens' ListStatements (Maybe Text)
listStatements_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListStatements' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListStatements' :: ListStatements -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListStatements
s@ListStatements' {} Maybe Text
a -> ListStatements
s {$sel:nextToken:ListStatements' :: Maybe Text
nextToken = Maybe Text
a} :: ListStatements)

-- | The origin of the request to list statements.
listStatements_requestOrigin :: Lens.Lens' ListStatements (Prelude.Maybe Prelude.Text)
listStatements_requestOrigin :: Lens' ListStatements (Maybe Text)
listStatements_requestOrigin = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListStatements' {Maybe Text
requestOrigin :: Maybe Text
$sel:requestOrigin:ListStatements' :: ListStatements -> Maybe Text
requestOrigin} -> Maybe Text
requestOrigin) (\s :: ListStatements
s@ListStatements' {} Maybe Text
a -> ListStatements
s {$sel:requestOrigin:ListStatements' :: Maybe Text
requestOrigin = Maybe Text
a} :: ListStatements)

-- | The Session ID of the statements.
listStatements_sessionId :: Lens.Lens' ListStatements Prelude.Text
listStatements_sessionId :: Lens' ListStatements Text
listStatements_sessionId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListStatements' {Text
sessionId :: Text
$sel:sessionId:ListStatements' :: ListStatements -> Text
sessionId} -> Text
sessionId) (\s :: ListStatements
s@ListStatements' {} Text
a -> ListStatements
s {$sel:sessionId:ListStatements' :: Text
sessionId = Text
a} :: ListStatements)

instance Core.AWSRequest ListStatements where
  type
    AWSResponse ListStatements =
      ListStatementsResponse
  request :: (Service -> Service) -> ListStatements -> Request ListStatements
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 ListStatements
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse ListStatements)))
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 [Statement] -> Int -> ListStatementsResponse
ListStatementsResponse'
            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.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"Statements" 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.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
      )

instance Prelude.Hashable ListStatements where
  hashWithSalt :: Int -> ListStatements -> Int
hashWithSalt Int
_salt ListStatements' {Maybe Text
Text
sessionId :: Text
requestOrigin :: Maybe Text
nextToken :: Maybe Text
$sel:sessionId:ListStatements' :: ListStatements -> Text
$sel:requestOrigin:ListStatements' :: ListStatements -> Maybe Text
$sel:nextToken:ListStatements' :: ListStatements -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
requestOrigin
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
sessionId

instance Prelude.NFData ListStatements where
  rnf :: ListStatements -> ()
rnf ListStatements' {Maybe Text
Text
sessionId :: Text
requestOrigin :: Maybe Text
nextToken :: Maybe Text
$sel:sessionId:ListStatements' :: ListStatements -> Text
$sel:requestOrigin:ListStatements' :: ListStatements -> Maybe Text
$sel:nextToken:ListStatements' :: ListStatements -> 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 Maybe Text
requestOrigin
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
sessionId

instance Data.ToHeaders ListStatements where
  toHeaders :: ListStatements -> 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
"AWSGlue.ListStatements" :: 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 ListStatements where
  toJSON :: ListStatements -> Value
toJSON ListStatements' {Maybe Text
Text
sessionId :: Text
requestOrigin :: Maybe Text
nextToken :: Maybe Text
$sel:sessionId:ListStatements' :: ListStatements -> Text
$sel:requestOrigin:ListStatements' :: ListStatements -> Maybe Text
$sel:nextToken:ListStatements' :: ListStatements -> Maybe Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (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,
            (Key
"RequestOrigin" 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
requestOrigin,
            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 ListStatements where
  toPath :: ListStatements -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

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

-- | /See:/ 'newListStatementsResponse' smart constructor.
data ListStatementsResponse = ListStatementsResponse'
  { -- | A continuation token, if not all statements have yet been returned.
    ListStatementsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | Returns the list of statements.
    ListStatementsResponse -> Maybe [Statement]
statements :: Prelude.Maybe [Statement],
    -- | The response's http status code.
    ListStatementsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (ListStatementsResponse -> ListStatementsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListStatementsResponse -> ListStatementsResponse -> Bool
$c/= :: ListStatementsResponse -> ListStatementsResponse -> Bool
== :: ListStatementsResponse -> ListStatementsResponse -> Bool
$c== :: ListStatementsResponse -> ListStatementsResponse -> Bool
Prelude.Eq, ReadPrec [ListStatementsResponse]
ReadPrec ListStatementsResponse
Int -> ReadS ListStatementsResponse
ReadS [ListStatementsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListStatementsResponse]
$creadListPrec :: ReadPrec [ListStatementsResponse]
readPrec :: ReadPrec ListStatementsResponse
$creadPrec :: ReadPrec ListStatementsResponse
readList :: ReadS [ListStatementsResponse]
$creadList :: ReadS [ListStatementsResponse]
readsPrec :: Int -> ReadS ListStatementsResponse
$creadsPrec :: Int -> ReadS ListStatementsResponse
Prelude.Read, Int -> ListStatementsResponse -> ShowS
[ListStatementsResponse] -> ShowS
ListStatementsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListStatementsResponse] -> ShowS
$cshowList :: [ListStatementsResponse] -> ShowS
show :: ListStatementsResponse -> String
$cshow :: ListStatementsResponse -> String
showsPrec :: Int -> ListStatementsResponse -> ShowS
$cshowsPrec :: Int -> ListStatementsResponse -> ShowS
Prelude.Show, forall x. Rep ListStatementsResponse x -> ListStatementsResponse
forall x. ListStatementsResponse -> Rep ListStatementsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListStatementsResponse x -> ListStatementsResponse
$cfrom :: forall x. ListStatementsResponse -> Rep ListStatementsResponse x
Prelude.Generic)

-- |
-- Create a value of 'ListStatementsResponse' 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', 'listStatementsResponse_nextToken' - A continuation token, if not all statements have yet been returned.
--
-- 'statements', 'listStatementsResponse_statements' - Returns the list of statements.
--
-- 'httpStatus', 'listStatementsResponse_httpStatus' - The response's http status code.
newListStatementsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  ListStatementsResponse
newListStatementsResponse :: Int -> ListStatementsResponse
newListStatementsResponse Int
pHttpStatus_ =
  ListStatementsResponse'
    { $sel:nextToken:ListStatementsResponse' :: Maybe Text
nextToken =
        forall a. Maybe a
Prelude.Nothing,
      $sel:statements:ListStatementsResponse' :: Maybe [Statement]
statements = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:ListStatementsResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | A continuation token, if not all statements have yet been returned.
listStatementsResponse_nextToken :: Lens.Lens' ListStatementsResponse (Prelude.Maybe Prelude.Text)
listStatementsResponse_nextToken :: Lens' ListStatementsResponse (Maybe Text)
listStatementsResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListStatementsResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListStatementsResponse' :: ListStatementsResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListStatementsResponse
s@ListStatementsResponse' {} Maybe Text
a -> ListStatementsResponse
s {$sel:nextToken:ListStatementsResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListStatementsResponse)

-- | Returns the list of statements.
listStatementsResponse_statements :: Lens.Lens' ListStatementsResponse (Prelude.Maybe [Statement])
listStatementsResponse_statements :: Lens' ListStatementsResponse (Maybe [Statement])
listStatementsResponse_statements = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListStatementsResponse' {Maybe [Statement]
statements :: Maybe [Statement]
$sel:statements:ListStatementsResponse' :: ListStatementsResponse -> Maybe [Statement]
statements} -> Maybe [Statement]
statements) (\s :: ListStatementsResponse
s@ListStatementsResponse' {} Maybe [Statement]
a -> ListStatementsResponse
s {$sel:statements:ListStatementsResponse' :: Maybe [Statement]
statements = Maybe [Statement]
a} :: ListStatementsResponse) 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 response's http status code.
listStatementsResponse_httpStatus :: Lens.Lens' ListStatementsResponse Prelude.Int
listStatementsResponse_httpStatus :: Lens' ListStatementsResponse Int
listStatementsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListStatementsResponse' {Int
httpStatus :: Int
$sel:httpStatus:ListStatementsResponse' :: ListStatementsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: ListStatementsResponse
s@ListStatementsResponse' {} Int
a -> ListStatementsResponse
s {$sel:httpStatus:ListStatementsResponse' :: Int
httpStatus = Int
a} :: ListStatementsResponse)

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