{-# 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.OpenSearch.DescribeReservedInstanceOfferings
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Describes the available Amazon OpenSearch Service Reserved Instance
-- offerings for a given Region. For more information, see
-- <https://docs.aws.amazon.com/opensearch-service/latest/developerguide/ri.html Reserved Instances in Amazon OpenSearch Service>.
module Amazonka.OpenSearch.DescribeReservedInstanceOfferings
  ( -- * Creating a Request
    DescribeReservedInstanceOfferings (..),
    newDescribeReservedInstanceOfferings,

    -- * Request Lenses
    describeReservedInstanceOfferings_maxResults,
    describeReservedInstanceOfferings_nextToken,
    describeReservedInstanceOfferings_reservedInstanceOfferingId,

    -- * Destructuring the Response
    DescribeReservedInstanceOfferingsResponse (..),
    newDescribeReservedInstanceOfferingsResponse,

    -- * Response Lenses
    describeReservedInstanceOfferingsResponse_nextToken,
    describeReservedInstanceOfferingsResponse_reservedInstanceOfferings,
    describeReservedInstanceOfferingsResponse_httpStatus,
  )
where

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

-- | Container for the request parameters to a
-- @DescribeReservedInstanceOfferings@ operation.
--
-- /See:/ 'newDescribeReservedInstanceOfferings' smart constructor.
data DescribeReservedInstanceOfferings = DescribeReservedInstanceOfferings'
  { -- | An optional parameter that specifies the maximum number of results to
    -- return. You can use @nextToken@ to get the next page of results.
    DescribeReservedInstanceOfferings -> Maybe Int
maxResults :: Prelude.Maybe Prelude.Int,
    -- | If your initial @DescribeReservedInstanceOfferings@ operation returns a
    -- @nextToken@, you can include the returned @nextToken@ in subsequent
    -- @DescribeReservedInstanceOfferings@ operations, which returns results in
    -- the next page.
    DescribeReservedInstanceOfferings -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The Reserved Instance identifier filter value. Use this parameter to
    -- show only the available instance types that match the specified
    -- reservation identifier.
    DescribeReservedInstanceOfferings -> Maybe Text
reservedInstanceOfferingId :: Prelude.Maybe Prelude.Text
  }
  deriving (DescribeReservedInstanceOfferings
-> DescribeReservedInstanceOfferings -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeReservedInstanceOfferings
-> DescribeReservedInstanceOfferings -> Bool
$c/= :: DescribeReservedInstanceOfferings
-> DescribeReservedInstanceOfferings -> Bool
== :: DescribeReservedInstanceOfferings
-> DescribeReservedInstanceOfferings -> Bool
$c== :: DescribeReservedInstanceOfferings
-> DescribeReservedInstanceOfferings -> Bool
Prelude.Eq, ReadPrec [DescribeReservedInstanceOfferings]
ReadPrec DescribeReservedInstanceOfferings
Int -> ReadS DescribeReservedInstanceOfferings
ReadS [DescribeReservedInstanceOfferings]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeReservedInstanceOfferings]
$creadListPrec :: ReadPrec [DescribeReservedInstanceOfferings]
readPrec :: ReadPrec DescribeReservedInstanceOfferings
$creadPrec :: ReadPrec DescribeReservedInstanceOfferings
readList :: ReadS [DescribeReservedInstanceOfferings]
$creadList :: ReadS [DescribeReservedInstanceOfferings]
readsPrec :: Int -> ReadS DescribeReservedInstanceOfferings
$creadsPrec :: Int -> ReadS DescribeReservedInstanceOfferings
Prelude.Read, Int -> DescribeReservedInstanceOfferings -> ShowS
[DescribeReservedInstanceOfferings] -> ShowS
DescribeReservedInstanceOfferings -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeReservedInstanceOfferings] -> ShowS
$cshowList :: [DescribeReservedInstanceOfferings] -> ShowS
show :: DescribeReservedInstanceOfferings -> String
$cshow :: DescribeReservedInstanceOfferings -> String
showsPrec :: Int -> DescribeReservedInstanceOfferings -> ShowS
$cshowsPrec :: Int -> DescribeReservedInstanceOfferings -> ShowS
Prelude.Show, forall x.
Rep DescribeReservedInstanceOfferings x
-> DescribeReservedInstanceOfferings
forall x.
DescribeReservedInstanceOfferings
-> Rep DescribeReservedInstanceOfferings x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeReservedInstanceOfferings x
-> DescribeReservedInstanceOfferings
$cfrom :: forall x.
DescribeReservedInstanceOfferings
-> Rep DescribeReservedInstanceOfferings x
Prelude.Generic)

-- |
-- Create a value of 'DescribeReservedInstanceOfferings' 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', 'describeReservedInstanceOfferings_maxResults' - An optional parameter that specifies the maximum number of results to
-- return. You can use @nextToken@ to get the next page of results.
--
-- 'nextToken', 'describeReservedInstanceOfferings_nextToken' - If your initial @DescribeReservedInstanceOfferings@ operation returns a
-- @nextToken@, you can include the returned @nextToken@ in subsequent
-- @DescribeReservedInstanceOfferings@ operations, which returns results in
-- the next page.
--
-- 'reservedInstanceOfferingId', 'describeReservedInstanceOfferings_reservedInstanceOfferingId' - The Reserved Instance identifier filter value. Use this parameter to
-- show only the available instance types that match the specified
-- reservation identifier.
newDescribeReservedInstanceOfferings ::
  DescribeReservedInstanceOfferings
newDescribeReservedInstanceOfferings :: DescribeReservedInstanceOfferings
newDescribeReservedInstanceOfferings =
  DescribeReservedInstanceOfferings'
    { $sel:maxResults:DescribeReservedInstanceOfferings' :: Maybe Int
maxResults =
        forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:DescribeReservedInstanceOfferings' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:reservedInstanceOfferingId:DescribeReservedInstanceOfferings' :: Maybe Text
reservedInstanceOfferingId =
        forall a. Maybe a
Prelude.Nothing
    }

-- | An optional parameter that specifies the maximum number of results to
-- return. You can use @nextToken@ to get the next page of results.
describeReservedInstanceOfferings_maxResults :: Lens.Lens' DescribeReservedInstanceOfferings (Prelude.Maybe Prelude.Int)
describeReservedInstanceOfferings_maxResults :: Lens' DescribeReservedInstanceOfferings (Maybe Int)
describeReservedInstanceOfferings_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstanceOfferings' {Maybe Int
maxResults :: Maybe Int
$sel:maxResults:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Int
maxResults} -> Maybe Int
maxResults) (\s :: DescribeReservedInstanceOfferings
s@DescribeReservedInstanceOfferings' {} Maybe Int
a -> DescribeReservedInstanceOfferings
s {$sel:maxResults:DescribeReservedInstanceOfferings' :: Maybe Int
maxResults = Maybe Int
a} :: DescribeReservedInstanceOfferings)

-- | If your initial @DescribeReservedInstanceOfferings@ operation returns a
-- @nextToken@, you can include the returned @nextToken@ in subsequent
-- @DescribeReservedInstanceOfferings@ operations, which returns results in
-- the next page.
describeReservedInstanceOfferings_nextToken :: Lens.Lens' DescribeReservedInstanceOfferings (Prelude.Maybe Prelude.Text)
describeReservedInstanceOfferings_nextToken :: Lens' DescribeReservedInstanceOfferings (Maybe Text)
describeReservedInstanceOfferings_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstanceOfferings' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeReservedInstanceOfferings
s@DescribeReservedInstanceOfferings' {} Maybe Text
a -> DescribeReservedInstanceOfferings
s {$sel:nextToken:DescribeReservedInstanceOfferings' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeReservedInstanceOfferings)

-- | The Reserved Instance identifier filter value. Use this parameter to
-- show only the available instance types that match the specified
-- reservation identifier.
describeReservedInstanceOfferings_reservedInstanceOfferingId :: Lens.Lens' DescribeReservedInstanceOfferings (Prelude.Maybe Prelude.Text)
describeReservedInstanceOfferings_reservedInstanceOfferingId :: Lens' DescribeReservedInstanceOfferings (Maybe Text)
describeReservedInstanceOfferings_reservedInstanceOfferingId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstanceOfferings' {Maybe Text
reservedInstanceOfferingId :: Maybe Text
$sel:reservedInstanceOfferingId:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Text
reservedInstanceOfferingId} -> Maybe Text
reservedInstanceOfferingId) (\s :: DescribeReservedInstanceOfferings
s@DescribeReservedInstanceOfferings' {} Maybe Text
a -> DescribeReservedInstanceOfferings
s {$sel:reservedInstanceOfferingId:DescribeReservedInstanceOfferings' :: Maybe Text
reservedInstanceOfferingId = Maybe Text
a} :: DescribeReservedInstanceOfferings)

instance
  Core.AWSRequest
    DescribeReservedInstanceOfferings
  where
  type
    AWSResponse DescribeReservedInstanceOfferings =
      DescribeReservedInstanceOfferingsResponse
  request :: (Service -> Service)
-> DescribeReservedInstanceOfferings
-> Request DescribeReservedInstanceOfferings
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 DescribeReservedInstanceOfferings
-> ClientResponse ClientBody
-> m (Either
        Error
        (ClientResponse (AWSResponse DescribeReservedInstanceOfferings)))
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 [ReservedInstanceOffering]
-> Int
-> DescribeReservedInstanceOfferingsResponse
DescribeReservedInstanceOfferingsResponse'
            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
"ReservedInstanceOfferings"
                            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
    DescribeReservedInstanceOfferings
  where
  hashWithSalt :: Int -> DescribeReservedInstanceOfferings -> Int
hashWithSalt
    Int
_salt
    DescribeReservedInstanceOfferings' {Maybe Int
Maybe Text
reservedInstanceOfferingId :: Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Int
$sel:reservedInstanceOfferingId:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Text
$sel:nextToken:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Text
$sel:maxResults:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Int
..} =
      Int
_salt
        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 Text
reservedInstanceOfferingId

instance
  Prelude.NFData
    DescribeReservedInstanceOfferings
  where
  rnf :: DescribeReservedInstanceOfferings -> ()
rnf DescribeReservedInstanceOfferings' {Maybe Int
Maybe Text
reservedInstanceOfferingId :: Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Int
$sel:reservedInstanceOfferingId:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Text
$sel:nextToken:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Text
$sel:maxResults:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Int
..} =
    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 Text
reservedInstanceOfferingId

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

instance
  Data.ToPath
    DescribeReservedInstanceOfferings
  where
  toPath :: DescribeReservedInstanceOfferings -> ByteString
toPath =
    forall a b. a -> b -> a
Prelude.const
      ByteString
"/2021-01-01/opensearch/reservedInstanceOfferings"

instance
  Data.ToQuery
    DescribeReservedInstanceOfferings
  where
  toQuery :: DescribeReservedInstanceOfferings -> QueryString
toQuery DescribeReservedInstanceOfferings' {Maybe Int
Maybe Text
reservedInstanceOfferingId :: Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Int
$sel:reservedInstanceOfferingId:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Text
$sel:nextToken:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Text
$sel:maxResults:DescribeReservedInstanceOfferings' :: DescribeReservedInstanceOfferings -> Maybe Int
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ 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
"offeringId" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
reservedInstanceOfferingId
      ]

