{-# 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.EMRContainers.ListManagedEndpoints
-- 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 managed endpoints based on a set of parameters. A managed endpoint
-- is a gateway that connects EMR Studio to Amazon EMR on EKS so that EMR
-- Studio can communicate with your virtual cluster.
--
-- This operation returns paginated results.
module Amazonka.EMRContainers.ListManagedEndpoints
  ( -- * Creating a Request
    ListManagedEndpoints (..),
    newListManagedEndpoints,

    -- * Request Lenses
    listManagedEndpoints_createdAfter,
    listManagedEndpoints_createdBefore,
    listManagedEndpoints_maxResults,
    listManagedEndpoints_nextToken,
    listManagedEndpoints_states,
    listManagedEndpoints_types,
    listManagedEndpoints_virtualClusterId,

    -- * Destructuring the Response
    ListManagedEndpointsResponse (..),
    newListManagedEndpointsResponse,

    -- * Response Lenses
    listManagedEndpointsResponse_endpoints,
    listManagedEndpointsResponse_nextToken,
    listManagedEndpointsResponse_httpStatus,
  )
where

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

-- | /See:/ 'newListManagedEndpoints' smart constructor.
data ListManagedEndpoints = ListManagedEndpoints'
  { -- | The date and time after which the endpoints are created.
    ListManagedEndpoints -> Maybe ISO8601
createdAfter :: Prelude.Maybe Data.ISO8601,
    -- | The date and time before which the endpoints are created.
    ListManagedEndpoints -> Maybe ISO8601
createdBefore :: Prelude.Maybe Data.ISO8601,
    -- | The maximum number of managed endpoints that can be listed.
    ListManagedEndpoints -> Maybe Int
maxResults :: Prelude.Maybe Prelude.Int,
    -- | The token for the next set of managed endpoints to return.
    ListManagedEndpoints -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The states of the managed endpoints.
    ListManagedEndpoints -> Maybe [EndpointState]
states :: Prelude.Maybe [EndpointState],
    -- | The types of the managed endpoints.
    ListManagedEndpoints -> Maybe [Text]
types :: Prelude.Maybe [Prelude.Text],
    -- | The ID of the virtual cluster.
    ListManagedEndpoints -> Text
virtualClusterId :: Prelude.Text
  }
  deriving (ListManagedEndpoints -> ListManagedEndpoints -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListManagedEndpoints -> ListManagedEndpoints -> Bool
$c/= :: ListManagedEndpoints -> ListManagedEndpoints -> Bool
== :: ListManagedEndpoints -> ListManagedEndpoints -> Bool
$c== :: ListManagedEndpoints -> ListManagedEndpoints -> Bool
Prelude.Eq, ReadPrec [ListManagedEndpoints]
ReadPrec ListManagedEndpoints
Int -> ReadS ListManagedEndpoints
ReadS [ListManagedEndpoints]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListManagedEndpoints]
$creadListPrec :: ReadPrec [ListManagedEndpoints]
readPrec :: ReadPrec ListManagedEndpoints
$creadPrec :: ReadPrec ListManagedEndpoints
readList :: ReadS [ListManagedEndpoints]
$creadList :: ReadS [ListManagedEndpoints]
readsPrec :: Int -> ReadS ListManagedEndpoints
$creadsPrec :: Int -> ReadS ListManagedEndpoints
Prelude.Read, Int -> ListManagedEndpoints -> ShowS
[ListManagedEndpoints] -> ShowS
ListManagedEndpoints -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListManagedEndpoints] -> ShowS
$cshowList :: [ListManagedEndpoints] -> ShowS
show :: ListManagedEndpoints -> String
$cshow :: ListManagedEndpoints -> String
showsPrec :: Int -> ListManagedEndpoints -> ShowS
$cshowsPrec :: Int -> ListManagedEndpoints -> ShowS
Prelude.Show, forall x. Rep ListManagedEndpoints x -> ListManagedEndpoints
forall x. ListManagedEndpoints -> Rep ListManagedEndpoints x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListManagedEndpoints x -> ListManagedEndpoints
$cfrom :: forall x. ListManagedEndpoints -> Rep ListManagedEndpoints x
Prelude.Generic)

