{-# 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.Redshift.DescribeReservedNodeOfferings
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Returns a list of the available reserved node offerings by Amazon
-- Redshift with their descriptions including the node type, the fixed and
-- recurring costs of reserving the node and duration the node will be
-- reserved for you. These descriptions help you determine which reserve
-- node offering you want to purchase. You then use the unique offering ID
-- in you call to PurchaseReservedNodeOffering to reserve one or more nodes
-- for your Amazon Redshift cluster.
--
-- For more information about reserved node offerings, go to
-- <https://docs.aws.amazon.com/redshift/latest/mgmt/purchase-reserved-node-instance.html Purchasing Reserved Nodes>
-- in the /Amazon Redshift Cluster Management Guide/.
--
-- This operation returns paginated results.
module Amazonka.Redshift.DescribeReservedNodeOfferings
  ( -- * Creating a Request
    DescribeReservedNodeOfferings (..),
    newDescribeReservedNodeOfferings,

    -- * Request Lenses
    describeReservedNodeOfferings_marker,
    describeReservedNodeOfferings_maxRecords,
    describeReservedNodeOfferings_reservedNodeOfferingId,

    -- * Destructuring the Response
    DescribeReservedNodeOfferingsResponse (..),
    newDescribeReservedNodeOfferingsResponse,

    -- * Response Lenses
    describeReservedNodeOfferingsResponse_marker,
    describeReservedNodeOfferingsResponse_reservedNodeOfferings,
    describeReservedNodeOfferingsResponse_httpStatus,
  )
where

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

-- |
--
-- /See:/ 'newDescribeReservedNodeOfferings' smart constructor.
data DescribeReservedNodeOfferings = DescribeReservedNodeOfferings'
  { -- | An optional parameter that specifies the starting point to return a set
    -- of response records. When the results of a DescribeReservedNodeOfferings
    -- request exceed the value specified in @MaxRecords@, Amazon Web Services
    -- returns a value in the @Marker@ field of the response. You can retrieve
    -- the next set of response records by providing the returned marker value
    -- in the @Marker@ parameter and retrying the request.
    DescribeReservedNodeOfferings -> Maybe Text
marker :: Prelude.Maybe Prelude.Text,
    -- | The maximum number of response records to return in each call. If the
    -- number of remaining response records exceeds the specified @MaxRecords@
    -- value, a value is returned in a @marker@ field of the response. You can
    -- retrieve the next set of records by retrying the command with the
    -- returned marker value.
    --
    -- Default: @100@
    --
    -- Constraints: minimum 20, maximum 100.
    DescribeReservedNodeOfferings -> Maybe Int
maxRecords :: Prelude.Maybe Prelude.Int,
    -- | The unique identifier for the offering.
    DescribeReservedNodeOfferings -> Maybe Text
reservedNodeOfferingId :: Prelude.Maybe Prelude.Text
  }
  deriving (DescribeReservedNodeOfferings
-> DescribeReservedNodeOfferings -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeReservedNodeOfferings
-> DescribeReservedNodeOfferings -> Bool
$c/= :: DescribeReservedNodeOfferings
-> DescribeReservedNodeOfferings -> Bool
== :: DescribeReservedNodeOfferings
-> DescribeReservedNodeOfferings -> Bool
$c== :: DescribeReservedNodeOfferings
-> DescribeReservedNodeOfferings -> Bool
Prelude.Eq, ReadPrec [DescribeReservedNodeOfferings]
ReadPrec DescribeReservedNodeOfferings
Int -> ReadS DescribeReservedNodeOfferings
ReadS [DescribeReservedNodeOfferings]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeReservedNodeOfferings]
$creadListPrec :: ReadPrec [DescribeReservedNodeOfferings]
readPrec :: ReadPrec DescribeReservedNodeOfferings
$creadPrec :: ReadPrec DescribeReservedNodeOfferings
readList :: ReadS [DescribeReservedNodeOfferings]
$creadList :: ReadS [DescribeReservedNodeOfferings]
readsPrec :: Int -> ReadS DescribeReservedNodeOfferings
$creadsPrec :: Int -> ReadS DescribeReservedNodeOfferings
Prelude.Read, Int -> DescribeReservedNodeOfferings -> ShowS
[DescribeReservedNodeOfferings] -> ShowS
DescribeReservedNodeOfferings -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeReservedNodeOfferings] -> ShowS
$cshowList :: [DescribeReservedNodeOfferings] -> ShowS
show :: DescribeReservedNodeOfferings -> String
$cshow :: DescribeReservedNodeOfferings -> String
showsPrec :: Int -> DescribeReservedNodeOfferings -> ShowS
$cshowsPrec :: Int -> DescribeReservedNodeOfferings -> ShowS
Prelude.Show, forall x.
Rep DescribeReservedNodeOfferings x
-> DescribeReservedNodeOfferings
forall x.
DescribeReservedNodeOfferings
-> Rep DescribeReservedNodeOfferings x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeReservedNodeOfferings x
-> DescribeReservedNodeOfferings
$cfrom :: forall x.
DescribeReservedNodeOfferings
-> Rep DescribeReservedNodeOfferings x
Prelude.Generic)

-- |
-- Create a value of 'DescribeReservedNodeOfferings' 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:
--
-- 'marker', 'describeReservedNodeOfferings_marker' - An optional parameter that specifies the starting point to return a set
-- of response records. When the results of a DescribeReservedNodeOfferings
-- request exceed the value specified in @MaxRecords@, Amazon Web Services
-- returns a value in the @Marker@ field of the response. You can retrieve
-- the next set of response records by providing the returned marker value
-- in the @Marker@ parameter and retrying the request.
--
-- 'maxRecords', 'describeReservedNodeOfferings_maxRecords' - The maximum number of response records to return in each call. If the
-- number of remaining response records exceeds the specified @MaxRecords@
-- value, a value is returned in a @marker@ field of the response. You can
-- retrieve the next set of records by retrying the command with the
-- returned marker value.
--
-- Default: @100@
--
-- Constraints: minimum 20, maximum 100.
--
-- 'reservedNodeOfferingId', 'describeReservedNodeOfferings_reservedNodeOfferingId' - The unique identifier for the offering.
newDescribeReservedNodeOfferings ::
  DescribeReservedNodeOfferings
newDescribeReservedNodeOfferings :: DescribeReservedNodeOfferings
newDescribeReservedNodeOfferings =
  DescribeReservedNodeOfferings'
    { $sel:marker:DescribeReservedNodeOfferings' :: Maybe Text
marker =
        forall a. Maybe a
Prelude.Nothing,
      $sel:maxRecords:DescribeReservedNodeOfferings' :: Maybe Int
maxRecords = forall a. Maybe a
Prelude.Nothing,
      $sel:reservedNodeOfferingId:DescribeReservedNodeOfferings' :: Maybe Text
reservedNodeOfferingId = forall a. Maybe a
Prelude.Nothing
    }

-- | An optional parameter that specifies the starting point to return a set
-- of response records. When the results of a DescribeReservedNodeOfferings
-- request exceed the value specified in @MaxRecords@, Amazon Web Services
-- returns a value in the @Marker@ field of the response. You can retrieve
-- the next set of response records by providing the returned marker value
-- in the @Marker@ parameter and retrying the request.
describeReservedNodeOfferings_marker :: Lens.Lens' DescribeReservedNodeOfferings (Prelude.Maybe Prelude.Text)
describeReservedNodeOfferings_marker :: Lens' DescribeReservedNodeOfferings (Maybe Text)
describeReservedNodeOfferings_marker = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedNodeOfferings' {Maybe Text
marker :: Maybe Text
$sel:marker:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Text
marker} -> Maybe Text
marker) (\s :: DescribeReservedNodeOfferings
s@DescribeReservedNodeOfferings' {} Maybe Text
a -> DescribeReservedNodeOfferings
s {$sel:marker:DescribeReservedNodeOfferings' :: Maybe Text
marker = Maybe Text
a} :: DescribeReservedNodeOfferings)

