{-# 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.EC2.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 one or more of the Reserved Instances that you purchased.
--
-- For more information about Reserved Instances, see
-- <https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/concepts-on-demand-reserved-instances.html Reserved Instances>
-- in the /Amazon EC2 User Guide/.
module Amazonka.EC2.DescribeReservedInstances
  ( -- * Creating a Request
    DescribeReservedInstances (..),
    newDescribeReservedInstances,

    -- * Request Lenses
    describeReservedInstances_dryRun,
    describeReservedInstances_filters,
    describeReservedInstances_offeringClass,
    describeReservedInstances_offeringType,
    describeReservedInstances_reservedInstancesIds,

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

    -- * Response Lenses
    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.EC2.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | Contains the parameters for DescribeReservedInstances.
--
-- /See:/ 'newDescribeReservedInstances' smart constructor.
data DescribeReservedInstances = DescribeReservedInstances'
  { -- | Checks whether you have the required permissions for the action, without
    -- actually making the request, and provides an error response. If you have
    -- the required permissions, the error response is @DryRunOperation@.
    -- Otherwise, it is @UnauthorizedOperation@.
    DescribeReservedInstances -> Maybe Bool
dryRun :: Prelude.Maybe Prelude.Bool,
    -- | One or more filters.
    --
    -- -   @availability-zone@ - The Availability Zone where the Reserved
    --     Instance can be used.
    --
    -- -   @duration@ - The duration of the Reserved Instance (one year or
    --     three years), in seconds (@31536000@ | @94608000@).
    --
    -- -   @end@ - The time when the Reserved Instance expires (for example,
    --     2015-08-07T11:54:42.000Z).
    --
    -- -   @fixed-price@ - The purchase price of the Reserved Instance (for
    --     example, 9800.0).
    --
    -- -   @instance-type@ - The instance type that is covered by the
    --     reservation.
    --
    -- -   @scope@ - The scope of the Reserved Instance (@Region@ or
    --     @Availability Zone@).
    --
    -- -   @product-description@ - The Reserved Instance product platform
    --     description. Instances that include @(Amazon VPC)@ in the product
    --     platform description will only be displayed to EC2-Classic account
    --     holders and are for use with Amazon VPC (@Linux\/UNIX@ |
    --     @Linux\/UNIX (Amazon VPC)@ | @SUSE Linux@ |
    --     @SUSE Linux (Amazon VPC)@ | @Red Hat Enterprise Linux@ |
    --     @Red Hat Enterprise Linux (Amazon VPC)@ |
    --     @Red Hat Enterprise Linux with HA (Amazon VPC)@ | @Windows@ |
    --     @Windows (Amazon VPC)@ | @Windows with SQL Server Standard@ |
    --     @Windows with SQL Server Standard (Amazon VPC)@ |
    --     @Windows with SQL Server Web@ |
    --     @Windows with SQL Server Web (Amazon VPC)@ |
    --     @Windows with SQL Server Enterprise@ |
    --     @Windows with SQL Server Enterprise (Amazon VPC)@).
    --
    -- -   @reserved-instances-id@ - The ID of the Reserved Instance.
    --
    -- -   @start@ - The time at which the Reserved Instance purchase request
    --     was placed (for example, 2014-08-07T11:54:42.000Z).
    --
    -- -   @state@ - The state of the Reserved Instance (@payment-pending@ |
    --     @active@ | @payment-failed@ | @retired@).
    --
    -- -   @tag:\<key>@ - The key\/value combination of a tag assigned to the
    --     resource. Use the tag key in the filter name and the tag value as
    --     the filter value. For example, to find all resources that have a tag
    --     with the key @Owner@ and the value @TeamA@, specify @tag:Owner@ for
    --     the filter name and @TeamA@ for the filter value.
    --
    -- -   @tag-key@ - The key of a tag assigned to the resource. Use this
    --     filter to find all resources assigned a tag with a specific key,
    --     regardless of the tag value.
    --
    -- -   @usage-price@ - The usage price of the Reserved Instance, per hour
    --     (for example, 0.84).
    DescribeReservedInstances -> Maybe [Filter]
filters :: Prelude.Maybe [Filter],
    -- | Describes whether the Reserved Instance is Standard or Convertible.
    DescribeReservedInstances -> Maybe OfferingClassType
offeringClass :: Prelude.Maybe OfferingClassType,
    -- | The Reserved Instance offering type. If you are using tools that predate
    -- the 2011-11-01 API version, you only have access to the
    -- @Medium Utilization@ Reserved Instance offering type.
    DescribeReservedInstances -> Maybe OfferingTypeValues
offeringType :: Prelude.Maybe OfferingTypeValues,
    -- | One or more Reserved Instance IDs.
    --
    -- Default: Describes all your Reserved Instances, or only those otherwise
    -- specified.
    DescribeReservedInstances -> Maybe [Text]
reservedInstancesIds :: 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:
--
-- 'dryRun', 'describeReservedInstances_dryRun' - Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
--
-- 'filters', 'describeReservedInstances_filters' - One or more filters.
--
-- -   @availability-zone@ - The Availability Zone where the Reserved
--     Instance can be used.
--
-- -   @duration@ - The duration of the Reserved Instance (one year or
--     three years), in seconds (@31536000@ | @94608000@).
--
-- -   @end@ - The time when the Reserved Instance expires (for example,
--     2015-08-07T11:54:42.000Z).
--
-- -   @fixed-price@ - The purchase price of the Reserved Instance (for
--     example, 9800.0).
--
-- -   @instance-type@ - The instance type that is covered by the
--     reservation.
--
-- -   @scope@ - The scope of the Reserved Instance (@Region@ or
--     @Availability Zone@).
--
-- -   @product-description@ - The Reserved Instance product platform
--     description. Instances that include @(Amazon VPC)@ in the product
--     platform description will only be displayed to EC2-Classic account
--     holders and are for use with Amazon VPC (@Linux\/UNIX@ |
--     @Linux\/UNIX (Amazon VPC)@ | @SUSE Linux@ |
--     @SUSE Linux (Amazon VPC)@ | @Red Hat Enterprise Linux@ |
--     @Red Hat Enterprise Linux (Amazon VPC)@ |
--     @Red Hat Enterprise Linux with HA (Amazon VPC)@ | @Windows@ |
--     @Windows (Amazon VPC)@ | @Windows with SQL Server Standard@ |
--     @Windows with SQL Server Standard (Amazon VPC)@ |
--     @Windows with SQL Server Web@ |
--     @Windows with SQL Server Web (Amazon VPC)@ |
--     @Windows with SQL Server Enterprise@ |
--     @Windows with SQL Server Enterprise (Amazon VPC)@).
--
-- -   @reserved-instances-id@ - The ID of the Reserved Instance.
--
-- -   @start@ - The time at which the Reserved Instance purchase request
--     was placed (for example, 2014-08-07T11:54:42.000Z).
--
-- -   @state@ - The state of the Reserved Instance (@payment-pending@ |
--     @active@ | @payment-failed@ | @retired@).
--
-- -   @tag:\<key>@ - The key\/value combination of a tag assigned to the
--     resource. Use the tag key in the filter name and the tag value as
--     the filter value. For example, to find all resources that have a tag
--     with the key @Owner@ and the value @TeamA@, specify @tag:Owner@ for
--     the filter name and @TeamA@ for the filter value.
--
-- -   @tag-key@ - The key of a tag assigned to the resource. Use this
--     filter to find all resources assigned a tag with a specific key,
--     regardless of the tag value.
--
-- -   @usage-price@ - The usage price of the Reserved Instance, per hour
--     (for example, 0.84).
--
-- 'offeringClass', 'describeReservedInstances_offeringClass' - Describes whether the Reserved Instance is Standard or Convertible.
--
-- 'offeringType', 'describeReservedInstances_offeringType' - The Reserved Instance offering type. If you are using tools that predate
-- the 2011-11-01 API version, you only have access to the
-- @Medium Utilization@ Reserved Instance offering type.
--
-- 'reservedInstancesIds', 'describeReservedInstances_reservedInstancesIds' - One or more Reserved Instance IDs.
--
-- Default: Describes all your Reserved Instances, or only those otherwise
-- specified.
newDescribeReservedInstances ::
  DescribeReservedInstances
newDescribeReservedInstances :: DescribeReservedInstances
newDescribeReservedInstances =
  DescribeReservedInstances'
    { $sel:dryRun:DescribeReservedInstances' :: Maybe Bool
dryRun =
        forall a. Maybe a
Prelude.Nothing,
      $sel:filters:DescribeReservedInstances' :: Maybe [Filter]
filters = forall a. Maybe a
Prelude.Nothing,
      $sel:offeringClass:DescribeReservedInstances' :: Maybe OfferingClassType
offeringClass = forall a. Maybe a
Prelude.Nothing,
      $sel:offeringType:DescribeReservedInstances' :: Maybe OfferingTypeValues
offeringType = forall a. Maybe a
Prelude.Nothing,
      $sel:reservedInstancesIds:DescribeReservedInstances' :: Maybe [Text]
reservedInstancesIds = forall a. Maybe a
Prelude.Nothing
    }

-- | Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
describeReservedInstances_dryRun :: Lens.Lens' DescribeReservedInstances (Prelude.Maybe Prelude.Bool)
describeReservedInstances_dryRun :: Lens' DescribeReservedInstances (Maybe Bool)
describeReservedInstances_dryRun = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstances' {Maybe Bool
dryRun :: Maybe Bool
$sel:dryRun:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe Bool
dryRun} -> Maybe Bool
dryRun) (\s :: DescribeReservedInstances
s@DescribeReservedInstances' {} Maybe Bool
a -> DescribeReservedInstances
s {$sel:dryRun:DescribeReservedInstances' :: Maybe Bool
dryRun = Maybe Bool
a} :: DescribeReservedInstances)

-- | One or more filters.
--
-- -   @availability-zone@ - The Availability Zone where the Reserved
--     Instance can be used.
--
-- -   @duration@ - The duration of the Reserved Instance (one year or
--     three years), in seconds (@31536000@ | @94608000@).
--
-- -   @end@ - The time when the Reserved Instance expires (for example,
--     2015-08-07T11:54:42.000Z).
--
-- -   @fixed-price@ - The purchase price of the Reserved Instance (for
--     example, 9800.0).
--
-- -   @instance-type@ - The instance type that is covered by the
--     reservation.
--
-- -   @scope@ - The scope of the Reserved Instance (@Region@ or
--     @Availability Zone@).
--
-- -   @product-description@ - The Reserved Instance product platform
--     description. Instances that include @(Amazon VPC)@ in the product
--     platform description will only be displayed to EC2-Classic account
--     holders and are for use with Amazon VPC (@Linux\/UNIX@ |
--     @Linux\/UNIX (Amazon VPC)@ | @SUSE Linux@ |
--     @SUSE Linux (Amazon VPC)@ | @Red Hat Enterprise Linux@ |
--     @Red Hat Enterprise Linux (Amazon VPC)@ |
--     @Red Hat Enterprise Linux with HA (Amazon VPC)@ | @Windows@ |
--     @Windows (Amazon VPC)@ | @Windows with SQL Server Standard@ |
--     @Windows with SQL Server Standard (Amazon VPC)@ |
--     @Windows with SQL Server Web@ |
--     @Windows with SQL Server Web (Amazon VPC)@ |
--     @Windows with SQL Server Enterprise@ |
--     @Windows with SQL Server Enterprise (Amazon VPC)@).
--
-- -   @reserved-instances-id@ - The ID of the Reserved Instance.
--
-- -   @start@ - The time at which the Reserved Instance purchase request
--     was placed (for example, 2014-08-07T11:54:42.000Z).
--
-- -   @state@ - The state of the Reserved Instance (@payment-pending@ |
--     @active@ | @payment-failed@ | @retired@).
--
-- -   @tag:\<key>@ - The key\/value combination of a tag assigned to the
--     resource. Use the tag key in the filter name and the tag value as
--     the filter value. For example, to find all resources that have a tag
--     with the key @Owner@ and the value @TeamA@, specify @tag:Owner@ for
--     the filter name and @TeamA@ for the filter value.
--
-- -   @tag-key@ - The key of a tag assigned to the resource. Use this
--     filter to find all resources assigned a tag with a specific key,
--     regardless of the tag value.
--
-- -   @usage-price@ - The usage price of the Reserved Instance, per hour
--     (for example, 0.84).
describeReservedInstances_filters :: Lens.Lens' DescribeReservedInstances (Prelude.Maybe [Filter])
describeReservedInstances_filters :: Lens' DescribeReservedInstances (Maybe [Filter])
describeReservedInstances_filters = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstances' {Maybe [Filter]
filters :: Maybe [Filter]
$sel:filters:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe [Filter]
filters} -> Maybe [Filter]
filters) (\s :: DescribeReservedInstances
s@DescribeReservedInstances' {} Maybe [Filter]
a -> DescribeReservedInstances
s {$sel:filters:DescribeReservedInstances' :: Maybe [Filter]
filters = Maybe [Filter]
a} :: DescribeReservedInstances) 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

-- | Describes whether the Reserved Instance is Standard or Convertible.
describeReservedInstances_offeringClass :: Lens.Lens' DescribeReservedInstances (Prelude.Maybe OfferingClassType)
describeReservedInstances_offeringClass :: Lens' DescribeReservedInstances (Maybe OfferingClassType)
describeReservedInstances_offeringClass = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstances' {Maybe OfferingClassType
offeringClass :: Maybe OfferingClassType
$sel:offeringClass:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe OfferingClassType
offeringClass} -> Maybe OfferingClassType
offeringClass) (\s :: DescribeReservedInstances
s@DescribeReservedInstances' {} Maybe OfferingClassType
a -> DescribeReservedInstances
s {$sel:offeringClass:DescribeReservedInstances' :: Maybe OfferingClassType
offeringClass = Maybe OfferingClassType
a} :: DescribeReservedInstances)

-- | The Reserved Instance offering type. If you are using tools that predate
-- the 2011-11-01 API version, you only have access to the
-- @Medium Utilization@ Reserved Instance offering type.
describeReservedInstances_offeringType :: Lens.Lens' DescribeReservedInstances (Prelude.Maybe OfferingTypeValues)
describeReservedInstances_offeringType :: Lens' DescribeReservedInstances (Maybe OfferingTypeValues)
describeReservedInstances_offeringType = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstances' {Maybe OfferingTypeValues
offeringType :: Maybe OfferingTypeValues
$sel:offeringType:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe OfferingTypeValues
offeringType} -> Maybe OfferingTypeValues
offeringType) (\s :: DescribeReservedInstances
s@DescribeReservedInstances' {} Maybe OfferingTypeValues
a -> DescribeReservedInstances
s {$sel:offeringType:DescribeReservedInstances' :: Maybe OfferingTypeValues
offeringType = Maybe OfferingTypeValues
a} :: DescribeReservedInstances)

-- | One or more Reserved Instance IDs.
--
-- Default: Describes all your Reserved Instances, or only those otherwise
-- specified.
describeReservedInstances_reservedInstancesIds :: Lens.Lens' DescribeReservedInstances (Prelude.Maybe [Prelude.Text])
describeReservedInstances_reservedInstancesIds :: Lens' DescribeReservedInstances (Maybe [Text])
describeReservedInstances_reservedInstancesIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstances' {Maybe [Text]
reservedInstancesIds :: Maybe [Text]
$sel:reservedInstancesIds:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe [Text]
reservedInstancesIds} -> Maybe [Text]
reservedInstancesIds) (\s :: DescribeReservedInstances
s@DescribeReservedInstances' {} Maybe [Text]
a -> DescribeReservedInstances
s {$sel:reservedInstancesIds:DescribeReservedInstances' :: Maybe [Text]
reservedInstancesIds = Maybe [Text]
a} :: DescribeReservedInstances) 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

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.postQuery (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 -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXML
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Maybe [ReservedInstances]
-> Int -> DescribeReservedInstancesResponse
DescribeReservedInstancesResponse'
            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
"reservedInstancesSet"
                            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
"item")
                        )
            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 Bool
Maybe [Text]
Maybe [Filter]
Maybe OfferingClassType
Maybe OfferingTypeValues
reservedInstancesIds :: Maybe [Text]
offeringType :: Maybe OfferingTypeValues
offeringClass :: Maybe OfferingClassType
filters :: Maybe [Filter]
dryRun :: Maybe Bool
$sel:reservedInstancesIds:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe [Text]
$sel:offeringType:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe OfferingTypeValues
$sel:offeringClass:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe OfferingClassType
$sel:filters:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe [Filter]
$sel:dryRun:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe Bool
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
dryRun
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Filter]
filters
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe OfferingClassType
offeringClass
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe OfferingTypeValues
offeringType
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Text]
reservedInstancesIds

instance Prelude.NFData DescribeReservedInstances where
  rnf :: DescribeReservedInstances -> ()
rnf DescribeReservedInstances' {Maybe Bool
Maybe [Text]
Maybe [Filter]
Maybe OfferingClassType
Maybe OfferingTypeValues
reservedInstancesIds :: Maybe [Text]
offeringType :: Maybe OfferingTypeValues
offeringClass :: Maybe OfferingClassType
filters :: Maybe [Filter]
dryRun :: Maybe Bool
$sel:reservedInstancesIds:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe [Text]
$sel:offeringType:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe OfferingTypeValues
$sel:offeringClass:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe OfferingClassType
$sel:filters:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe [Filter]
$sel:dryRun:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe Bool
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
dryRun
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Filter]
filters
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe OfferingClassType
offeringClass
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe OfferingTypeValues
offeringType
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
reservedInstancesIds

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
"/"

instance Data.ToQuery DescribeReservedInstances where
  toQuery :: DescribeReservedInstances -> QueryString
toQuery DescribeReservedInstances' {Maybe Bool
Maybe [Text]
Maybe [Filter]
Maybe OfferingClassType
Maybe OfferingTypeValues
reservedInstancesIds :: Maybe [Text]
offeringType :: Maybe OfferingTypeValues
offeringClass :: Maybe OfferingClassType
filters :: Maybe [Filter]
dryRun :: Maybe Bool
$sel:reservedInstancesIds:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe [Text]
$sel:offeringType:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe OfferingTypeValues
$sel:offeringClass:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe OfferingClassType
$sel:filters:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe [Filter]
$sel:dryRun:DescribeReservedInstances' :: DescribeReservedInstances -> Maybe Bool
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"DescribeReservedInstances" :: Prelude.ByteString),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2016-11-15" :: Prelude.ByteString),
        ByteString
"DryRun" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
dryRun,
        forall a. ToQuery a => a -> QueryString
Data.toQuery
          (forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"Filter" forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Filter]
filters),
        ByteString
"OfferingClass" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe OfferingClassType
offeringClass,
        ByteString
"OfferingType" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe OfferingTypeValues
offeringType,
        forall a. ToQuery a => a -> QueryString
Data.toQuery
          ( forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"ReservedInstancesId"
              forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Text]
reservedInstancesIds
          )
      ]

-- | Contains the output for DescribeReservedInstances.
--
-- /See:/ 'newDescribeReservedInstancesResponse' smart constructor.
data DescribeReservedInstancesResponse = DescribeReservedInstancesResponse'
  { -- | A list of Reserved Instances.
    DescribeReservedInstancesResponse -> Maybe [ReservedInstances]
reservedInstances :: Prelude.Maybe [ReservedInstances],
    -- | 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:
--
-- 'reservedInstances', 'describeReservedInstancesResponse_reservedInstances' - A list of Reserved Instances.
--
-- 'httpStatus', 'describeReservedInstancesResponse_httpStatus' - The response's http status code.
newDescribeReservedInstancesResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeReservedInstancesResponse
newDescribeReservedInstancesResponse :: Int -> DescribeReservedInstancesResponse
newDescribeReservedInstancesResponse Int
pHttpStatus_ =
  DescribeReservedInstancesResponse'
    { $sel:reservedInstances:DescribeReservedInstancesResponse' :: Maybe [ReservedInstances]
reservedInstances =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeReservedInstancesResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | A list of Reserved Instances.
describeReservedInstancesResponse_reservedInstances :: Lens.Lens' DescribeReservedInstancesResponse (Prelude.Maybe [ReservedInstances])
describeReservedInstancesResponse_reservedInstances :: Lens' DescribeReservedInstancesResponse (Maybe [ReservedInstances])
describeReservedInstancesResponse_reservedInstances = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservedInstancesResponse' {Maybe [ReservedInstances]
reservedInstances :: Maybe [ReservedInstances]
$sel:reservedInstances:DescribeReservedInstancesResponse' :: DescribeReservedInstancesResponse -> Maybe [ReservedInstances]
reservedInstances} -> Maybe [ReservedInstances]
reservedInstances) (\s :: DescribeReservedInstancesResponse
s@DescribeReservedInstancesResponse' {} Maybe [ReservedInstances]
a -> DescribeReservedInstancesResponse
s {$sel:reservedInstances:DescribeReservedInstancesResponse' :: Maybe [ReservedInstances]
reservedInstances = Maybe [ReservedInstances]
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 [ReservedInstances]
httpStatus :: Int
reservedInstances :: Maybe [ReservedInstances]
$sel:httpStatus:DescribeReservedInstancesResponse' :: DescribeReservedInstancesResponse -> Int
$sel:reservedInstances:DescribeReservedInstancesResponse' :: DescribeReservedInstancesResponse -> Maybe [ReservedInstances]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [ReservedInstances]
reservedInstances
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus