{-# 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.Greengrass.ListSubscriptionDefinitionVersions
-- 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 the versions of a subscription definition.
--
-- This operation returns paginated results.
module Amazonka.Greengrass.ListSubscriptionDefinitionVersions
  ( -- * Creating a Request
    ListSubscriptionDefinitionVersions (..),
    newListSubscriptionDefinitionVersions,

    -- * Request Lenses
    listSubscriptionDefinitionVersions_maxResults,
    listSubscriptionDefinitionVersions_nextToken,
    listSubscriptionDefinitionVersions_subscriptionDefinitionId,

    -- * Destructuring the Response
    ListSubscriptionDefinitionVersionsResponse (..),
    newListSubscriptionDefinitionVersionsResponse,

    -- * Response Lenses
    listSubscriptionDefinitionVersionsResponse_nextToken,
    listSubscriptionDefinitionVersionsResponse_versions,
    listSubscriptionDefinitionVersionsResponse_httpStatus,
  )
where

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

-- | /See:/ 'newListSubscriptionDefinitionVersions' smart constructor.
data ListSubscriptionDefinitionVersions = ListSubscriptionDefinitionVersions'
  { -- | The maximum number of results to be returned per request.
    ListSubscriptionDefinitionVersions -> Maybe Text
maxResults :: Prelude.Maybe Prelude.Text,
    -- | The token for the next set of results, or \'\'null\'\' if there are no
    -- additional results.
    ListSubscriptionDefinitionVersions -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The ID of the subscription definition.
    ListSubscriptionDefinitionVersions -> Text
subscriptionDefinitionId :: Prelude.Text
  }
  deriving (ListSubscriptionDefinitionVersions
-> ListSubscriptionDefinitionVersions -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListSubscriptionDefinitionVersions
-> ListSubscriptionDefinitionVersions -> Bool
$c/= :: ListSubscriptionDefinitionVersions
-> ListSubscriptionDefinitionVersions -> Bool
== :: ListSubscriptionDefinitionVersions
-> ListSubscriptionDefinitionVersions -> Bool
$c== :: ListSubscriptionDefinitionVersions
-> ListSubscriptionDefinitionVersions -> Bool
Prelude.Eq, ReadPrec [ListSubscriptionDefinitionVersions]
ReadPrec ListSubscriptionDefinitionVersions
Int -> ReadS ListSubscriptionDefinitionVersions
ReadS [ListSubscriptionDefinitionVersions]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListSubscriptionDefinitionVersions]
$creadListPrec :: ReadPrec [ListSubscriptionDefinitionVersions]
readPrec :: ReadPrec ListSubscriptionDefinitionVersions
$creadPrec :: ReadPrec ListSubscriptionDefinitionVersions
readList :: ReadS [ListSubscriptionDefinitionVersions]
$creadList :: ReadS [ListSubscriptionDefinitionVersions]
readsPrec :: Int -> ReadS ListSubscriptionDefinitionVersions
$creadsPrec :: Int -> ReadS ListSubscriptionDefinitionVersions
Prelude.Read, Int -> ListSubscriptionDefinitionVersions -> ShowS
[ListSubscriptionDefinitionVersions] -> ShowS
ListSubscriptionDefinitionVersions -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListSubscriptionDefinitionVersions] -> ShowS
$cshowList :: [ListSubscriptionDefinitionVersions] -> ShowS
show :: ListSubscriptionDefinitionVersions -> String
$cshow :: ListSubscriptionDefinitionVersions -> String
showsPrec :: Int -> ListSubscriptionDefinitionVersions -> ShowS
$cshowsPrec :: Int -> ListSubscriptionDefinitionVersions -> ShowS
Prelude.Show, forall x.
Rep ListSubscriptionDefinitionVersions x
-> ListSubscriptionDefinitionVersions
forall x.
ListSubscriptionDefinitionVersions
-> Rep ListSubscriptionDefinitionVersions x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ListSubscriptionDefinitionVersions x
-> ListSubscriptionDefinitionVersions
$cfrom :: forall x.
ListSubscriptionDefinitionVersions
-> Rep ListSubscriptionDefinitionVersions x
Prelude.Generic)

-- |
-- Create a value of 'ListSubscriptionDefinitionVersions' 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', 'listSubscriptionDefinitionVersions_maxResults' - The maximum number of results to be returned per request.
--
-- 'nextToken', 'listSubscriptionDefinitionVersions_nextToken' - The token for the next set of results, or \'\'null\'\' if there are no
-- additional results.
--
-- 'subscriptionDefinitionId', 'listSubscriptionDefinitionVersions_subscriptionDefinitionId' - The ID of the subscription definition.
newListSubscriptionDefinitionVersions ::
  -- | 'subscriptionDefinitionId'
  Prelude.Text ->
  ListSubscriptionDefinitionVersions
newListSubscriptionDefinitionVersions :: Text -> ListSubscriptionDefinitionVersions
newListSubscriptionDefinitionVersions
  Text
pSubscriptionDefinitionId_ =
    ListSubscriptionDefinitionVersions'
      { $sel:maxResults:ListSubscriptionDefinitionVersions' :: Maybe Text
maxResults =
          forall a. Maybe a
Prelude.Nothing,
        $sel:nextToken:ListSubscriptionDefinitionVersions' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
        $sel:subscriptionDefinitionId:ListSubscriptionDefinitionVersions' :: Text
subscriptionDefinitionId =
          Text
pSubscriptionDefinitionId_
      }

-- | The maximum number of results to be returned per request.
listSubscriptionDefinitionVersions_maxResults :: Lens.Lens' ListSubscriptionDefinitionVersions (Prelude.Maybe Prelude.Text)
listSubscriptionDefinitionVersions_maxResults :: Lens' ListSubscriptionDefinitionVersions (Maybe Text)
listSubscriptionDefinitionVersions_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListSubscriptionDefinitionVersions' {Maybe Text
maxResults :: Maybe Text
$sel:maxResults:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Maybe Text
maxResults} -> Maybe Text
maxResults) (\s :: ListSubscriptionDefinitionVersions
s@ListSubscriptionDefinitionVersions' {} Maybe Text
a -> ListSubscriptionDefinitionVersions
s {$sel:maxResults:ListSubscriptionDefinitionVersions' :: Maybe Text
maxResults = Maybe Text
a} :: ListSubscriptionDefinitionVersions)

-- | The token for the next set of results, or \'\'null\'\' if there are no
-- additional results.
listSubscriptionDefinitionVersions_nextToken :: Lens.Lens' ListSubscriptionDefinitionVersions (Prelude.Maybe Prelude.Text)
listSubscriptionDefinitionVersions_nextToken :: Lens' ListSubscriptionDefinitionVersions (Maybe Text)
listSubscriptionDefinitionVersions_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListSubscriptionDefinitionVersions' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListSubscriptionDefinitionVersions
s@ListSubscriptionDefinitionVersions' {} Maybe Text
a -> ListSubscriptionDefinitionVersions
s {$sel:nextToken:ListSubscriptionDefinitionVersions' :: Maybe Text
nextToken = Maybe Text
a} :: ListSubscriptionDefinitionVersions)

-- | The ID of the subscription definition.
listSubscriptionDefinitionVersions_subscriptionDefinitionId :: Lens.Lens' ListSubscriptionDefinitionVersions Prelude.Text
listSubscriptionDefinitionVersions_subscriptionDefinitionId :: Lens' ListSubscriptionDefinitionVersions Text
listSubscriptionDefinitionVersions_subscriptionDefinitionId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListSubscriptionDefinitionVersions' {Text
subscriptionDefinitionId :: Text
$sel:subscriptionDefinitionId:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Text
subscriptionDefinitionId} -> Text
subscriptionDefinitionId) (\s :: ListSubscriptionDefinitionVersions
s@ListSubscriptionDefinitionVersions' {} Text
a -> ListSubscriptionDefinitionVersions
s {$sel:subscriptionDefinitionId:ListSubscriptionDefinitionVersions' :: Text
subscriptionDefinitionId = Text
a} :: ListSubscriptionDefinitionVersions)

instance
  Core.AWSPager
    ListSubscriptionDefinitionVersions
  where
  page :: ListSubscriptionDefinitionVersions
-> AWSResponse ListSubscriptionDefinitionVersions
-> Maybe ListSubscriptionDefinitionVersions
page ListSubscriptionDefinitionVersions
rq AWSResponse ListSubscriptionDefinitionVersions
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse ListSubscriptionDefinitionVersions
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListSubscriptionDefinitionVersionsResponse (Maybe Text)
listSubscriptionDefinitionVersionsResponse_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 ListSubscriptionDefinitionVersions
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens'
  ListSubscriptionDefinitionVersionsResponse
  (Maybe [VersionInformation])
listSubscriptionDefinitionVersionsResponse_versions
            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.$ ListSubscriptionDefinitionVersions
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' ListSubscriptionDefinitionVersions (Maybe Text)
listSubscriptionDefinitionVersions_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse ListSubscriptionDefinitionVersions
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListSubscriptionDefinitionVersionsResponse (Maybe Text)
listSubscriptionDefinitionVersionsResponse_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
    ListSubscriptionDefinitionVersions
  where
  type
    AWSResponse ListSubscriptionDefinitionVersions =
      ListSubscriptionDefinitionVersionsResponse
  request :: (Service -> Service)
-> ListSubscriptionDefinitionVersions
-> Request ListSubscriptionDefinitionVersions
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 ListSubscriptionDefinitionVersions
-> ClientResponse ClientBody
-> m (Either
        Error
        (ClientResponse (AWSResponse ListSubscriptionDefinitionVersions)))
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 [VersionInformation]
-> Int
-> ListSubscriptionDefinitionVersionsResponse
ListSubscriptionDefinitionVersionsResponse'
            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
"Versions" 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
    ListSubscriptionDefinitionVersions
  where
  hashWithSalt :: Int -> ListSubscriptionDefinitionVersions -> Int
hashWithSalt
    Int
_salt
    ListSubscriptionDefinitionVersions' {Maybe Text
Text
subscriptionDefinitionId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Text
$sel:subscriptionDefinitionId:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Text
$sel:nextToken:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Maybe Text
$sel:maxResults:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Maybe Text
..} =
      Int
_salt
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
maxResults
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
subscriptionDefinitionId

instance
  Prelude.NFData
    ListSubscriptionDefinitionVersions
  where
  rnf :: ListSubscriptionDefinitionVersions -> ()
rnf ListSubscriptionDefinitionVersions' {Maybe Text
Text
subscriptionDefinitionId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Text
$sel:subscriptionDefinitionId:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Text
$sel:nextToken:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Maybe Text
$sel:maxResults:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
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
subscriptionDefinitionId

instance
  Data.ToHeaders
    ListSubscriptionDefinitionVersions
  where
  toHeaders :: ListSubscriptionDefinitionVersions -> 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
    ListSubscriptionDefinitionVersions
  where
  toPath :: ListSubscriptionDefinitionVersions -> ByteString
toPath ListSubscriptionDefinitionVersions' {Maybe Text
Text
subscriptionDefinitionId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Text
$sel:subscriptionDefinitionId:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Text
$sel:nextToken:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Maybe Text
$sel:maxResults:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Maybe Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"/greengrass/definition/subscriptions/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
subscriptionDefinitionId,
        ByteString
"/versions"
      ]

instance
  Data.ToQuery
    ListSubscriptionDefinitionVersions
  where
  toQuery :: ListSubscriptionDefinitionVersions -> QueryString
toQuery ListSubscriptionDefinitionVersions' {Maybe Text
Text
subscriptionDefinitionId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Text
$sel:subscriptionDefinitionId:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Text
$sel:nextToken:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Maybe Text
$sel:maxResults:ListSubscriptionDefinitionVersions' :: ListSubscriptionDefinitionVersions -> Maybe Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"MaxResults" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
maxResults,
        ByteString
"NextToken" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
nextToken
      ]

-- | /See:/ 'newListSubscriptionDefinitionVersionsResponse' smart constructor.
data ListSubscriptionDefinitionVersionsResponse = ListSubscriptionDefinitionVersionsResponse'
  { -- | The token for the next set of results, or \'\'null\'\' if there are no
    -- additional results.
    ListSubscriptionDefinitionVersionsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | Information about a version.
    ListSubscriptionDefinitionVersionsResponse
-> Maybe [VersionInformation]
versions :: Prelude.Maybe [VersionInformation],
    -- | The response's http status code.
    ListSubscriptionDefinitionVersionsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (ListSubscriptionDefinitionVersionsResponse
-> ListSubscriptionDefinitionVersionsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListSubscriptionDefinitionVersionsResponse
-> ListSubscriptionDefinitionVersionsResponse -> Bool
$c/= :: ListSubscriptionDefinitionVersionsResponse
-> ListSubscriptionDefinitionVersionsResponse -> Bool
== :: ListSubscriptionDefinitionVersionsResponse
-> ListSubscriptionDefinitionVersionsResponse -> Bool
$c== :: ListSubscriptionDefinitionVersionsResponse
-> ListSubscriptionDefinitionVersionsResponse -> Bool
Prelude.Eq, ReadPrec [ListSubscriptionDefinitionVersionsResponse]
ReadPrec ListSubscriptionDefinitionVersionsResponse
Int -> ReadS ListSubscriptionDefinitionVersionsResponse
ReadS [ListSubscriptionDefinitionVersionsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListSubscriptionDefinitionVersionsResponse]
$creadListPrec :: ReadPrec [ListSubscriptionDefinitionVersionsResponse]
readPrec :: ReadPrec ListSubscriptionDefinitionVersionsResponse
$creadPrec :: ReadPrec ListSubscriptionDefinitionVersionsResponse
readList :: ReadS [ListSubscriptionDefinitionVersionsResponse]
$creadList :: ReadS [ListSubscriptionDefinitionVersionsResponse]
readsPrec :: Int -> ReadS ListSubscriptionDefinitionVersionsResponse
$creadsPrec :: Int -> ReadS ListSubscriptionDefinitionVersionsResponse
Prelude.Read, Int -> ListSubscriptionDefinitionVersionsResponse -> ShowS
[ListSubscriptionDefinitionVersionsResponse] -> ShowS
ListSubscriptionDefinitionVersionsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListSubscriptionDefinitionVersionsResponse] -> ShowS
$cshowList :: [ListSubscriptionDefinitionVersionsResponse] -> ShowS
show :: ListSubscriptionDefinitionVersionsResponse -> String
$cshow :: ListSubscriptionDefinitionVersionsResponse -> String
showsPrec :: Int -> ListSubscriptionDefinitionVersionsResponse -> ShowS
$cshowsPrec :: Int -> ListSubscriptionDefinitionVersionsResponse -> ShowS
Prelude.Show, forall x.
Rep ListSubscriptionDefinitionVersionsResponse x
-> ListSubscriptionDefinitionVersionsResponse
forall x.
ListSubscriptionDefinitionVersionsResponse
-> Rep ListSubscriptionDefinitionVersionsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ListSubscriptionDefinitionVersionsResponse x
-> ListSubscriptionDefinitionVersionsResponse
$cfrom :: forall x.
ListSubscriptionDefinitionVersionsResponse
-> Rep ListSubscriptionDefinitionVersionsResponse x
Prelude.Generic)

-- |
-- Create a value of 'ListSubscriptionDefinitionVersionsResponse' 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', 'listSubscriptionDefinitionVersionsResponse_nextToken' - The token for the next set of results, or \'\'null\'\' if there are no
-- additional results.
--
-- 'versions', 'listSubscriptionDefinitionVersionsResponse_versions' - Information about a version.
--
-- 'httpStatus', 'listSubscriptionDefinitionVersionsResponse_httpStatus' - The response's http status code.
newListSubscriptionDefinitionVersionsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  ListSubscriptionDefinitionVersionsResponse
newListSubscriptionDefinitionVersionsResponse :: Int -> ListSubscriptionDefinitionVersionsResponse
newListSubscriptionDefinitionVersionsResponse
  Int
pHttpStatus_ =
    ListSubscriptionDefinitionVersionsResponse'
      { $sel:nextToken:ListSubscriptionDefinitionVersionsResponse' :: Maybe Text
nextToken =
          forall a. Maybe a
Prelude.Nothing,
        $sel:versions:ListSubscriptionDefinitionVersionsResponse' :: Maybe [VersionInformation]
versions = forall a. Maybe a
Prelude.Nothing,
        $sel:httpStatus:ListSubscriptionDefinitionVersionsResponse' :: Int
httpStatus = Int
pHttpStatus_
      }

-- | The token for the next set of results, or \'\'null\'\' if there are no
-- additional results.
listSubscriptionDefinitionVersionsResponse_nextToken :: Lens.Lens' ListSubscriptionDefinitionVersionsResponse (Prelude.Maybe Prelude.Text)
listSubscriptionDefinitionVersionsResponse_nextToken :: Lens' ListSubscriptionDefinitionVersionsResponse (Maybe Text)
listSubscriptionDefinitionVersionsResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListSubscriptionDefinitionVersionsResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListSubscriptionDefinitionVersionsResponse' :: ListSubscriptionDefinitionVersionsResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListSubscriptionDefinitionVersionsResponse
s@ListSubscriptionDefinitionVersionsResponse' {} Maybe Text
a -> ListSubscriptionDefinitionVersionsResponse
s {$sel:nextToken:ListSubscriptionDefinitionVersionsResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListSubscriptionDefinitionVersionsResponse)

-- | Information about a version.
listSubscriptionDefinitionVersionsResponse_versions :: Lens.Lens' ListSubscriptionDefinitionVersionsResponse (Prelude.Maybe [VersionInformation])
listSubscriptionDefinitionVersionsResponse_versions :: Lens'
  ListSubscriptionDefinitionVersionsResponse
  (Maybe [VersionInformation])
listSubscriptionDefinitionVersionsResponse_versions = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListSubscriptionDefinitionVersionsResponse' {Maybe [VersionInformation]
versions :: Maybe [VersionInformation]
$sel:versions:ListSubscriptionDefinitionVersionsResponse' :: ListSubscriptionDefinitionVersionsResponse
-> Maybe [VersionInformation]
versions} -> Maybe [VersionInformation]
versions) (\s :: ListSubscriptionDefinitionVersionsResponse
s@ListSubscriptionDefinitionVersionsResponse' {} Maybe [VersionInformation]
a -> ListSubscriptionDefinitionVersionsResponse
s {$sel:versions:ListSubscriptionDefinitionVersionsResponse' :: Maybe [VersionInformation]
versions = Maybe [VersionInformation]
a} :: ListSubscriptionDefinitionVersionsResponse) 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.
listSubscriptionDefinitionVersionsResponse_httpStatus :: Lens.Lens' ListSubscriptionDefinitionVersionsResponse Prelude.Int
listSubscriptionDefinitionVersionsResponse_httpStatus :: Lens' ListSubscriptionDefinitionVersionsResponse Int
listSubscriptionDefinitionVersionsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListSubscriptionDefinitionVersionsResponse' {Int
httpStatus :: Int
$sel:httpStatus:ListSubscriptionDefinitionVersionsResponse' :: ListSubscriptionDefinitionVersionsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: ListSubscriptionDefinitionVersionsResponse
s@ListSubscriptionDefinitionVersionsResponse' {} Int
a -> ListSubscriptionDefinitionVersionsResponse
s {$sel:httpStatus:ListSubscriptionDefinitionVersionsResponse' :: Int
httpStatus = Int
a} :: ListSubscriptionDefinitionVersionsResponse)

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