-- |
-- Create a value of 'ListManagedEndpoints' 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:
--
-- 'createdAfter', 'listManagedEndpoints_createdAfter' - The date and time after which the endpoints are created.
--
-- 'createdBefore', 'listManagedEndpoints_createdBefore' - The date and time before which the endpoints are created.
--
-- 'maxResults', 'listManagedEndpoints_maxResults' - The maximum number of managed endpoints that can be listed.
--
-- 'nextToken', 'listManagedEndpoints_nextToken' - The token for the next set of managed endpoints to return.
--
-- 'states', 'listManagedEndpoints_states' - The states of the managed endpoints.
--
-- 'types', 'listManagedEndpoints_types' - The types of the managed endpoints.
--
-- 'virtualClusterId', 'listManagedEndpoints_virtualClusterId' - The ID of the virtual cluster.
newListManagedEndpoints ::
  -- | 'virtualClusterId'
  Prelude.Text ->
  ListManagedEndpoints
newListManagedEndpoints :: Text -> ListManagedEndpoints
newListManagedEndpoints Text
pVirtualClusterId_ =
  ListManagedEndpoints'
    { $sel:createdAfter:ListManagedEndpoints' :: Maybe ISO8601
createdAfter =
        forall a. Maybe a
Prelude.Nothing,
      $sel:createdBefore:ListManagedEndpoints' :: Maybe ISO8601
createdBefore = forall a. Maybe a
Prelude.Nothing,
      $sel:maxResults:ListManagedEndpoints' :: Maybe Int
maxResults = forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:ListManagedEndpoints' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:states:ListManagedEndpoints' :: Maybe [EndpointState]
states = forall a. Maybe a
Prelude.Nothing,
      $sel:types:ListManagedEndpoints' :: Maybe [Text]
types = forall a. Maybe a
Prelude.Nothing,
      $sel:virtualClusterId:ListManagedEndpoints' :: Text
virtualClusterId = Text
pVirtualClusterId_
    }

-- | The date and time after which the endpoints are created.
listManagedEndpoints_createdAfter :: Lens.Lens' ListManagedEndpoints (Prelude.Maybe Prelude.UTCTime)
listManagedEndpoints_createdAfter :: Lens' ListManagedEndpoints (Maybe UTCTime)
listManagedEndpoints_createdAfter = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListManagedEndpoints' {Maybe ISO8601
createdAfter :: Maybe ISO8601
$sel:createdAfter:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe ISO8601
createdAfter} -> Maybe ISO8601
createdAfter) (\s :: ListManagedEndpoints
s@ListManagedEndpoints' {} Maybe ISO8601
a -> ListManagedEndpoints
s {$sel:createdAfter:ListManagedEndpoints' :: Maybe ISO8601
createdAfter = Maybe ISO8601
a} :: ListManagedEndpoints) 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 (a :: Format). Iso' (Time a) UTCTime
Data._Time

-- | The date and time before which the endpoints are created.
listManagedEndpoints_createdBefore :: Lens.Lens' ListManagedEndpoints (Prelude.Maybe Prelude.UTCTime)
listManagedEndpoints_createdBefore :: Lens' ListManagedEndpoints (Maybe UTCTime)
listManagedEndpoints_createdBefore = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListManagedEndpoints' {Maybe ISO8601
createdBefore :: Maybe ISO8601
$sel:createdBefore:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe ISO8601
createdBefore} -> Maybe ISO8601
createdBefore) (\s :: ListManagedEndpoints
s@ListManagedEndpoints' {} Maybe ISO8601
a -> ListManagedEndpoints
s {$sel:createdBefore:ListManagedEndpoints' :: Maybe ISO8601
createdBefore = Maybe ISO8601
a} :: ListManagedEndpoints) 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 (a :: Format). Iso' (Time a) UTCTime
Data._Time

-- | The maximum number of managed endpoints that can be listed.
listManagedEndpoints_maxResults :: Lens.Lens' ListManagedEndpoints (Prelude.Maybe Prelude.Int)
listManagedEndpoints_maxResults :: Lens' ListManagedEndpoints (Maybe Int)
listManagedEndpoints_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListManagedEndpoints' {Maybe Int
maxResults :: Maybe Int
$sel:maxResults:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe Int
maxResults} -> Maybe Int
maxResults) (\s :: ListManagedEndpoints
s@ListManagedEndpoints' {} Maybe Int
a -> ListManagedEndpoints
s {$sel:maxResults:ListManagedEndpoints' :: Maybe Int
maxResults = Maybe Int
a} :: ListManagedEndpoints)

