/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include #include #include #include #include namespace Aws { namespace CostExplorer { namespace Model { /** */ class GetSavingsPlansUtilizationDetailsRequest : public CostExplorerRequest { public: AWS_COSTEXPLORER_API GetSavingsPlansUtilizationDetailsRequest(); // Service request name is the Operation name which will send this request out, // each operation should has unique request name, so that we can get operation's name from this request. // Note: this is not true for response, multiple operations may have the same response name, // so we can not get operation's name from response. inline virtual const char* GetServiceRequestName() const override { return "GetSavingsPlansUtilizationDetails"; } AWS_COSTEXPLORER_API Aws::String SerializePayload() const override; AWS_COSTEXPLORER_API Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const override; /** *

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.

*/ inline const DateInterval& GetTimePeriod() const{ return m_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.

*/ inline bool TimePeriodHasBeenSet() const { return m_timePeriodHasBeenSet; } /** *

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.

*/ inline void SetTimePeriod(const DateInterval& value) { m_timePeriodHasBeenSet = true; m_timePeriod = value; } /** *

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.

*/ inline void SetTimePeriod(DateInterval&& value) { m_timePeriodHasBeenSet = true; m_timePeriod = std::move(value); } /** *

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.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithTimePeriod(const DateInterval& value) { SetTimePeriod(value); return *this;} /** *

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.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithTimePeriod(DateInterval&& value) { SetTimePeriod(std::move(value)); return *this;} /** *

Filters Savings Plans utilization coverage data for active Savings Plans * dimensions. You can filter data with the following dimensions:

  • * LINKED_ACCOUNT

  • SAVINGS_PLAN_ARN *

  • REGION

  • * PAYMENT_OPTION

  • * INSTANCE_TYPE_FAMILY

* GetSavingsPlansUtilizationDetails uses the same Expression * object as the other operations, but only AND is supported among * each dimension.

*/ inline const Expression& GetFilter() const{ return m_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 *

  • REGION

  • * PAYMENT_OPTION

  • * INSTANCE_TYPE_FAMILY

* GetSavingsPlansUtilizationDetails uses the same Expression * object as the other operations, but only AND is supported among * each dimension.

*/ inline bool FilterHasBeenSet() const { return m_filterHasBeenSet; } /** *

Filters Savings Plans utilization coverage data for active Savings Plans * dimensions. You can filter data with the following dimensions:

  • * LINKED_ACCOUNT

  • SAVINGS_PLAN_ARN *

  • REGION

  • * PAYMENT_OPTION

  • * INSTANCE_TYPE_FAMILY

* GetSavingsPlansUtilizationDetails uses the same Expression * object as the other operations, but only AND is supported among * each dimension.

*/ inline void SetFilter(const Expression& value) { m_filterHasBeenSet = true; m_filter = value; } /** *

Filters Savings Plans utilization coverage data for active Savings Plans * dimensions. You can filter data with the following dimensions:

  • * LINKED_ACCOUNT

  • SAVINGS_PLAN_ARN *

  • REGION

  • * PAYMENT_OPTION

  • * INSTANCE_TYPE_FAMILY

* GetSavingsPlansUtilizationDetails uses the same Expression * object as the other operations, but only AND is supported among * each dimension.

*/ inline void SetFilter(Expression&& value) { m_filterHasBeenSet = true; m_filter = std::move(value); } /** *

Filters Savings Plans utilization coverage data for active Savings Plans * dimensions. You can filter data with the following dimensions:

  • * LINKED_ACCOUNT

  • SAVINGS_PLAN_ARN *

  • REGION

  • * PAYMENT_OPTION

  • * INSTANCE_TYPE_FAMILY

* GetSavingsPlansUtilizationDetails uses the same Expression * object as the other operations, but only AND is supported among * each dimension.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithFilter(const Expression& value) { SetFilter(value); return *this;} /** *

Filters Savings Plans utilization coverage data for active Savings Plans * dimensions. You can filter data with the following dimensions:

  • * LINKED_ACCOUNT

  • SAVINGS_PLAN_ARN *

  • REGION

  • * PAYMENT_OPTION

  • * INSTANCE_TYPE_FAMILY

* GetSavingsPlansUtilizationDetails uses the same Expression * object as the other operations, but only AND is supported among * each dimension.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithFilter(Expression&& value) { SetFilter(std::move(value)); return *this;} /** *

The data type.

*/ inline const Aws::Vector& GetDataType() const{ return m_dataType; } /** *

The data type.

*/ inline bool DataTypeHasBeenSet() const { return m_dataTypeHasBeenSet; } /** *

The data type.

*/ inline void SetDataType(const Aws::Vector& value) { m_dataTypeHasBeenSet = true; m_dataType = value; } /** *

The data type.

*/ inline void SetDataType(Aws::Vector&& value) { m_dataTypeHasBeenSet = true; m_dataType = std::move(value); } /** *

The data type.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithDataType(const Aws::Vector& value) { SetDataType(value); return *this;} /** *

The data type.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithDataType(Aws::Vector&& value) { SetDataType(std::move(value)); return *this;} /** *

The data type.

*/ inline GetSavingsPlansUtilizationDetailsRequest& AddDataType(const SavingsPlansDataType& value) { m_dataTypeHasBeenSet = true; m_dataType.push_back(value); return *this; } /** *

The data type.

*/ inline GetSavingsPlansUtilizationDetailsRequest& AddDataType(SavingsPlansDataType&& value) { m_dataTypeHasBeenSet = true; m_dataType.push_back(std::move(value)); return *this; } /** *

The token to retrieve the next set of results. Amazon Web Services provides * the token when the response from a previous call has more results than the * maximum page size.

*/ inline const Aws::String& GetNextToken() const{ return m_nextToken; } /** *

The token to retrieve the next set of results. Amazon Web Services provides * the token when the response from a previous call has more results than the * maximum page size.

*/ inline bool NextTokenHasBeenSet() const { return m_nextTokenHasBeenSet; } /** *

The token to retrieve the next set of results. Amazon Web Services provides * the token when the response from a previous call has more results than the * maximum page size.

*/ inline void SetNextToken(const Aws::String& value) { m_nextTokenHasBeenSet = true; m_nextToken = value; } /** *

The token to retrieve the next set of results. Amazon Web Services provides * the token when the response from a previous call has more results than the * maximum page size.

*/ inline void SetNextToken(Aws::String&& value) { m_nextTokenHasBeenSet = true; m_nextToken = std::move(value); } /** *

The token to retrieve the next set of results. Amazon Web Services provides * the token when the response from a previous call has more results than the * maximum page size.

*/ inline void SetNextToken(const char* value) { m_nextTokenHasBeenSet = true; m_nextToken.assign(value); } /** *

The token to retrieve the next set of results. Amazon Web Services provides * the token when the response from a previous call has more results than the * maximum page size.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithNextToken(const Aws::String& value) { SetNextToken(value); return *this;} /** *

The token to retrieve the next set of results. Amazon Web Services provides * the token when the response from a previous call has more results than the * maximum page size.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithNextToken(Aws::String&& value) { SetNextToken(std::move(value)); return *this;} /** *

The token to retrieve the next set of results. Amazon Web Services provides * the token when the response from a previous call has more results than the * maximum page size.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithNextToken(const char* value) { SetNextToken(value); return *this;} /** *

The number of items to be returned in a response. The default is * 20, with a minimum value of 1.

*/ inline int GetMaxResults() const{ return m_maxResults; } /** *

The number of items to be returned in a response. The default is * 20, with a minimum value of 1.

*/ inline bool MaxResultsHasBeenSet() const { return m_maxResultsHasBeenSet; } /** *

The number of items to be returned in a response. The default is * 20, with a minimum value of 1.

*/ inline void SetMaxResults(int value) { m_maxResultsHasBeenSet = true; m_maxResults = value; } /** *

The number of items to be returned in a response. The default is * 20, with a minimum value of 1.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithMaxResults(int value) { SetMaxResults(value); return *this;} /** *

The value that you want to sort the data by.

The following values are * supported for Key:

  • * UtilizationPercentage

  • * TotalCommitment

  • UsedCommitment *

  • UnusedCommitment

  • * NetSavings

  • * AmortizedRecurringCommitment

  • * AmortizedUpfrontCommitment

The supported values * for SortOrder are ASCENDING and * DESCENDING.

*/ inline const SortDefinition& GetSortBy() const{ return m_sortBy; } /** *

The value that you want to sort the data by.

The following values are * supported for Key:

  • * UtilizationPercentage

  • * TotalCommitment

  • UsedCommitment *

  • UnusedCommitment

  • * NetSavings

  • * AmortizedRecurringCommitment

  • * AmortizedUpfrontCommitment

The supported values * for SortOrder are ASCENDING and * DESCENDING.

*/ inline bool SortByHasBeenSet() const { return m_sortByHasBeenSet; } /** *

The value that you want to sort the data by.

The following values are * supported for Key:

  • * UtilizationPercentage

  • * TotalCommitment

  • UsedCommitment *

  • UnusedCommitment

  • * NetSavings

  • * AmortizedRecurringCommitment

  • * AmortizedUpfrontCommitment

The supported values * for SortOrder are ASCENDING and * DESCENDING.

*/ inline void SetSortBy(const SortDefinition& value) { m_sortByHasBeenSet = true; m_sortBy = value; } /** *

The value that you want to sort the data by.

The following values are * supported for Key:

  • * UtilizationPercentage

  • * TotalCommitment

  • UsedCommitment *

  • UnusedCommitment

  • * NetSavings

  • * AmortizedRecurringCommitment

  • * AmortizedUpfrontCommitment

The supported values * for SortOrder are ASCENDING and * DESCENDING.

*/ inline void SetSortBy(SortDefinition&& value) { m_sortByHasBeenSet = true; m_sortBy = std::move(value); } /** *

The value that you want to sort the data by.

The following values are * supported for Key:

  • * UtilizationPercentage

  • * TotalCommitment

  • UsedCommitment *

  • UnusedCommitment

  • * NetSavings

  • * AmortizedRecurringCommitment

  • * AmortizedUpfrontCommitment

The supported values * for SortOrder are ASCENDING and * DESCENDING.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithSortBy(const SortDefinition& value) { SetSortBy(value); return *this;} /** *

The value that you want to sort the data by.

The following values are * supported for Key:

  • * UtilizationPercentage

  • * TotalCommitment

  • UsedCommitment *

  • UnusedCommitment

  • * NetSavings

  • * AmortizedRecurringCommitment

  • * AmortizedUpfrontCommitment

The supported values * for SortOrder are ASCENDING and * DESCENDING.

*/ inline GetSavingsPlansUtilizationDetailsRequest& WithSortBy(SortDefinition&& value) { SetSortBy(std::move(value)); return *this;} private: DateInterval m_timePeriod; bool m_timePeriodHasBeenSet = false; Expression m_filter; bool m_filterHasBeenSet = false; Aws::Vector m_dataType; bool m_dataTypeHasBeenSet = false; Aws::String m_nextToken; bool m_nextTokenHasBeenSet = false; int m_maxResults; bool m_maxResultsHasBeenSet = false; SortDefinition m_sortBy; bool m_sortByHasBeenSet = false; }; } // namespace Model } // namespace CostExplorer } // namespace Aws