-- | Container for results of a @DescribeReservedInstanceOfferings@ request.
--
-- /See:/ 'newDescribeReservedInstanceOfferingsResponse' smart constructor.
data DescribeReservedInstanceOfferingsResponse = DescribeReservedInstanceOfferingsResponse'
  { -- | When @nextToken@ is returned, there are more results available. The
    -- value of @nextToken@ is a unique pagination token for each page. Make
    -- the call again using the returned token to retrieve the next page.
    DescribeReservedInstanceOfferingsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | List of Reserved Instance offerings.
    DescribeReservedInstanceOfferingsResponse
-> Maybe [ReservedInstanceOffering]
reservedInstanceOfferings :: Prelude.Maybe [ReservedInstanceOffering],
    -- | The response's http status code.
    DescribeReservedInstanceOfferingsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeReservedInstanceOfferingsResponse
-> DescribeReservedInstanceOfferingsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeReservedInstanceOfferingsResponse
-> DescribeReservedInstanceOfferingsResponse -> Bool
$c/= :: DescribeReservedInstanceOfferingsResponse
-> DescribeReservedInstanceOfferingsResponse -> Bool
== :: DescribeReservedInstanceOfferingsResponse
-> DescribeReservedInstanceOfferingsResponse -> Bool
$c== :: DescribeReservedInstanceOfferingsResponse
-> DescribeReservedInstanceOfferingsResponse -> Bool
Prelude.Eq, ReadPrec [DescribeReservedInstanceOfferingsResponse]
ReadPrec DescribeReservedInstanceOfferingsResponse
Int -> ReadS DescribeReservedInstanceOfferingsResponse
ReadS [DescribeReservedInstanceOfferingsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeReservedInstanceOfferingsResponse]
$creadListPrec :: ReadPrec [DescribeReservedInstanceOfferingsResponse]
readPrec :: ReadPrec DescribeReservedInstanceOfferingsResponse
$creadPrec :: ReadPrec DescribeReservedInstanceOfferingsResponse
readList :: ReadS [DescribeReservedInstanceOfferingsResponse]
$creadList :: ReadS [DescribeReservedInstanceOfferingsResponse]
readsPrec :: Int -> ReadS DescribeReservedInstanceOfferingsResponse
$creadsPrec :: Int -> ReadS DescribeReservedInstanceOfferingsResponse
Prelude.Read, Int -> DescribeReservedInstanceOfferingsResponse -> ShowS
[DescribeReservedInstanceOfferingsResponse] -> ShowS
DescribeReservedInstanceOfferingsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeReservedInstanceOfferingsResponse] -> ShowS
$cshowList :: [DescribeReservedInstanceOfferingsResponse] -> ShowS
show :: DescribeReservedInstanceOfferingsResponse -> String
$cshow :: DescribeReservedInstanceOfferingsResponse -> String
showsPrec :: Int -> DescribeReservedInstanceOfferingsResponse -> ShowS
$cshowsPrec :: Int -> DescribeReservedInstanceOfferingsResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeReservedInstanceOfferingsResponse x
-> DescribeReservedInstanceOfferingsResponse
forall x.
DescribeReservedInstanceOfferingsResponse
-> Rep DescribeReservedInstanceOfferingsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeReservedInstanceOfferingsResponse x
-> DescribeReservedInstanceOfferingsResponse
$cfrom :: forall x.
DescribeReservedInstanceOfferingsResponse
-> Rep DescribeReservedInstanceOfferingsResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeReservedInstanceOfferingsResponse' 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', 'describeReservedInstanceOfferingsResponse_nextToken' - When @nextToken@ is returned, there are more results available. The
-- value of @nextToken@ is a unique pagination token for each page. Make
-- the call again using the returned token to retrieve the next page.
--
-- 'reservedInstanceOfferings', 'describeReservedInstanceOfferingsResponse_reservedInstanceOfferings' - List of Reserved Instance offerings.
--
-- 'httpStatus', 'describeReservedInstanceOfferingsResponse_httpStatus' - The response's http status code.
newDescribeReservedInstanceOfferingsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeReservedInstanceOfferingsResponse
newDescribeReservedInstanceOfferingsResponse :: Int -> DescribeReservedInstanceOfferingsResponse
newDescribeReservedInstanceOfferingsResponse
  Int
pHttpStatus_ =
    DescribeReservedInstanceOfferingsResponse'
      { $sel:nextToken:DescribeReservedInstanceOfferingsResponse' :: Maybe Text
nextToken =
          forall a. Maybe a
Prelude.Nothing,
        $sel:reservedInstanceOfferings:DescribeReservedInstanceOfferingsResponse' :: Maybe [ReservedInstanceOffering]
reservedInstanceOfferings =
          forall a. Maybe a
Prelude.Nothing,
        $sel:httpStatus:DescribeReservedInstanceOfferingsResponse' :: Int
httpStatus = Int
pHttpStatus_
      }

-- | When @nextToken@ is returned, there are more results available. The
-- value of @nextToken@ is a unique pagination token for each page. Make
-- the call again using the returned token to retrieve the next page.
describeReservedInstanceOfferingsResponse_nextToken :: Lens.Lens' DescribeReservedInstanceOfferingsResponse (Prelude.Maybe Prelude.Text)
describeReservedInstanceOfferingsResponse_nextToken :: Lens' DescribeReservedInstanceOfferingsResponse (Maybe Text)
describeReservedInstanceOfferingsResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstanceOfferingsResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeReservedInstanceOfferingsResponse' :: DescribeReservedInstanceOfferingsResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeReservedInstanceOfferingsResponse
s@DescribeReservedInstanceOfferingsResponse' {} Maybe Text
a -> DescribeReservedInstanceOfferingsResponse
s {$sel:nextToken:DescribeReservedInstanceOfferingsResponse' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeReservedInstanceOfferingsResponse)

-- | List of Reserved Instance offerings.
describeReservedInstanceOfferingsResponse_reservedInstanceOfferings :: Lens.Lens' DescribeReservedInstanceOfferingsResponse (Prelude.Maybe [ReservedInstanceOffering])
describeReservedInstanceOfferingsResponse_reservedInstanceOfferings :: Lens'
  DescribeReservedInstanceOfferingsResponse
  (Maybe [ReservedInstanceOffering])
describeReservedInstanceOfferingsResponse_reservedInstanceOfferings = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstanceOfferingsResponse' {Maybe [ReservedInstanceOffering]
reservedInstanceOfferings :: Maybe [ReservedInstanceOffering]
$sel:reservedInstanceOfferings:DescribeReservedInstanceOfferingsResponse' :: DescribeReservedInstanceOfferingsResponse
-> Maybe [ReservedInstanceOffering]
reservedInstanceOfferings} -> Maybe [ReservedInstanceOffering]
reservedInstanceOfferings) (\s :: DescribeReservedInstanceOfferingsResponse
s@DescribeReservedInstanceOfferingsResponse' {} Maybe [ReservedInstanceOffering]
a -> DescribeReservedInstanceOfferingsResponse
s {$sel:reservedInstanceOfferings:DescribeReservedInstanceOfferingsResponse' :: Maybe [ReservedInstanceOffering]
reservedInstanceOfferings = Maybe [ReservedInstanceOffering]
a} :: DescribeReservedInstanceOfferingsResponse) 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.
describeReservedInstanceOfferingsResponse_httpStatus :: Lens.Lens' DescribeReservedInstanceOfferingsResponse Prelude.Int
describeReservedInstanceOfferingsResponse_httpStatus :: Lens' DescribeReservedInstanceOfferingsResponse Int
describeReservedInstanceOfferingsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstanceOfferingsResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeReservedInstanceOfferingsResponse' :: DescribeReservedInstanceOfferingsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeReservedInstanceOfferingsResponse
s@DescribeReservedInstanceOfferingsResponse' {} Int
a -> DescribeReservedInstanceOfferingsResponse
s {$sel:httpStatus:DescribeReservedInstanceOfferingsResponse' :: Int
httpStatus = Int
a} :: DescribeReservedInstanceOfferingsResponse)

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