-- | The maximum number of response records to return in each call. If the
-- number of remaining response records exceeds the specified @MaxRecords@
-- value, a value is returned in a @marker@ field of the response. You can
-- retrieve the next set of records by retrying the command with the
-- returned marker value.
--
-- Default: @100@
--
-- Constraints: minimum 20, maximum 100.
describeReservedNodeOfferings_maxRecords :: Lens.Lens' DescribeReservedNodeOfferings (Prelude.Maybe Prelude.Int)
describeReservedNodeOfferings_maxRecords :: Lens' DescribeReservedNodeOfferings (Maybe Int)
describeReservedNodeOfferings_maxRecords = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedNodeOfferings' {Maybe Int
maxRecords :: Maybe Int
$sel:maxRecords:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Int
maxRecords} -> Maybe Int
maxRecords) (\s :: DescribeReservedNodeOfferings
s@DescribeReservedNodeOfferings' {} Maybe Int
a -> DescribeReservedNodeOfferings
s {$sel:maxRecords:DescribeReservedNodeOfferings' :: Maybe Int
maxRecords = Maybe Int
a} :: DescribeReservedNodeOfferings)

-- | The unique identifier for the offering.
describeReservedNodeOfferings_reservedNodeOfferingId :: Lens.Lens' DescribeReservedNodeOfferings (Prelude.Maybe Prelude.Text)
describeReservedNodeOfferings_reservedNodeOfferingId :: Lens' DescribeReservedNodeOfferings (Maybe Text)
describeReservedNodeOfferings_reservedNodeOfferingId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedNodeOfferings' {Maybe Text
reservedNodeOfferingId :: Maybe Text
$sel:reservedNodeOfferingId:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Text
reservedNodeOfferingId} -> Maybe Text
reservedNodeOfferingId) (\s :: DescribeReservedNodeOfferings
s@DescribeReservedNodeOfferings' {} Maybe Text
a -> DescribeReservedNodeOfferings
s {$sel:reservedNodeOfferingId:DescribeReservedNodeOfferings' :: Maybe Text
reservedNodeOfferingId = Maybe Text
a} :: DescribeReservedNodeOfferings)

instance Core.AWSPager DescribeReservedNodeOfferings where
  page :: DescribeReservedNodeOfferings
-> AWSResponse DescribeReservedNodeOfferings
-> Maybe DescribeReservedNodeOfferings
page DescribeReservedNodeOfferings
rq AWSResponse DescribeReservedNodeOfferings
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse DescribeReservedNodeOfferings
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeReservedNodeOfferingsResponse (Maybe Text)
describeReservedNodeOfferingsResponse_marker
            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 DescribeReservedNodeOfferings
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens'
  DescribeReservedNodeOfferingsResponse
  (Maybe [ReservedNodeOffering])
describeReservedNodeOfferingsResponse_reservedNodeOfferings
            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.$ DescribeReservedNodeOfferings
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' DescribeReservedNodeOfferings (Maybe Text)
describeReservedNodeOfferings_marker
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse DescribeReservedNodeOfferings
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeReservedNodeOfferingsResponse (Maybe Text)
describeReservedNodeOfferingsResponse_marker
          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
    DescribeReservedNodeOfferings
  where
  type
    AWSResponse DescribeReservedNodeOfferings =
      DescribeReservedNodeOfferingsResponse
  request :: (Service -> Service)
