{-# 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.Lambda.ListLayerVersions
-- 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 an
-- <https://docs.aws.amazon.com/lambda/latest/dg/configuration-layers.html Lambda layer>.
-- Versions that have been deleted aren\'t listed. Specify a
-- <https://docs.aws.amazon.com/lambda/latest/dg/lambda-runtimes.html runtime identifier>
-- to list only versions that indicate that they\'re compatible with that
-- runtime. Specify a compatible architecture to include only layer
-- versions that are compatible with that architecture.
--
-- This operation returns paginated results.
module Amazonka.Lambda.ListLayerVersions
  ( -- * Creating a Request
    ListLayerVersions (..),
    newListLayerVersions,

    -- * Request Lenses
    listLayerVersions_compatibleArchitecture,
    listLayerVersions_compatibleRuntime,
    listLayerVersions_marker,
    listLayerVersions_maxItems,
    listLayerVersions_layerName,

    -- * Destructuring the Response
    ListLayerVersionsResponse (..),
    newListLayerVersionsResponse,

    -- * Response Lenses
    listLayerVersionsResponse_layerVersions,
    listLayerVersionsResponse_nextMarker,
    listLayerVersionsResponse_httpStatus,
  )
where

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

-- | /See:/ 'newListLayerVersions' smart constructor.
data ListLayerVersions = ListLayerVersions'
  { -- | The compatible
    -- <https://docs.aws.amazon.com/lambda/latest/dg/foundation-arch.html instruction set architecture>.
    ListLayerVersions -> Maybe Architecture
compatibleArchitecture :: Prelude.Maybe Architecture,
    -- | A runtime identifier. For example, @go1.x@.
    ListLayerVersions -> Maybe Runtime
compatibleRuntime :: Prelude.Maybe Runtime,
    -- | A pagination token returned by a previous call.
    ListLayerVersions -> Maybe Text
marker :: Prelude.Maybe Prelude.Text,
    -- | The maximum number of versions to return.
    ListLayerVersions -> Maybe Natural
maxItems :: Prelude.Maybe Prelude.Natural,
    -- | The name or Amazon Resource Name (ARN) of the layer.
    ListLayerVersions -> Text
layerName :: Prelude.Text
  }
  deriving (ListLayerVersions -> ListLayerVersions -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListLayerVersions -> ListLayerVersions -> Bool
$c/= :: ListLayerVersions -> ListLayerVersions -> Bool
== :: ListLayerVersions -> ListLayerVersions -> Bool
$c== :: ListLayerVersions -> ListLayerVersions -> Bool
Prelude.Eq, ReadPrec [ListLayerVersions]
ReadPrec ListLayerVersions
Int -> ReadS ListLayerVersions
ReadS [ListLayerVersions]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListLayerVersions]
$creadListPrec :: ReadPrec [ListLayerVersions]
readPrec :: ReadPrec ListLayerVersions
$creadPrec :: ReadPrec ListLayerVersions
readList :: ReadS [ListLayerVersions]
$creadList :: ReadS [ListLayerVersions]
readsPrec :: Int -> ReadS ListLayerVersions
$creadsPrec :: Int -> ReadS ListLayerVersions
Prelude.Read, Int -> ListLayerVersions -> ShowS
[ListLayerVersions] -> ShowS
ListLayerVersions -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListLayerVersions] -> ShowS
$cshowList :: [ListLayerVersions] -> ShowS
show :: ListLayerVersions -> String
$cshow :: ListLayerVersions -> String
showsPrec :: Int -> ListLayerVersions -> ShowS
$cshowsPrec :: Int -> ListLayerVersions -> ShowS
Prelude.Show, forall x. Rep ListLayerVersions x -> ListLayerVersions
forall x. ListLayerVersions -> Rep ListLayerVersions x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListLayerVersions x -> ListLayerVersions
$cfrom :: forall x. ListLayerVersions -> Rep ListLayerVersions x
Prelude.Generic)

-- |
-- Create a value of 'ListLayerVersions' 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:
--
-- 'compatibleArchitecture', 'listLayerVersions_compatibleArchitecture' - The compatible
-- <https://docs.aws.amazon.com/lambda/latest/dg/foundation-arch.html instruction set architecture>.
--
-- 'compatibleRuntime', 'listLayerVersions_compatibleRuntime' - A runtime identifier. For example, @go1.x@.
--
-- 'marker', 'listLayerVersions_marker' - A pagination token returned by a previous call.
--
-- 'maxItems', 'listLayerVersions_maxItems' - The maximum number of versions to return.
--
-- 'layerName', 'listLayerVersions_layerName' - The name or Amazon Resource Name (ARN) of the layer.
newListLayerVersions ::
  -- | 'layerName'
  Prelude.Text ->
  ListLayerVersions
newListLayerVersions :: Text -> ListLayerVersions
newListLayerVersions Text
pLayerName_ =
  ListLayerVersions'
    { $sel:compatibleArchitecture:ListLayerVersions' :: Maybe Architecture
compatibleArchitecture =
        forall a. Maybe a
Prelude.Nothing,
      $sel:compatibleRuntime:ListLayerVersions' :: Maybe Runtime
compatibleRuntime = forall a. Maybe a
Prelude.Nothing,
      $sel:marker:ListLayerVersions' :: Maybe Text
marker = forall a. Maybe a
Prelude.Nothing,
      $sel:maxItems:ListLayerVersions' :: Maybe Natural
maxItems = forall a. Maybe a
Prelude.Nothing,
      $sel:layerName:ListLayerVersions' :: Text
layerName = Text
pLayerName_
    }

-- | The compatible
-- <https://docs.aws.amazon.com/lambda/latest/dg/foundation-arch.html instruction set architecture>.
listLayerVersions_compatibleArchitecture :: Lens.Lens' ListLayerVersions (Prelude.Maybe Architecture)
listLayerVersions_compatibleArchitecture :: Lens' ListLayerVersions (Maybe Architecture)
listLayerVersions_compatibleArchitecture = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListLayerVersions' {Maybe Architecture
compatibleArchitecture :: Maybe Architecture
$sel:compatibleArchitecture:ListLayerVersions' :: ListLayerVersions -> Maybe Architecture
compatibleArchitecture} -> Maybe Architecture
compatibleArchitecture) (\s :: ListLayerVersions
s@ListLayerVersions' {} Maybe Architecture
a -> ListLayerVersions
s {$sel:compatibleArchitecture:ListLayerVersions' :: Maybe Architecture
compatibleArchitecture = Maybe Architecture
a} :: ListLayerVersions)

-- | A runtime identifier. For example, @go1.x@.
listLayerVersions_compatibleRuntime :: Lens.Lens' ListLayerVersions (Prelude.Maybe Runtime)
listLayerVersions_compatibleRuntime :: Lens' ListLayerVersions (Maybe Runtime)
listLayerVersions_compatibleRuntime = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListLayerVersions' {Maybe Runtime
compatibleRuntime :: Maybe Runtime
$sel:compatibleRuntime:ListLayerVersions' :: ListLayerVersions -> Maybe Runtime
compatibleRuntime} -> Maybe Runtime
compatibleRuntime) (\s :: ListLayerVersions
s@ListLayerVersions' {} Maybe Runtime
a -> ListLayerVersions
s {$sel:compatibleRuntime:ListLayerVersions' :: Maybe Runtime
compatibleRuntime = Maybe Runtime
a} :: ListLayerVersions)

-- | A pagination token returned by a previous call.
listLayerVersions_marker :: Lens.Lens' ListLayerVersions (Prelude.Maybe Prelude.Text)
listLayerVersions_marker :: Lens' ListLayerVersions (Maybe Text)
listLayerVersions_marker = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListLayerVersions' {Maybe Text
marker :: Maybe Text
$sel:marker:ListLayerVersions' :: ListLayerVersions -> Maybe Text
marker} -> Maybe Text
marker) (\s :: ListLayerVersions
s@ListLayerVersions' {} Maybe Text
a -> ListLayerVersions
s {$sel:marker:ListLayerVersions' :: Maybe Text
marker = Maybe Text
a} :: ListLayerVersions)

-- | The maximum number of versions to return.
listLayerVersions_maxItems :: Lens.Lens' ListLayerVersions (Prelude.Maybe Prelude.Natural)
listLayerVersions_maxItems :: Lens' ListLayerVersions (Maybe Natural)
listLayerVersions_maxItems = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListLayerVersions' {Maybe Natural
maxItems :: Maybe Natural
$sel:maxItems:ListLayerVersions' :: ListLayerVersions -> Maybe Natural
maxItems} -> Maybe Natural
maxItems) (\s :: ListLayerVersions
s@ListLayerVersions' {} Maybe Natural
a -> ListLayerVersions
s {$sel:maxItems:ListLayerVersions' :: Maybe Natural
maxItems = Maybe Natural
a} :: ListLayerVersions)

-- | The name or Amazon Resource Name (ARN) of the layer.
listLayerVersions_layerName :: Lens.Lens' ListLayerVersions Prelude.Text
listLayerVersions_layerName :: Lens' ListLayerVersions Text
listLayerVersions_layerName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListLayerVersions' {Text
layerName :: Text
$sel:layerName:ListLayerVersions' :: ListLayerVersions -> Text
layerName} -> Text
layerName) (\s :: ListLayerVersions
s@ListLayerVersions' {} Text
a -> ListLayerVersions
s {$sel:layerName:ListLayerVersions' :: Text
layerName = Text
a} :: ListLayerVersions)

instance Core.AWSPager ListLayerVersions where
  page :: ListLayerVersions
-> AWSResponse ListLayerVersions -> Maybe ListLayerVersions
page ListLayerVersions
rq AWSResponse ListLayerVersions
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse ListLayerVersions
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListLayerVersionsResponse (Maybe Text)
listLayerVersionsResponse_nextMarker
            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 ListLayerVersions
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListLayerVersionsResponse (Maybe [LayerVersionsListItem])
listLayerVersionsResponse_layerVersions
            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.$ ListLayerVersions
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' ListLayerVersions (Maybe Text)
listLayerVersions_marker
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse ListLayerVersions
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListLayerVersionsResponse (Maybe Text)
listLayerVersionsResponse_nextMarker
          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 ListLayerVersions where
  type
    AWSResponse ListLayerVersions =
      ListLayerVersionsResponse
  request :: (Service -> Service)
-> ListLayerVersions -> Request ListLayerVersions
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 ListLayerVersions
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse ListLayerVersions)))
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 [LayerVersionsListItem]
-> Maybe Text -> Int -> ListLayerVersionsResponse
ListLayerVersionsResponse'
            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
"LayerVersions" 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
"NextMarker")
            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 ListLayerVersions where
  hashWithSalt :: Int -> ListLayerVersions -> Int
hashWithSalt Int
_salt ListLayerVersions' {Maybe Natural
Maybe Text
Maybe Architecture
Maybe Runtime
Text
layerName :: Text
maxItems :: Maybe Natural
marker :: Maybe Text
compatibleRuntime :: Maybe Runtime
compatibleArchitecture :: Maybe Architecture
$sel:layerName:ListLayerVersions' :: ListLayerVersions -> Text
$sel:maxItems:ListLayerVersions' :: ListLayerVersions -> Maybe Natural
$sel:marker:ListLayerVersions' :: ListLayerVersions -> Maybe Text
$sel:compatibleRuntime:ListLayerVersions' :: ListLayerVersions -> Maybe Runtime
$sel:compatibleArchitecture:ListLayerVersions' :: ListLayerVersions -> Maybe Architecture
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Architecture
compatibleArchitecture
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Runtime
compatibleRuntime
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
marker
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Natural
maxItems
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
layerName

instance Prelude.NFData ListLayerVersions where
  rnf :: ListLayerVersions -> ()
rnf ListLayerVersions' {Maybe Natural
Maybe Text
Maybe Architecture
Maybe Runtime
Text
layerName :: Text
maxItems :: Maybe Natural
marker :: Maybe Text
compatibleRuntime :: Maybe Runtime
compatibleArchitecture :: Maybe Architecture
$sel:layerName:ListLayerVersions' :: ListLayerVersions -> Text
$sel:maxItems:ListLayerVersions' :: ListLayerVersions -> Maybe Natural
$sel:marker:ListLayerVersions' :: ListLayerVersions -> Maybe Text
$sel:compatibleRuntime:ListLayerVersions' :: ListLayerVersions -> Maybe Runtime
$sel:compatibleArchitecture:ListLayerVersions' :: ListLayerVersions -> Maybe Architecture
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Architecture
compatibleArchitecture
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Runtime
compatibleRuntime
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
marker
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Natural
maxItems
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
layerName

instance Data.ToHeaders ListLayerVersions where
  toHeaders :: ListLayerVersions -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

instance Data.ToPath ListLayerVersions where
  toPath :: ListLayerVersions -> ByteString
toPath ListLayerVersions' {Maybe Natural
Maybe Text
Maybe Architecture
Maybe Runtime
Text
layerName :: Text
maxItems :: Maybe Natural
marker :: Maybe Text
compatibleRuntime :: Maybe Runtime
compatibleArchitecture :: Maybe Architecture
$sel:layerName:ListLayerVersions' :: ListLayerVersions -> Text
$sel:maxItems:ListLayerVersions' :: ListLayerVersions -> Maybe Natural
$sel:marker:ListLayerVersions' :: ListLayerVersions -> Maybe Text
$sel:compatibleRuntime:ListLayerVersions' :: ListLayerVersions -> Maybe Runtime
$sel:compatibleArchitecture:ListLayerVersions' :: ListLayerVersions -> Maybe Architecture
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"/2018-10-31/layers/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
layerName,
        ByteString
"/versions"
      ]

instance Data.ToQuery ListLayerVersions where
  toQuery :: ListLayerVersions -> QueryString
toQuery ListLayerVersions' {Maybe Natural
Maybe Text
Maybe Architecture
Maybe Runtime
Text
layerName :: Text
maxItems :: Maybe Natural
marker :: Maybe Text
compatibleRuntime :: Maybe Runtime
compatibleArchitecture :: Maybe Architecture
$sel:layerName:ListLayerVersions' :: ListLayerVersions -> Text
$sel:maxItems:ListLayerVersions' :: ListLayerVersions -> Maybe Natural
$sel:marker:ListLayerVersions' :: ListLayerVersions -> Maybe Text
$sel:compatibleRuntime:ListLayerVersions' :: ListLayerVersions -> Maybe Runtime
$sel:compatibleArchitecture:ListLayerVersions' :: ListLayerVersions -> Maybe Architecture
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"CompatibleArchitecture"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Architecture
compatibleArchitecture,
        ByteString
"CompatibleRuntime" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Runtime
compatibleRuntime,
        ByteString
"Marker" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
marker,
        ByteString
"MaxItems" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Natural
maxItems
      ]

-- | /See:/ 'newListLayerVersionsResponse' smart constructor.
data ListLayerVersionsResponse = ListLayerVersionsResponse'
  { -- | A list of versions.
    ListLayerVersionsResponse -> Maybe [LayerVersionsListItem]
layerVersions :: Prelude.Maybe [LayerVersionsListItem],
    -- | A pagination token returned when the response doesn\'t contain all
    -- versions.
    ListLayerVersionsResponse -> Maybe Text
nextMarker :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    ListLayerVersionsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (ListLayerVersionsResponse -> ListLayerVersionsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListLayerVersionsResponse -> ListLayerVersionsResponse -> Bool
$c/= :: ListLayerVersionsResponse -> ListLayerVersionsResponse -> Bool
== :: ListLayerVersionsResponse -> ListLayerVersionsResponse -> Bool
$c== :: ListLayerVersionsResponse -> ListLayerVersionsResponse -> Bool
Prelude.Eq, ReadPrec [ListLayerVersionsResponse]
ReadPrec ListLayerVersionsResponse
Int -> ReadS ListLayerVersionsResponse
ReadS [ListLayerVersionsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListLayerVersionsResponse]
$creadListPrec :: ReadPrec [ListLayerVersionsResponse]
readPrec :: ReadPrec ListLayerVersionsResponse
$creadPrec :: ReadPrec ListLayerVersionsResponse
readList :: ReadS [ListLayerVersionsResponse]
$creadList :: ReadS [ListLayerVersionsResponse]
readsPrec :: Int -> ReadS ListLayerVersionsResponse
$creadsPrec :: Int -> ReadS ListLayerVersionsResponse
Prelude.Read, Int -> ListLayerVersionsResponse -> ShowS
[ListLayerVersionsResponse] -> ShowS
ListLayerVersionsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListLayerVersionsResponse] -> ShowS
$cshowList :: [ListLayerVersionsResponse] -> ShowS
show :: ListLayerVersionsResponse -> String
$cshow :: ListLayerVersionsResponse -> String
showsPrec :: Int -> ListLayerVersionsResponse -> ShowS
$cshowsPrec :: Int -> ListLayerVersionsResponse -> ShowS
Prelude.Show, forall x.
Rep ListLayerVersionsResponse x -> ListLayerVersionsResponse
forall x.
ListLayerVersionsResponse -> Rep ListLayerVersionsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ListLayerVersionsResponse x -> ListLayerVersionsResponse
$cfrom :: forall x.
ListLayerVersionsResponse -> Rep ListLayerVersionsResponse x
Prelude.Generic)

-- |
-- Create a value of 'ListLayerVersionsResponse' 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:
--
-- 'layerVersions', 'listLayerVersionsResponse_layerVersions' - A list of versions.
--
-- 'nextMarker', 'listLayerVersionsResponse_nextMarker' - A pagination token returned when the response doesn\'t contain all
-- versions.
--
-- 'httpStatus', 'listLayerVersionsResponse_httpStatus' - The response's http status code.
newListLayerVersionsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  ListLayerVersionsResponse
newListLayerVersionsResponse :: Int -> ListLayerVersionsResponse
newListLayerVersionsResponse Int
pHttpStatus_ =
  ListLayerVersionsResponse'
    { $sel:layerVersions:ListLayerVersionsResponse' :: Maybe [LayerVersionsListItem]
layerVersions =
        forall a. Maybe a
Prelude.Nothing,
      $sel:nextMarker:ListLayerVersionsResponse' :: Maybe Text
nextMarker = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:ListLayerVersionsResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | A list of versions.
listLayerVersionsResponse_layerVersions :: Lens.Lens' ListLayerVersionsResponse (Prelude.Maybe [LayerVersionsListItem])
listLayerVersionsResponse_layerVersions :: Lens' ListLayerVersionsResponse (Maybe [LayerVersionsListItem])
listLayerVersionsResponse_layerVersions = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListLayerVersionsResponse' {Maybe [LayerVersionsListItem]
layerVersions :: Maybe [LayerVersionsListItem]
$sel:layerVersions:ListLayerVersionsResponse' :: ListLayerVersionsResponse -> Maybe [LayerVersionsListItem]
layerVersions} -> Maybe [LayerVersionsListItem]
layerVersions) (\s :: ListLayerVersionsResponse
s@ListLayerVersionsResponse' {} Maybe [LayerVersionsListItem]
a -> ListLayerVersionsResponse
s {$sel:layerVersions:ListLayerVersionsResponse' :: Maybe [LayerVersionsListItem]
layerVersions = Maybe [LayerVersionsListItem]
a} :: ListLayerVersionsResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | A pagination token returned when the response doesn\'t contain all
-- versions.
listLayerVersionsResponse_nextMarker :: Lens.Lens' ListLayerVersionsResponse (Prelude.Maybe Prelude.Text)
listLayerVersionsResponse_nextMarker :: Lens' ListLayerVersionsResponse (Maybe Text)
listLayerVersionsResponse_nextMarker = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListLayerVersionsResponse' {Maybe Text
nextMarker :: Maybe Text
$sel:nextMarker:ListLayerVersionsResponse' :: ListLayerVersionsResponse -> Maybe Text
nextMarker} -> Maybe Text
nextMarker) (\s :: ListLayerVersionsResponse
s@ListLayerVersionsResponse' {} Maybe Text
a -> ListLayerVersionsResponse
s {$sel:nextMarker:ListLayerVersionsResponse' :: Maybe Text
nextMarker = Maybe Text
a} :: ListLayerVersionsResponse)

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

instance Prelude.NFData ListLayerVersionsResponse where
  rnf :: ListLayerVersionsResponse -> ()
rnf ListLayerVersionsResponse' {Int
Maybe [LayerVersionsListItem]
Maybe Text
httpStatus :: Int
nextMarker :: Maybe Text
layerVersions :: Maybe [LayerVersionsListItem]
$sel:httpStatus:ListLayerVersionsResponse' :: ListLayerVersionsResponse -> Int
$sel:nextMarker:ListLayerVersionsResponse' :: ListLayerVersionsResponse -> Maybe Text
$sel:layerVersions:ListLayerVersionsResponse' :: ListLayerVersionsResponse -> Maybe [LayerVersionsListItem]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [LayerVersionsListItem]
layerVersions
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextMarker
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus