{-# 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.DescribeReservedInstances
-- 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 Amazon OpenSearch Service instances that you have reserved
-- in 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.DescribeReservedInstances
  ( -- * Creating a Request
    DescribeReservedInstances (..),
    newDescribeReservedInstances,

    -- * Request Lenses
    describeReservedInstances_maxResults,
    describeReservedInstances_nextToken,
    describeReservedInstances_reservedInstanceId,

    -- * Destructuring the Response
    DescribeReservedInstancesResponse (..),
    newDescribeReservedInstancesResponse,

    -- * Response Lenses
    describeReservedInstancesResponse_nextToken,
    describeReservedInstancesResponse_reservedInstances,
    describeReservedInstancesResponse_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 the @DescribeReservedInstances@
-- operation.
--
-- /See:/ 'newDescribeReservedInstances' smart constructor.
data DescribeReservedInstances = DescribeReservedInstances'
  { -- | An optional parameter that specifies the maximum number of results to
    -- return. You can use @nextToken@ to get the next page of results.
    DescribeReservedInstances -> Maybe Int
maxResults :: Prelude.Maybe Prelude.Int,
    -- | If your initial @DescribeReservedInstances@ operation returns a
    -- @nextToken@, you can include the returned @nextToken@ in subsequent
    -- @DescribeReservedInstances@ operations, which returns results in the
    -- next page.
    DescribeReservedInstances -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The reserved instance identifier filter value. Use this parameter to
    -- show only the reservation that matches the specified reserved OpenSearch
    -- instance ID.
    DescribeReservedInstances -> Maybe Text
reservedInstanceId :: Prelude.Maybe Prelude.Text
  }
  deriving (DescribeReservedInstances -> DescribeReservedInstances -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeReservedInstances -> DescribeReservedInstances -> Bool
$c/= :: DescribeReservedInstances -> DescribeReservedInstances -> Bool
== :: DescribeReservedInstances -> DescribeReservedInstances -> Bool
$c== :: DescribeReservedInstances -> DescribeReservedInstances -> Bool
Prelude.Eq, ReadPrec [DescribeReservedInstances]
ReadPrec DescribeReservedInstances
Int -> ReadS DescribeReservedInstances
ReadS [DescribeReservedInstances]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeReservedInstances]
$creadListPrec :: ReadPrec [DescribeReservedInstances]
readPrec :: ReadPrec DescribeReservedInstances
$creadPrec :: ReadPrec DescribeReservedInstances
readList :: ReadS [DescribeReservedInstances]
$creadList :: ReadS [DescribeReservedInstances]
readsPrec :: Int -> ReadS DescribeReservedInstances
$creadsPrec :: Int -> ReadS DescribeReservedInstances
Prelude.Read, Int -> DescribeReservedInstances -> ShowS
[DescribeReservedInstances] -> ShowS
DescribeReservedInstances -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeReservedInstances] -> ShowS
$cshowList :: [DescribeReservedInstances] -> ShowS
show :: DescribeReservedInstances -> String
$cshow :: DescribeReservedInstances -> String
showsPrec :: Int -> DescribeReservedInstances -> ShowS
$cshowsPrec :: Int -> DescribeReservedInstances -> ShowS
Prelude.Show, forall x.
Rep DescribeReservedInstances x -> DescribeReservedInstances
forall x.
DescribeReservedInstances -> Rep DescribeReservedInstances x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeReservedInstances x -> DescribeReservedInstances
$cfrom :: forall x.
DescribeReservedInstances -> Rep DescribeReservedInstances x
Prelude.Generic)

-- |
-- Create a value of 'DescribeReservedInstances' 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', 'describeReservedInstances_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', 'describeReservedInstances_nextToken' - If your initial @DescribeReservedInstances@ operation returns a
-- @nextToken@, you can include the returned @nextToken@ in subsequent
-- @DescribeReservedInstances@ operations, which returns results in the
-- next page.
--
-- 'reservedInstanceId', 'describeReservedInstances_reservedInstanceId' - The reserved instance identifier filter value. Use this parameter to
-- show only the reservation that matches the specified reserved OpenSearch
-- instance ID.
newDescribeReservedInstances ::
  DescribeReservedInstances
newDescribeReservedInstances :: DescribeReservedInstances
newDescribeReservedInstances =
  DescribeReservedInstances'
    { $sel:maxResults:DescribeReservedInstances' :: Maybe Int
maxResults =
        forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:DescribeReservedInstances' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:reservedInstanceId:DescribeReservedInstances' :: Maybe Text
reservedInstanceId = 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.
describeReservedInstances_maxResults :: Lens.Lens' DescribeReservedInstances (Prelude.Maybe Prelude.Int)
describeReservedInstances_maxResults :: Lens' DescribeReservedInstances (Maybe Int)
describeReservedInstances_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstances' {Maybe Int
maxResults :: Maybe Int
$sel:maxResults:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe Int
maxResults} -> Maybe Int
maxResults) (\s :: DescribeReservedInstances
s@DescribeReservedInstances' {} Maybe Int
a -> DescribeReservedInstances
s {$sel:maxResults:DescribeReservedInstances' :: Maybe Int
maxResults = Maybe Int
a} :: DescribeReservedInstances)

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

-- | The reserved instance identifier filter value. Use this parameter to
-- show only the reservation that matches the specified reserved OpenSearch
-- instance ID.
describeReservedInstances_reservedInstanceId :: Lens.Lens' DescribeReservedInstances (Prelude.Maybe Prelude.Text)
describeReservedInstances_reservedInstanceId :: Lens' DescribeReservedInstances (Maybe Text)
describeReservedInstances_reservedInstanceId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstances' {Maybe Text
reservedInstanceId :: Maybe Text
$sel:reservedInstanceId:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe Text
reservedInstanceId} -> Maybe Text
reservedInstanceId) (\s :: DescribeReservedInstances
s@DescribeReservedInstances' {} Maybe Text
a -> DescribeReservedInstances
s {$sel:reservedInstanceId:DescribeReservedInstances' :: Maybe Text
reservedInstanceId = Maybe Text
a} :: DescribeReservedInstances)

instance Core.AWSRequest DescribeReservedInstances where
  type
    AWSResponse DescribeReservedInstances =
      DescribeReservedInstancesResponse
  request :: (Service -> Service)
-> DescribeReservedInstances -> Request DescribeReservedInstances
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 DescribeReservedInstances
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DescribeReservedInstances)))
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 [ReservedInstance]
-> Int
-> DescribeReservedInstancesResponse
DescribeReservedInstancesResponse'
            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
"ReservedInstances"
                            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 DescribeReservedInstances where
  hashWithSalt :: Int -> DescribeReservedInstances -> Int
hashWithSalt Int
_salt DescribeReservedInstances' {Maybe Int
Maybe Text
reservedInstanceId :: Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Int
$sel:reservedInstanceId:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe Text
$sel:nextToken:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe Text
$sel:maxResults:DescribeReservedInstances' :: DescribeReservedInstances -> 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
reservedInstanceId

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

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

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

instance Data.ToQuery DescribeReservedInstances where
  toQuery :: DescribeReservedInstances -> QueryString
toQuery DescribeReservedInstances' {Maybe Int
Maybe Text
reservedInstanceId :: Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Int
$sel:reservedInstanceId:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe Text
$sel:nextToken:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe Text
$sel:maxResults:DescribeReservedInstances' :: DescribeReservedInstances -> 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
"reservationId" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
reservedInstanceId
      ]

-- | Container for results from @DescribeReservedInstances@
--
-- /See:/ 'newDescribeReservedInstancesResponse' smart constructor.
data DescribeReservedInstancesResponse = DescribeReservedInstancesResponse'
  { -- | 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.
    DescribeReservedInstancesResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | List of Reserved Instances in the current Region.
    DescribeReservedInstancesResponse -> Maybe [ReservedInstance]
reservedInstances :: Prelude.Maybe [ReservedInstance],
    -- | The response's http status code.
    DescribeReservedInstancesResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeReservedInstancesResponse
-> DescribeReservedInstancesResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeReservedInstancesResponse
-> DescribeReservedInstancesResponse -> Bool
$c/= :: DescribeReservedInstancesResponse
-> DescribeReservedInstancesResponse -> Bool
== :: DescribeReservedInstancesResponse
-> DescribeReservedInstancesResponse -> Bool
$c== :: DescribeReservedInstancesResponse
-> DescribeReservedInstancesResponse -> Bool
Prelude.Eq, ReadPrec [DescribeReservedInstancesResponse]
ReadPrec DescribeReservedInstancesResponse
Int -> ReadS DescribeReservedInstancesResponse
ReadS [DescribeReservedInstancesResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeReservedInstancesResponse]
$creadListPrec :: ReadPrec [DescribeReservedInstancesResponse]
readPrec :: ReadPrec DescribeReservedInstancesResponse
$creadPrec :: ReadPrec DescribeReservedInstancesResponse
readList :: ReadS [DescribeReservedInstancesResponse]
$creadList :: ReadS [DescribeReservedInstancesResponse]
readsPrec :: Int -> ReadS DescribeReservedInstancesResponse
$creadsPrec :: Int -> ReadS DescribeReservedInstancesResponse
Prelude.Read, Int -> DescribeReservedInstancesResponse -> ShowS
[DescribeReservedInstancesResponse] -> ShowS
DescribeReservedInstancesResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeReservedInstancesResponse] -> ShowS
$cshowList :: [DescribeReservedInstancesResponse] -> ShowS
show :: DescribeReservedInstancesResponse -> String
$cshow :: DescribeReservedInstancesResponse -> String
showsPrec :: Int -> DescribeReservedInstancesResponse -> ShowS
$cshowsPrec :: Int -> DescribeReservedInstancesResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeReservedInstancesResponse x
-> DescribeReservedInstancesResponse
forall x.
DescribeReservedInstancesResponse
-> Rep DescribeReservedInstancesResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeReservedInstancesResponse x
-> DescribeReservedInstancesResponse
$cfrom :: forall x.
DescribeReservedInstancesResponse
-> Rep DescribeReservedInstancesResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeReservedInstancesResponse' 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', 'describeReservedInstancesResponse_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.
--
-- 'reservedInstances', 'describeReservedInstancesResponse_reservedInstances' - List of Reserved Instances in the current Region.
--
-- 'httpStatus', 'describeReservedInstancesResponse_httpStatus' - The response's http status code.
newDescribeReservedInstancesResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeReservedInstancesResponse
newDescribeReservedInstancesResponse :: Int -> DescribeReservedInstancesResponse
newDescribeReservedInstancesResponse Int
pHttpStatus_ =
  DescribeReservedInstancesResponse'
    { $sel:nextToken:DescribeReservedInstancesResponse' :: Maybe Text
nextToken =
        forall a. Maybe a
Prelude.Nothing,
      $sel:reservedInstances:DescribeReservedInstancesResponse' :: Maybe [ReservedInstance]
reservedInstances = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeReservedInstancesResponse' :: 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.
describeReservedInstancesResponse_nextToken :: Lens.Lens' DescribeReservedInstancesResponse (Prelude.Maybe Prelude.Text)
describeReservedInstancesResponse_nextToken :: Lens' DescribeReservedInstancesResponse (Maybe Text)
describeReservedInstancesResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstancesResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeReservedInstancesResponse' :: DescribeReservedInstancesResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeReservedInstancesResponse
s@DescribeReservedInstancesResponse' {} Maybe Text
a -> DescribeReservedInstancesResponse
s {$sel:nextToken:DescribeReservedInstancesResponse' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeReservedInstancesResponse)

-- | List of Reserved Instances in the current Region.
describeReservedInstancesResponse_reservedInstances :: Lens.Lens' DescribeReservedInstancesResponse (Prelude.Maybe [ReservedInstance])
describeReservedInstancesResponse_reservedInstances :: Lens' DescribeReservedInstancesResponse (Maybe [ReservedInstance])
describeReservedInstancesResponse_reservedInstances = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstancesResponse' {Maybe [ReservedInstance]
reservedInstances :: Maybe [ReservedInstance]
$sel:reservedInstances:DescribeReservedInstancesResponse' :: DescribeReservedInstancesResponse -> Maybe [ReservedInstance]
reservedInstances} -> Maybe [ReservedInstance]
reservedInstances) (\s :: DescribeReservedInstancesResponse
s@DescribeReservedInstancesResponse' {} Maybe [ReservedInstance]
a -> DescribeReservedInstancesResponse
s {$sel:reservedInstances:DescribeReservedInstancesResponse' :: Maybe [ReservedInstance]
reservedInstances = Maybe [ReservedInstance]
a} :: DescribeReservedInstancesResponse) 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.
describeReservedInstancesResponse_httpStatus :: Lens.Lens' DescribeReservedInstancesResponse Prelude.Int
describeReservedInstancesResponse_httpStatus :: Lens' DescribeReservedInstancesResponse Int
describeReservedInstancesResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstancesResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeReservedInstancesResponse' :: DescribeReservedInstancesResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeReservedInstancesResponse
s@DescribeReservedInstancesResponse' {} Int
a -> DescribeReservedInstancesResponse
s {$sel:httpStatus:DescribeReservedInstancesResponse' :: Int
httpStatus = Int
a} :: DescribeReservedInstancesResponse)

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