-- | The token for the next set of managed endpoints to return.
listManagedEndpoints_nextToken :: Lens.Lens' ListManagedEndpoints (Prelude.Maybe Prelude.Text)
listManagedEndpoints_nextToken :: Lens' ListManagedEndpoints (Maybe Text)
listManagedEndpoints_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListManagedEndpoints' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListManagedEndpoints
s@ListManagedEndpoints' {} Maybe Text
a -> ListManagedEndpoints
s {$sel:nextToken:ListManagedEndpoints' :: Maybe Text
nextToken = Maybe Text
a} :: ListManagedEndpoints)

-- | The states of the managed endpoints.
listManagedEndpoints_states :: Lens.Lens' ListManagedEndpoints (Prelude.Maybe [EndpointState])
listManagedEndpoints_states :: Lens' ListManagedEndpoints (Maybe [EndpointState])
listManagedEndpoints_states = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListManagedEndpoints' {Maybe [EndpointState]
states :: Maybe [EndpointState]
$sel:states:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe [EndpointState]
states} -> Maybe [EndpointState]
states) (\s :: ListManagedEndpoints
s@ListManagedEndpoints' {} Maybe [EndpointState]
a -> ListManagedEndpoints
s {$sel:states:ListManagedEndpoints' :: Maybe [EndpointState]
states = Maybe [EndpointState]
a} :: ListManagedEndpoints) 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 types of the managed endpoints.
listManagedEndpoints_types :: Lens.Lens' ListManagedEndpoints (Prelude.Maybe [Prelude.Text])
listManagedEndpoints_types :: Lens' ListManagedEndpoints (Maybe [Text])
listManagedEndpoints_types = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListManagedEndpoints' {Maybe [Text]
types :: Maybe [Text]
$sel:types:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe [Text]
types} -> Maybe [Text]
types) (\s :: ListManagedEndpoints
s@ListManagedEndpoints' {} Maybe [Text]
a -> ListManagedEndpoints
s {$sel:types:ListManagedEndpoints' :: Maybe [Text]
types = Maybe [Text]
a} :: ListManagedEndpoints) 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 ID of the virtual cluster.
listManagedEndpoints_virtualClusterId :: Lens.Lens' ListManagedEndpoints Prelude.Text
listManagedEndpoints_virtualClusterId :: Lens' ListManagedEndpoints Text
listManagedEndpoints_virtualClusterId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListManagedEndpoints' {Text
virtualClusterId :: Text
$sel:virtualClusterId:ListManagedEndpoints' :: ListManagedEndpoints -> Text
virtualClusterId} -> Text
virtualClusterId) (\s :: ListManagedEndpoints
s@ListManagedEndpoints' {} Text
a -> ListManagedEndpoints
s {$sel:virtualClusterId:ListManagedEndpoints' :: Text
virtualClusterId = Text
a} :: ListManagedEndpoints)

instance Core.AWSPager ListManagedEndpoints where
  page :: ListManagedEndpoints
-> AWSResponse ListManagedEndpoints -> Maybe ListManagedEndpoints
page ListManagedEndpoints
rq AWSResponse ListManagedEndpoints
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse ListManagedEndpoints
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListManagedEndpointsResponse (Maybe Text)
listManagedEndpointsResponse_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 ListManagedEndpoints
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListManagedEndpointsResponse (Maybe [Endpoint])
listManagedEndpointsResponse_endpoints
            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.$ ListManagedEndpoints
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' ListManagedEndpoints (Maybe Text)
listManagedEndpoints_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse ListManagedEndpoints
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListManagedEndpointsResponse (Maybe Text)
listManagedEndpointsResponse_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 ListManagedEndpoints where
  type
    AWSResponse ListManagedEndpoints =
      ListManagedEndpointsResponse
  request :: (Service -> Service)
-> ListManagedEndpoints -> Request ListManagedEndpoints
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.get (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy ListManagedEndpoints
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse ListManagedEndpoints)))
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 [Endpoint]
-> Maybe Text -> Int -> ListManagedEndpointsResponse
ListManagedEndpointsResponse'
            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
"endpoints" 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 ListManagedEndpoints where
  hashWithSalt :: Int -> ListManagedEndpoints -> Int
hashWithSalt Int
_salt ListManagedEndpoints' {Maybe Int
Maybe [Text]
Maybe [EndpointState]
Maybe Text
Maybe ISO8601
Text
virtualClusterId :: Text
types :: Maybe [Text]
states :: Maybe [EndpointState]
nextToken :: Maybe Text
maxResults :: Maybe Int
createdBefore :: Maybe ISO8601
createdAfter :: Maybe ISO8601
$sel:virtualClusterId:ListManagedEndpoints' :: ListManagedEndpoints -> Text
$sel:types:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe [Text]
$sel:states:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe [EndpointState]
$sel:nextToken:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe Text
$sel:maxResults:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe Int
$sel:createdBefore:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe ISO8601
$sel:createdAfter:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe ISO8601
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ISO8601
createdAfter
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ISO8601
createdBefore
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Int
maxResults
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [EndpointState]
states
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Text]
types
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
virtualClusterId

instance Prelude.NFData ListManagedEndpoints where
  rnf :: ListManagedEndpoints -> ()
rnf ListManagedEndpoints' {Maybe Int
Maybe [Text]
Maybe [EndpointState]
Maybe Text
Maybe ISO8601
Text
virtualClusterId :: Text
types :: Maybe [Text]
states :: Maybe [EndpointState]
nextToken :: Maybe Text
maxResults :: Maybe Int
createdBefore :: Maybe ISO8601
createdAfter :: Maybe ISO8601
$sel:virtualClusterId:ListManagedEndpoints' :: ListManagedEndpoints -> Text
$sel:types:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe [Text]
$sel:states:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe [EndpointState]
$sel:nextToken:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe Text
$sel:maxResults:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe Int
$sel:createdBefore:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe ISO8601
$sel:createdAfter:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe ISO8601
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe ISO8601
createdAfter
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe ISO8601
createdBefore
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Int
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 Maybe [EndpointState]
states
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
types
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
virtualClusterId

instance Data.ToHeaders ListManagedEndpoints where
  toHeaders :: ListManagedEndpoints -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToPath ListManagedEndpoints where
  toPath :: ListManagedEndpoints -> ByteString
toPath ListManagedEndpoints' {Maybe Int
Maybe [Text]
Maybe [EndpointState]
Maybe Text
Maybe ISO8601
Text
virtualClusterId :: Text
types :: Maybe [Text]
states :: Maybe [EndpointState]
nextToken :: Maybe Text
maxResults :: Maybe Int
createdBefore :: Maybe ISO8601
createdAfter :: Maybe ISO8601
$sel:virtualClusterId:ListManagedEndpoints' :: ListManagedEndpoints -> Text
$sel:types:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe [Text]
$sel:states:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe [EndpointState]
$sel:nextToken:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe Text
$sel:maxResults:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe Int
$sel:createdBefore:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe ISO8601
$sel:createdAfter:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe ISO8601
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"/virtualclusters/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
virtualClusterId,
        ByteString
"/endpoints"
      ]

instance Data.ToQuery ListManagedEndpoints where
  toQuery :: ListManagedEndpoints -> QueryString
toQuery ListManagedEndpoints' {Maybe Int
Maybe [Text]
Maybe [EndpointState]
Maybe Text
Maybe ISO8601
Text
virtualClusterId :: Text
types :: Maybe [Text]
states :: Maybe [EndpointState]
nextToken :: Maybe Text
maxResults :: Maybe Int
createdBefore :: Maybe ISO8601
createdAfter :: Maybe ISO8601
$sel:virtualClusterId:ListManagedEndpoints' :: ListManagedEndpoints -> Text
$sel:types:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe [Text]
$sel:states:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe [EndpointState]
$sel:nextToken:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe Text
$sel:maxResults:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe Int
$sel:createdBefore:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe ISO8601
$sel:createdAfter:ListManagedEndpoints' :: ListManagedEndpoints -> Maybe ISO8601
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"createdAfter" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe ISO8601
createdAfter,
        ByteString
"createdBefore" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe ISO8601
createdBefore,
        ByteString
"maxResults" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Int
maxResults,
        ByteString
"nextToken" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
nextToken,
        ByteString
"states"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: forall a. ToQuery a => a -> QueryString
Data.toQuery
            (forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"member" forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [EndpointState]
states),
        ByteString
"types"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: forall a. ToQuery a => a -> QueryString
Data.toQuery
            (forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"member" forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Text]
types)
      ]

-- | /See:/ 'newListManagedEndpointsResponse' smart constructor.
data ListManagedEndpointsResponse = ListManagedEndpointsResponse'
  { -- | The managed endpoints to be listed.
    ListManagedEndpointsResponse -> Maybe [Endpoint]
endpoints :: Prelude.Maybe [Endpoint],
    -- | The token for the next set of endpoints to return.
    ListManagedEndpointsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    ListManagedEndpointsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (ListManagedEndpointsResponse
-> ListManagedEndpointsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListManagedEndpointsResponse
-> ListManagedEndpointsResponse -> Bool
$c/= :: ListManagedEndpointsResponse
-> ListManagedEndpointsResponse -> Bool
== :: ListManagedEndpointsResponse
-> ListManagedEndpointsResponse -> Bool
$c== :: ListManagedEndpointsResponse
-> ListManagedEndpointsResponse -> Bool
Prelude.Eq, Int -> ListManagedEndpointsResponse -> ShowS
[ListManagedEndpointsResponse] -> ShowS
ListManagedEndpointsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListManagedEndpointsResponse] -> ShowS
$cshowList :: [ListManagedEndpointsResponse] -> ShowS
show :: ListManagedEndpointsResponse -> String
$cshow :: ListManagedEndpointsResponse -> String
showsPrec :: Int -> ListManagedEndpointsResponse -> ShowS
$cshowsPrec :: Int -> ListManagedEndpointsResponse -> ShowS
Prelude.Show, forall x.
Rep ListManagedEndpointsResponse x -> ListManagedEndpointsResponse
forall x.
ListManagedEndpointsResponse -> Rep ListManagedEndpointsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ListManagedEndpointsResponse x -> ListManagedEndpointsResponse
$cfrom :: forall x.
ListManagedEndpointsResponse -> Rep ListManagedEndpointsResponse x
Prelude.Generic)

-- |
-- Create a value of 'ListManagedEndpointsResponse' 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:
--
-- 'endpoints', 'listManagedEndpointsResponse_endpoints' - The managed endpoints to be listed.
--
-- 'nextToken', 'listManagedEndpointsResponse_nextToken' - The token for the next set of endpoints to return.
--
-- 'httpStatus', 'listManagedEndpointsResponse_httpStatus' - The response's http status code.
newListManagedEndpointsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  ListManagedEndpointsResponse
newListManagedEndpointsResponse :: Int -> ListManagedEndpointsResponse
newListManagedEndpointsResponse Int
pHttpStatus_ =
  ListManagedEndpointsResponse'
    { $sel:endpoints:ListManagedEndpointsResponse' :: Maybe [Endpoint]
endpoints =
        forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:ListManagedEndpointsResponse' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:ListManagedEndpointsResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The managed endpoints to be listed.
listManagedEndpointsResponse_endpoints :: Lens.Lens' ListManagedEndpointsResponse (Prelude.Maybe [Endpoint])
listManagedEndpointsResponse_endpoints :: Lens' ListManagedEndpointsResponse (Maybe [Endpoint])
listManagedEndpointsResponse_endpoints = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListManagedEndpointsResponse' {Maybe [Endpoint]
endpoints :: Maybe [Endpoint]
$sel:endpoints:ListManagedEndpointsResponse' :: ListManagedEndpointsResponse -> Maybe [Endpoint]
endpoints} -> Maybe [Endpoint]
endpoints) (\s :: ListManagedEndpointsResponse
s@ListManagedEndpointsResponse' {} Maybe [Endpoint]
a -> ListManagedEndpointsResponse
s {$sel:endpoints:ListManagedEndpointsResponse' :: Maybe [Endpoint]
endpoints = Maybe [Endpoint]
a} :: ListManagedEndpointsResponse) 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 token for the next set of endpoints to return.
listManagedEndpointsResponse_nextToken :: Lens.Lens' ListManagedEndpointsResponse (Prelude.Maybe Prelude.Text)
listManagedEndpointsResponse_nextToken :: Lens' ListManagedEndpointsResponse (Maybe Text)
listManagedEndpointsResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListManagedEndpointsResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListManagedEndpointsResponse' :: ListManagedEndpointsResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListManagedEndpointsResponse
s@ListManagedEndpointsResponse' {} Maybe Text
a -> ListManagedEndpointsResponse
s {$sel:nextToken:ListManagedEndpointsResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListManagedEndpointsResponse)

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

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