-> DescribeReservedNodeOfferings
-> Request DescribeReservedNodeOfferings
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DescribeReservedNodeOfferings
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DescribeReservedNodeOfferings)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
Text
-> (Int
    -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXMLWrapper
      Text
"DescribeReservedNodeOfferingsResult"
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Maybe Text
-> Maybe [ReservedNodeOffering]
-> Int
-> DescribeReservedNodeOfferingsResponse
DescribeReservedNodeOfferingsResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"Marker")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ( [Node]
x
                            forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"ReservedNodeOfferings"
                            forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty
                            forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
Prelude.>>= forall (f :: * -> *) a b.
Applicative f =>
([a] -> f b) -> [a] -> f (Maybe b)
Core.may (forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"ReservedNodeOffering")
                        )
            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
    DescribeReservedNodeOfferings
  where
  hashWithSalt :: Int -> DescribeReservedNodeOfferings -> Int
hashWithSalt Int
_salt DescribeReservedNodeOfferings' {Maybe Int
Maybe Text
reservedNodeOfferingId :: Maybe Text
maxRecords :: Maybe Int
marker :: Maybe Text
$sel:reservedNodeOfferingId:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Text
$sel:maxRecords:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Int
$sel:marker:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
marker
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Int
maxRecords
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
reservedNodeOfferingId

instance Prelude.NFData DescribeReservedNodeOfferings where
  rnf :: DescribeReservedNodeOfferings -> ()
rnf DescribeReservedNodeOfferings' {Maybe Int
Maybe Text
reservedNodeOfferingId :: Maybe Text
maxRecords :: Maybe Int
marker :: Maybe Text
$sel:reservedNodeOfferingId:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Text
$sel:maxRecords:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Int
$sel:marker:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Text
..} =
    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 Int
maxRecords
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
reservedNodeOfferingId

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

instance Data.ToPath DescribeReservedNodeOfferings where
  toPath :: DescribeReservedNodeOfferings -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery DescribeReservedNodeOfferings where
  toQuery :: DescribeReservedNodeOfferings -> QueryString
toQuery DescribeReservedNodeOfferings' {Maybe Int
Maybe Text
reservedNodeOfferingId :: Maybe Text
maxRecords :: Maybe Int
marker :: Maybe Text
$sel:reservedNodeOfferingId:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Text
$sel:maxRecords:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Int
$sel:marker:DescribeReservedNodeOfferings' :: DescribeReservedNodeOfferings -> Maybe Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: ( ByteString
"DescribeReservedNodeOfferings" ::
                      Prelude.ByteString
                  ),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2012-12-01" :: Prelude.ByteString),
        ByteString
"Marker" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
marker,
        ByteString
"MaxRecords" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Int
maxRecords,
        ByteString
"ReservedNodeOfferingId"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
reservedNodeOfferingId
      ]

-- |
--
-- /See:/ 'newDescribeReservedNodeOfferingsResponse' smart constructor.
data DescribeReservedNodeOfferingsResponse = DescribeReservedNodeOfferingsResponse'
  { -- | A value that indicates the starting point for the next set of response
    -- records in a subsequent request. If a value is returned in a response,
    -- you can retrieve the next set of records by providing this returned
    -- marker value in the @Marker@ parameter and retrying the command. If the
    -- @Marker@ field is empty, all response records have been retrieved for
    -- the request.
    DescribeReservedNodeOfferingsResponse -> Maybe Text
marker :: Prelude.Maybe Prelude.Text,
    -- | A list of @ReservedNodeOffering@ objects.
    DescribeReservedNodeOfferingsResponse
-> Maybe [ReservedNodeOffering]
reservedNodeOfferings :: Prelude.Maybe [ReservedNodeOffering],
    -- | The response's http status code.
    DescribeReservedNodeOfferingsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeReservedNodeOfferingsResponse
-> DescribeReservedNodeOfferingsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeReservedNodeOfferingsResponse
-> DescribeReservedNodeOfferingsResponse -> Bool
$c/= :: DescribeReservedNodeOfferingsResponse
-> DescribeReservedNodeOfferingsResponse -> Bool
== :: DescribeReservedNodeOfferingsResponse
-> DescribeReservedNodeOfferingsResponse -> Bool
$c== :: DescribeReservedNodeOfferingsResponse
-> DescribeReservedNodeOfferingsResponse -> Bool
Prelude.Eq, ReadPrec [DescribeReservedNodeOfferingsResponse]
ReadPrec DescribeReservedNodeOfferingsResponse
Int -> ReadS DescribeReservedNodeOfferingsResponse
ReadS [DescribeReservedNodeOfferingsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeReservedNodeOfferingsResponse]
$creadListPrec :: ReadPrec [DescribeReservedNodeOfferingsResponse]
readPrec :: ReadPrec DescribeReservedNodeOfferingsResponse
$creadPrec :: ReadPrec DescribeReservedNodeOfferingsResponse
readList :: ReadS [DescribeReservedNodeOfferingsResponse]
$creadList :: ReadS [DescribeReservedNodeOfferingsResponse]
readsPrec :: Int -> ReadS DescribeReservedNodeOfferingsResponse
$creadsPrec :: Int -> ReadS DescribeReservedNodeOfferingsResponse
Prelude.Read, Int -> DescribeReservedNodeOfferingsResponse -> ShowS
[DescribeReservedNodeOfferingsResponse] -> ShowS
DescribeReservedNodeOfferingsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeReservedNodeOfferingsResponse] -> ShowS
$cshowList :: [DescribeReservedNodeOfferingsResponse] -> ShowS
show :: DescribeReservedNodeOfferingsResponse -> String
$cshow :: DescribeReservedNodeOfferingsResponse -> String
showsPrec :: Int -> DescribeReservedNodeOfferingsResponse -> ShowS
$cshowsPrec :: Int -> DescribeReservedNodeOfferingsResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeReservedNodeOfferingsResponse x
-> DescribeReservedNodeOfferingsResponse
forall x.
DescribeReservedNodeOfferingsResponse
-> Rep DescribeReservedNodeOfferingsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeReservedNodeOfferingsResponse x
-> DescribeReservedNodeOfferingsResponse
$cfrom :: forall x.
DescribeReservedNodeOfferingsResponse
-> Rep DescribeReservedNodeOfferingsResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeReservedNodeOfferingsResponse' 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:
--
-- 'marker', 'describeReservedNodeOfferingsResponse_marker' - A value that indicates the starting point for the next set of response
-- records in a subsequent request. If a value is returned in a response,
-- you can retrieve the next set of records by providing this returned
-- marker value in the @Marker@ parameter and retrying the command. If the
-- @Marker@ field is empty, all response records have been retrieved for
-- the request.
--
-- 'reservedNodeOfferings', 'describeReservedNodeOfferingsResponse_reservedNodeOfferings' - A list of @ReservedNodeOffering@ objects.
--
-- 'httpStatus', 'describeReservedNodeOfferingsResponse_httpStatus' - The response's http status code.
newDescribeReservedNodeOfferingsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeReservedNodeOfferingsResponse
newDescribeReservedNodeOfferingsResponse :: Int -> DescribeReservedNodeOfferingsResponse
newDescribeReservedNodeOfferingsResponse Int
pHttpStatus_ =
  DescribeReservedNodeOfferingsResponse'
    { $sel:marker:DescribeReservedNodeOfferingsResponse' :: Maybe Text
marker =
        forall a. Maybe a
Prelude.Nothing,
      $sel:reservedNodeOfferings:DescribeReservedNodeOfferingsResponse' :: Maybe [ReservedNodeOffering]
reservedNodeOfferings =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeReservedNodeOfferingsResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | A value that indicates the starting point for the next set of response
-- records in a subsequent request. If a value is returned in a response,
-- you can retrieve the next set of records by providing this returned
-- marker value in the @Marker@ parameter and retrying the command. If the
-- @Marker@ field is empty, all response records have been retrieved for
-- the request.
describeReservedNodeOfferingsResponse_marker :: Lens.Lens' DescribeReservedNodeOfferingsResponse (Prelude.Maybe Prelude.Text)
describeReservedNodeOfferingsResponse_marker :: Lens' DescribeReservedNodeOfferingsResponse (Maybe Text)
describeReservedNodeOfferingsResponse_marker = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedNodeOfferingsResponse' {Maybe Text
marker :: Maybe Text
$sel:marker:DescribeReservedNodeOfferingsResponse' :: DescribeReservedNodeOfferingsResponse -> Maybe Text
marker} -> Maybe Text
marker) (\s :: DescribeReservedNodeOfferingsResponse
s@DescribeReservedNodeOfferingsResponse' {} Maybe Text
a -> DescribeReservedNodeOfferingsResponse
s {$sel:marker:DescribeReservedNodeOfferingsResponse' :: Maybe Text
marker = Maybe Text
a} :: DescribeReservedNodeOfferingsResponse)

-- | A list of @ReservedNodeOffering@ objects.
describeReservedNodeOfferingsResponse_reservedNodeOfferings :: Lens.Lens' DescribeReservedNodeOfferingsResponse (Prelude.Maybe [ReservedNodeOffering])
describeReservedNodeOfferingsResponse_reservedNodeOfferings :: Lens'
  DescribeReservedNodeOfferingsResponse
  (Maybe [ReservedNodeOffering])
describeReservedNodeOfferingsResponse_reservedNodeOfferings = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedNodeOfferingsResponse' {Maybe [ReservedNodeOffering]
reservedNodeOfferings :: Maybe [ReservedNodeOffering]
$sel:reservedNodeOfferings:DescribeReservedNodeOfferingsResponse' :: DescribeReservedNodeOfferingsResponse
-> Maybe [ReservedNodeOffering]
reservedNodeOfferings} -> Maybe [ReservedNodeOffering]
reservedNodeOfferings) (\s :: DescribeReservedNodeOfferingsResponse
s@DescribeReservedNodeOfferingsResponse' {} Maybe [ReservedNodeOffering]
a -> DescribeReservedNodeOfferingsResponse
s {$sel:reservedNodeOfferings:DescribeReservedNodeOfferingsResponse' :: Maybe [ReservedNodeOffering]
reservedNodeOfferings = Maybe [ReservedNodeOffering]
a} :: DescribeReservedNodeOfferingsResponse) 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.
describeReservedNodeOfferingsResponse_httpStatus :: Lens.Lens' DescribeReservedNodeOfferingsResponse Prelude.Int
describeReservedNodeOfferingsResponse_httpStatus :: Lens' DescribeReservedNodeOfferingsResponse Int
describeReservedNodeOfferingsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedNodeOfferingsResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeReservedNodeOfferingsResponse' :: DescribeReservedNodeOfferingsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeReservedNodeOfferingsResponse
s@DescribeReservedNodeOfferingsResponse' {} Int
a -> DescribeReservedNodeOfferingsResponse
s {$sel:httpStatus:DescribeReservedNodeOfferingsResponse' :: Int
httpStatus = Int
a} :: DescribeReservedNodeOfferingsResponse)

instance
  Prelude.NFData
    DescribeReservedNodeOfferingsResponse
  where
  rnf :: DescribeReservedNodeOfferingsResponse -> ()
rnf DescribeReservedNodeOfferingsResponse' {Int
Maybe [ReservedNodeOffering]
Maybe Text
httpStatus :: Int
reservedNodeOfferings :: Maybe [ReservedNodeOffering]
marker :: Maybe Text
$sel:httpStatus:DescribeReservedNodeOfferingsResponse' :: DescribeReservedNodeOfferingsResponse -> Int
$sel:reservedNodeOfferings:DescribeReservedNodeOfferingsResponse' :: DescribeReservedNodeOfferingsResponse
-> Maybe [ReservedNodeOffering]
$sel:marker:DescribeReservedNodeOfferingsResponse' :: DescribeReservedNodeOfferingsResponse -> Maybe Text
..} =
    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 [ReservedNodeOffering]
reservedNodeOfferings
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus