{-# 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.CostExplorer.GetSavingsPlansUtilization
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Retrieves the Savings Plans utilization for your account across date
-- ranges with daily or monthly granularity. Management account in an
-- organization have access to member accounts. You can use
-- @GetDimensionValues@ in @SAVINGS_PLANS@ to determine the possible
-- dimension values.
--
-- You can\'t group by any dimension values for
-- @GetSavingsPlansUtilization@.
module Amazonka.CostExplorer.GetSavingsPlansUtilization
  ( -- * Creating a Request
    GetSavingsPlansUtilization (..),
    newGetSavingsPlansUtilization,

    -- * Request Lenses
    getSavingsPlansUtilization_filter,
    getSavingsPlansUtilization_granularity,
    getSavingsPlansUtilization_sortBy,
    getSavingsPlansUtilization_timePeriod,

    -- * Destructuring the Response
    GetSavingsPlansUtilizationResponse (..),
    newGetSavingsPlansUtilizationResponse,

    -- * Response Lenses
    getSavingsPlansUtilizationResponse_savingsPlansUtilizationsByTime,
    getSavingsPlansUtilizationResponse_httpStatus,
    getSavingsPlansUtilizationResponse_total,
  )
where

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

-- | /See:/ 'newGetSavingsPlansUtilization' smart constructor.
data GetSavingsPlansUtilization = GetSavingsPlansUtilization'
  { -- | Filters Savings Plans utilization coverage data for active Savings Plans
    -- dimensions. You can filter data with the following dimensions:
    --
    -- -   @LINKED_ACCOUNT@
    --
    -- -   @SAVINGS_PLAN_ARN@
    --
    -- -   @SAVINGS_PLANS_TYPE@
    --
    -- -   @REGION@
    --
    -- -   @PAYMENT_OPTION@
    --
    -- -   @INSTANCE_TYPE_FAMILY@
    --
    -- @GetSavingsPlansUtilization@ uses the same
    -- <https://docs.aws.amazon.com/aws-cost-management/latest/APIReference/API_Expression.html Expression>
    -- object as the other operations, but only @AND@ is supported among each
    -- dimension.
    GetSavingsPlansUtilization -> Maybe Expression
filter' :: Prelude.Maybe Expression,
    -- | The granularity of the Amazon Web Services utillization data for your
    -- Savings Plans.
    --
    -- The @GetSavingsPlansUtilization@ operation supports only @DAILY@ and
    -- @MONTHLY@ granularities.
    GetSavingsPlansUtilization -> Maybe Granularity
granularity :: Prelude.Maybe Granularity,
    -- | The value that you want to sort the data by.
    --
    -- The following values are supported for @Key@:
    --
    -- -   @UtilizationPercentage@
    --
    -- -   @TotalCommitment@
    --
    -- -   @UsedCommitment@
    --
    -- -   @UnusedCommitment@
    --
    -- -   @NetSavings@
    --
    -- The supported values for @SortOrder@ are @ASCENDING@ and @DESCENDING@.
    GetSavingsPlansUtilization -> Maybe SortDefinition
sortBy :: Prelude.Maybe SortDefinition,
    -- | The time period that you want the usage and costs for. The @Start@ date
    -- must be within 13 months. The @End@ date must be after the @Start@ date,
    -- and before the current date. Future dates can\'t be used as an @End@
    -- date.
    GetSavingsPlansUtilization -> DateInterval
timePeriod :: DateInterval
  }
  deriving (GetSavingsPlansUtilization -> GetSavingsPlansUtilization -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetSavingsPlansUtilization -> GetSavingsPlansUtilization -> Bool
$c/= :: GetSavingsPlansUtilization -> GetSavingsPlansUtilization -> Bool
== :: GetSavingsPlansUtilization -> GetSavingsPlansUtilization -> Bool
$c== :: GetSavingsPlansUtilization -> GetSavingsPlansUtilization -> Bool
Prelude.Eq, ReadPrec [GetSavingsPlansUtilization]
ReadPrec GetSavingsPlansUtilization
Int -> ReadS GetSavingsPlansUtilization
ReadS [GetSavingsPlansUtilization]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetSavingsPlansUtilization]
$creadListPrec :: ReadPrec [GetSavingsPlansUtilization]
readPrec :: ReadPrec GetSavingsPlansUtilization
$creadPrec :: ReadPrec GetSavingsPlansUtilization
readList :: ReadS [GetSavingsPlansUtilization]
$creadList :: ReadS [GetSavingsPlansUtilization]
readsPrec :: Int -> ReadS GetSavingsPlansUtilization
$creadsPrec :: Int -> ReadS GetSavingsPlansUtilization
Prelude.Read, Int -> GetSavingsPlansUtilization -> ShowS
[GetSavingsPlansUtilization] -> ShowS
GetSavingsPlansUtilization -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetSavingsPlansUtilization] -> ShowS
$cshowList :: [GetSavingsPlansUtilization] -> ShowS
show :: GetSavingsPlansUtilization -> String
$cshow :: GetSavingsPlansUtilization -> String
showsPrec :: Int -> GetSavingsPlansUtilization -> ShowS
$cshowsPrec :: Int -> GetSavingsPlansUtilization -> ShowS
Prelude.Show, forall x.
Rep GetSavingsPlansUtilization x -> GetSavingsPlansUtilization
forall x.
GetSavingsPlansUtilization -> Rep GetSavingsPlansUtilization x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetSavingsPlansUtilization x -> GetSavingsPlansUtilization
$cfrom :: forall x.
GetSavingsPlansUtilization -> Rep GetSavingsPlansUtilization x
Prelude.Generic)

-- |
-- Create a value of 'GetSavingsPlansUtilization' 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:
--
-- 'filter'', 'getSavingsPlansUtilization_filter' - Filters Savings Plans utilization coverage data for active Savings Plans
-- dimensions. You can filter data with the following dimensions:
--
-- -   @LINKED_ACCOUNT@
--
-- -   @SAVINGS_PLAN_ARN@
--
-- -   @SAVINGS_PLANS_TYPE@
--
-- -   @REGION@
--
-- -   @PAYMENT_OPTION@
--
-- -   @INSTANCE_TYPE_FAMILY@
--
-- @GetSavingsPlansUtilization@ uses the same
-- <https://docs.aws.amazon.com/aws-cost-management/latest/APIReference/API_Expression.html Expression>
-- object as the other operations, but only @AND@ is supported among each
-- dimension.
--
-- 'granularity', 'getSavingsPlansUtilization_granularity' - The granularity of the Amazon Web Services utillization data for your
-- Savings Plans.
--
-- The @GetSavingsPlansUtilization@ operation supports only @DAILY@ and
-- @MONTHLY@ granularities.
--
-- 'sortBy', 'getSavingsPlansUtilization_sortBy' - The value that you want to sort the data by.
--
-- The following values are supported for @Key@:
--
-- -   @UtilizationPercentage@
--
-- -   @TotalCommitment@
--
-- -   @UsedCommitment@
--
-- -   @UnusedCommitment@
--
-- -   @NetSavings@
--
-- The supported values for @SortOrder@ are @ASCENDING@ and @DESCENDING@.
--
-- 'timePeriod', 'getSavingsPlansUtilization_timePeriod' - The time period that you want the usage and costs for. The @Start@ date
-- must be within 13 months. The @End@ date must be after the @Start@ date,
-- and before the current date. Future dates can\'t be used as an @End@
-- date.
newGetSavingsPlansUtilization ::
  -- | 'timePeriod'
  DateInterval ->
  GetSavingsPlansUtilization
newGetSavingsPlansUtilization :: DateInterval -> GetSavingsPlansUtilization
newGetSavingsPlansUtilization DateInterval
pTimePeriod_ =
  GetSavingsPlansUtilization'
    { $sel:filter':GetSavingsPlansUtilization' :: Maybe Expression
filter' =
        forall a. Maybe a
Prelude.Nothing,
      $sel:granularity:GetSavingsPlansUtilization' :: Maybe Granularity
granularity = forall a. Maybe a
Prelude.Nothing,
      $sel:sortBy:GetSavingsPlansUtilization' :: Maybe SortDefinition
sortBy = forall a. Maybe a
Prelude.Nothing,
      $sel:timePeriod:GetSavingsPlansUtilization' :: DateInterval
timePeriod = DateInterval
pTimePeriod_
    }

-- | Filters Savings Plans utilization coverage data for active Savings Plans
-- dimensions. You can filter data with the following dimensions:
--
-- -   @LINKED_ACCOUNT@
--
-- -   @SAVINGS_PLAN_ARN@
--
-- -   @SAVINGS_PLANS_TYPE@
--
-- -   @REGION@
--
-- -   @PAYMENT_OPTION@
--
-- -   @INSTANCE_TYPE_FAMILY@
--
-- @GetSavingsPlansUtilization@ uses the same
-- <https://docs.aws.amazon.com/aws-cost-management/latest/APIReference/API_Expression.html Expression>
-- object as the other operations, but only @AND@ is supported among each
-- dimension.
getSavingsPlansUtilization_filter :: Lens.Lens' GetSavingsPlansUtilization (Prelude.Maybe Expression)
getSavingsPlansUtilization_filter :: Lens' GetSavingsPlansUtilization (Maybe Expression)
getSavingsPlansUtilization_filter = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetSavingsPlansUtilization' {Maybe Expression
filter' :: Maybe Expression
$sel:filter':GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe Expression
filter'} -> Maybe Expression
filter') (\s :: GetSavingsPlansUtilization
s@GetSavingsPlansUtilization' {} Maybe Expression
a -> GetSavingsPlansUtilization
s {$sel:filter':GetSavingsPlansUtilization' :: Maybe Expression
filter' = Maybe Expression
a} :: GetSavingsPlansUtilization)

-- | The granularity of the Amazon Web Services utillization data for your
-- Savings Plans.
--
-- The @GetSavingsPlansUtilization@ operation supports only @DAILY@ and
-- @MONTHLY@ granularities.
getSavingsPlansUtilization_granularity :: Lens.Lens' GetSavingsPlansUtilization (Prelude.Maybe Granularity)
getSavingsPlansUtilization_granularity :: Lens' GetSavingsPlansUtilization (Maybe Granularity)
getSavingsPlansUtilization_granularity = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetSavingsPlansUtilization' {Maybe Granularity
granularity :: Maybe Granularity
$sel:granularity:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe Granularity
granularity} -> Maybe Granularity
granularity) (\s :: GetSavingsPlansUtilization
s@GetSavingsPlansUtilization' {} Maybe Granularity
a -> GetSavingsPlansUtilization
s {$sel:granularity:GetSavingsPlansUtilization' :: Maybe Granularity
granularity = Maybe Granularity
a} :: GetSavingsPlansUtilization)

-- | The value that you want to sort the data by.
--
-- The following values are supported for @Key@:
--
-- -   @UtilizationPercentage@
--
-- -   @TotalCommitment@
--
-- -   @UsedCommitment@
--
-- -   @UnusedCommitment@
--
-- -   @NetSavings@
--
-- The supported values for @SortOrder@ are @ASCENDING@ and @DESCENDING@.
getSavingsPlansUtilization_sortBy :: Lens.Lens' GetSavingsPlansUtilization (Prelude.Maybe SortDefinition)
getSavingsPlansUtilization_sortBy :: Lens' GetSavingsPlansUtilization (Maybe SortDefinition)
getSavingsPlansUtilization_sortBy = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetSavingsPlansUtilization' {Maybe SortDefinition
sortBy :: Maybe SortDefinition
$sel:sortBy:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe SortDefinition
sortBy} -> Maybe SortDefinition
sortBy) (\s :: GetSavingsPlansUtilization
s@GetSavingsPlansUtilization' {} Maybe SortDefinition
a -> GetSavingsPlansUtilization
s {$sel:sortBy:GetSavingsPlansUtilization' :: Maybe SortDefinition
sortBy = Maybe SortDefinition
a} :: GetSavingsPlansUtilization)

-- | The time period that you want the usage and costs for. The @Start@ date
-- must be within 13 months. The @End@ date must be after the @Start@ date,
-- and before the current date. Future dates can\'t be used as an @End@
-- date.
getSavingsPlansUtilization_timePeriod :: Lens.Lens' GetSavingsPlansUtilization DateInterval
getSavingsPlansUtilization_timePeriod :: Lens' GetSavingsPlansUtilization DateInterval
getSavingsPlansUtilization_timePeriod = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetSavingsPlansUtilization' {DateInterval
timePeriod :: DateInterval
$sel:timePeriod:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> DateInterval
timePeriod} -> DateInterval
timePeriod) (\s :: GetSavingsPlansUtilization
s@GetSavingsPlansUtilization' {} DateInterval
a -> GetSavingsPlansUtilization
s {$sel:timePeriod:GetSavingsPlansUtilization' :: DateInterval
timePeriod = DateInterval
a} :: GetSavingsPlansUtilization)

instance Core.AWSRequest GetSavingsPlansUtilization where
  type
    AWSResponse GetSavingsPlansUtilization =
      GetSavingsPlansUtilizationResponse
  request :: (Service -> Service)
-> GetSavingsPlansUtilization -> Request GetSavingsPlansUtilization
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy GetSavingsPlansUtilization
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse GetSavingsPlansUtilization)))
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 [SavingsPlansUtilizationByTime]
-> Int
-> SavingsPlansUtilizationAggregates
-> GetSavingsPlansUtilizationResponse
GetSavingsPlansUtilizationResponse'
            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
"SavingsPlansUtilizationsByTime"
                            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))
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"Total")
      )

instance Prelude.Hashable GetSavingsPlansUtilization where
  hashWithSalt :: Int -> GetSavingsPlansUtilization -> Int
hashWithSalt Int
_salt GetSavingsPlansUtilization' {Maybe Granularity
Maybe SortDefinition
Maybe Expression
DateInterval
timePeriod :: DateInterval
sortBy :: Maybe SortDefinition
granularity :: Maybe Granularity
filter' :: Maybe Expression
$sel:timePeriod:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> DateInterval
$sel:sortBy:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe SortDefinition
$sel:granularity:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe Granularity
$sel:filter':GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe Expression
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Expression
filter'
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Granularity
granularity
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe SortDefinition
sortBy
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` DateInterval
timePeriod

instance Prelude.NFData GetSavingsPlansUtilization where
  rnf :: GetSavingsPlansUtilization -> ()
rnf GetSavingsPlansUtilization' {Maybe Granularity
Maybe SortDefinition
Maybe Expression
DateInterval
timePeriod :: DateInterval
sortBy :: Maybe SortDefinition
granularity :: Maybe Granularity
filter' :: Maybe Expression
$sel:timePeriod:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> DateInterval
$sel:sortBy:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe SortDefinition
$sel:granularity:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe Granularity
$sel:filter':GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe Expression
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Expression
filter'
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Granularity
granularity
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe SortDefinition
sortBy
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf DateInterval
timePeriod

instance Data.ToHeaders GetSavingsPlansUtilization where
  toHeaders :: GetSavingsPlansUtilization -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"X-Amz-Target"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"AWSInsightsIndexService.GetSavingsPlansUtilization" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON GetSavingsPlansUtilization where
  toJSON :: GetSavingsPlansUtilization -> Value
toJSON GetSavingsPlansUtilization' {Maybe Granularity
Maybe SortDefinition
Maybe Expression
DateInterval
timePeriod :: DateInterval
sortBy :: Maybe SortDefinition
granularity :: Maybe Granularity
filter' :: Maybe Expression
$sel:timePeriod:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> DateInterval
$sel:sortBy:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe SortDefinition
$sel:granularity:GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe Granularity
$sel:filter':GetSavingsPlansUtilization' :: GetSavingsPlansUtilization -> Maybe Expression
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"Filter" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Expression
filter',
            (Key
"Granularity" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Granularity
granularity,
            (Key
"SortBy" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe SortDefinition
sortBy,
            forall a. a -> Maybe a
Prelude.Just (Key
"TimePeriod" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= DateInterval
timePeriod)
          ]
      )

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

instance Data.ToQuery GetSavingsPlansUtilization where
  toQuery :: GetSavingsPlansUtilization -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newGetSavingsPlansUtilizationResponse' smart constructor.
data GetSavingsPlansUtilizationResponse = GetSavingsPlansUtilizationResponse'
  { -- | The amount of cost\/commitment that you used your Savings Plans. You can
    -- use it to specify date ranges.
    GetSavingsPlansUtilizationResponse
-> Maybe [SavingsPlansUtilizationByTime]
savingsPlansUtilizationsByTime :: Prelude.Maybe [SavingsPlansUtilizationByTime],
    -- | The response's http status code.
    GetSavingsPlansUtilizationResponse -> Int
httpStatus :: Prelude.Int,
    -- | The total amount of cost\/commitment that you used your Savings Plans,
    -- regardless of date ranges.
    GetSavingsPlansUtilizationResponse
-> SavingsPlansUtilizationAggregates
total :: SavingsPlansUtilizationAggregates
  }
  deriving (GetSavingsPlansUtilizationResponse
-> GetSavingsPlansUtilizationResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetSavingsPlansUtilizationResponse
-> GetSavingsPlansUtilizationResponse -> Bool
$c/= :: GetSavingsPlansUtilizationResponse
-> GetSavingsPlansUtilizationResponse -> Bool
== :: GetSavingsPlansUtilizationResponse
-> GetSavingsPlansUtilizationResponse -> Bool
$c== :: GetSavingsPlansUtilizationResponse
-> GetSavingsPlansUtilizationResponse -> Bool
Prelude.Eq, ReadPrec [GetSavingsPlansUtilizationResponse]
ReadPrec GetSavingsPlansUtilizationResponse
Int -> ReadS GetSavingsPlansUtilizationResponse
ReadS [GetSavingsPlansUtilizationResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetSavingsPlansUtilizationResponse]
$creadListPrec :: ReadPrec [GetSavingsPlansUtilizationResponse]
readPrec :: ReadPrec GetSavingsPlansUtilizationResponse
$creadPrec :: ReadPrec GetSavingsPlansUtilizationResponse
readList :: ReadS [GetSavingsPlansUtilizationResponse]
$creadList :: ReadS [GetSavingsPlansUtilizationResponse]
readsPrec :: Int -> ReadS GetSavingsPlansUtilizationResponse
$creadsPrec :: Int -> ReadS GetSavingsPlansUtilizationResponse
Prelude.Read, Int -> GetSavingsPlansUtilizationResponse -> ShowS
[GetSavingsPlansUtilizationResponse] -> ShowS
GetSavingsPlansUtilizationResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetSavingsPlansUtilizationResponse] -> ShowS
$cshowList :: [GetSavingsPlansUtilizationResponse] -> ShowS
show :: GetSavingsPlansUtilizationResponse -> String
$cshow :: GetSavingsPlansUtilizationResponse -> String
showsPrec :: Int -> GetSavingsPlansUtilizationResponse -> ShowS
$cshowsPrec :: Int -> GetSavingsPlansUtilizationResponse -> ShowS
Prelude.Show, forall x.
Rep GetSavingsPlansUtilizationResponse x
-> GetSavingsPlansUtilizationResponse
forall x.
GetSavingsPlansUtilizationResponse
-> Rep GetSavingsPlansUtilizationResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetSavingsPlansUtilizationResponse x
-> GetSavingsPlansUtilizationResponse
$cfrom :: forall x.
GetSavingsPlansUtilizationResponse
-> Rep GetSavingsPlansUtilizationResponse x
Prelude.Generic)

-- |
-- Create a value of 'GetSavingsPlansUtilizationResponse' 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:
--
-- 'savingsPlansUtilizationsByTime', 'getSavingsPlansUtilizationResponse_savingsPlansUtilizationsByTime' - The amount of cost\/commitment that you used your Savings Plans. You can
-- use it to specify date ranges.
--
-- 'httpStatus', 'getSavingsPlansUtilizationResponse_httpStatus' - The response's http status code.
--
-- 'total', 'getSavingsPlansUtilizationResponse_total' - The total amount of cost\/commitment that you used your Savings Plans,
-- regardless of date ranges.
newGetSavingsPlansUtilizationResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'total'
  SavingsPlansUtilizationAggregates ->
  GetSavingsPlansUtilizationResponse
newGetSavingsPlansUtilizationResponse :: Int
-> SavingsPlansUtilizationAggregates
-> GetSavingsPlansUtilizationResponse
newGetSavingsPlansUtilizationResponse
  Int
pHttpStatus_
  SavingsPlansUtilizationAggregates
pTotal_ =
    GetSavingsPlansUtilizationResponse'
      { $sel:savingsPlansUtilizationsByTime:GetSavingsPlansUtilizationResponse' :: Maybe [SavingsPlansUtilizationByTime]
savingsPlansUtilizationsByTime =
          forall a. Maybe a
Prelude.Nothing,
        $sel:httpStatus:GetSavingsPlansUtilizationResponse' :: Int
httpStatus = Int
pHttpStatus_,
        $sel:total:GetSavingsPlansUtilizationResponse' :: SavingsPlansUtilizationAggregates
total = SavingsPlansUtilizationAggregates
pTotal_
      }

-- | The amount of cost\/commitment that you used your Savings Plans. You can
-- use it to specify date ranges.
getSavingsPlansUtilizationResponse_savingsPlansUtilizationsByTime :: Lens.Lens' GetSavingsPlansUtilizationResponse (Prelude.Maybe [SavingsPlansUtilizationByTime])
getSavingsPlansUtilizationResponse_savingsPlansUtilizationsByTime :: Lens'
  GetSavingsPlansUtilizationResponse
  (Maybe [SavingsPlansUtilizationByTime])
getSavingsPlansUtilizationResponse_savingsPlansUtilizationsByTime = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetSavingsPlansUtilizationResponse' {Maybe [SavingsPlansUtilizationByTime]
savingsPlansUtilizationsByTime :: Maybe [SavingsPlansUtilizationByTime]
$sel:savingsPlansUtilizationsByTime:GetSavingsPlansUtilizationResponse' :: GetSavingsPlansUtilizationResponse
-> Maybe [SavingsPlansUtilizationByTime]
savingsPlansUtilizationsByTime} -> Maybe [SavingsPlansUtilizationByTime]
savingsPlansUtilizationsByTime) (\s :: GetSavingsPlansUtilizationResponse
s@GetSavingsPlansUtilizationResponse' {} Maybe [SavingsPlansUtilizationByTime]
a -> GetSavingsPlansUtilizationResponse
s {$sel:savingsPlansUtilizationsByTime:GetSavingsPlansUtilizationResponse' :: Maybe [SavingsPlansUtilizationByTime]
savingsPlansUtilizationsByTime = Maybe [SavingsPlansUtilizationByTime]
a} :: GetSavingsPlansUtilizationResponse) 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.
getSavingsPlansUtilizationResponse_httpStatus :: Lens.Lens' GetSavingsPlansUtilizationResponse Prelude.Int
getSavingsPlansUtilizationResponse_httpStatus :: Lens' GetSavingsPlansUtilizationResponse Int
getSavingsPlansUtilizationResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetSavingsPlansUtilizationResponse' {Int
httpStatus :: Int
$sel:httpStatus:GetSavingsPlansUtilizationResponse' :: GetSavingsPlansUtilizationResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: GetSavingsPlansUtilizationResponse
s@GetSavingsPlansUtilizationResponse' {} Int
a -> GetSavingsPlansUtilizationResponse
s {$sel:httpStatus:GetSavingsPlansUtilizationResponse' :: Int
httpStatus = Int
a} :: GetSavingsPlansUtilizationResponse)

-- | The total amount of cost\/commitment that you used your Savings Plans,
-- regardless of date ranges.
getSavingsPlansUtilizationResponse_total :: Lens.Lens' GetSavingsPlansUtilizationResponse SavingsPlansUtilizationAggregates
getSavingsPlansUtilizationResponse_total :: Lens'
  GetSavingsPlansUtilizationResponse
  SavingsPlansUtilizationAggregates
getSavingsPlansUtilizationResponse_total = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetSavingsPlansUtilizationResponse' {SavingsPlansUtilizationAggregates
total :: SavingsPlansUtilizationAggregates
$sel:total:GetSavingsPlansUtilizationResponse' :: GetSavingsPlansUtilizationResponse
-> SavingsPlansUtilizationAggregates
total} -> SavingsPlansUtilizationAggregates
total) (\s :: GetSavingsPlansUtilizationResponse
s@GetSavingsPlansUtilizationResponse' {} SavingsPlansUtilizationAggregates
a -> GetSavingsPlansUtilizationResponse
s {$sel:total:GetSavingsPlansUtilizationResponse' :: SavingsPlansUtilizationAggregates
total = SavingsPlansUtilizationAggregates
a} :: GetSavingsPlansUtilizationResponse)

instance
  Prelude.NFData
    GetSavingsPlansUtilizationResponse
  where
  rnf :: GetSavingsPlansUtilizationResponse -> ()
rnf GetSavingsPlansUtilizationResponse' {Int
Maybe [SavingsPlansUtilizationByTime]
SavingsPlansUtilizationAggregates
total :: SavingsPlansUtilizationAggregates
httpStatus :: Int
savingsPlansUtilizationsByTime :: Maybe [SavingsPlansUtilizationByTime]
$sel:total:GetSavingsPlansUtilizationResponse' :: GetSavingsPlansUtilizationResponse
-> SavingsPlansUtilizationAggregates
$sel:httpStatus:GetSavingsPlansUtilizationResponse' :: GetSavingsPlansUtilizationResponse -> Int
$sel:savingsPlansUtilizationsByTime:GetSavingsPlansUtilizationResponse' :: GetSavingsPlansUtilizationResponse
-> Maybe [SavingsPlansUtilizationByTime]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [SavingsPlansUtilizationByTime]
savingsPlansUtilizationsByTime
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf SavingsPlansUtilizationAggregates
total