/AWS1/IF_CEX=>GETUSAGEFORECAST()¶
About GetUsageForecast¶
Retrieves a forecast for how much Amazon Web Services predicts that you will use over the forecast time period that you select, based on your past usage.
Method Signature¶
METHODS /AWS1/IF_CEX~GETUSAGEFORECAST
IMPORTING
!IO_TIMEPERIOD TYPE REF TO /AWS1/CL_CEXDATEINTERVAL OPTIONAL
!IV_METRIC TYPE /AWS1/CEXMETRIC OPTIONAL
!IV_GRANULARITY TYPE /AWS1/CEXGRANULARITY OPTIONAL
!IO_FILTER TYPE REF TO /AWS1/CL_CEXEXPRESSION OPTIONAL
!IV_BILLINGVIEWARN TYPE /AWS1/CEXBILLINGVIEWARN OPTIONAL
!IV_PREDICTIONINTERVALLEVEL TYPE /AWS1/CEXPREDICTIONINTERVALL00 OPTIONAL
RETURNING
VALUE(OO_OUTPUT) TYPE REF TO /aws1/cl_cexgetusagefcresponse
RAISING
/AWS1/CX_CEXBLLVIEWHLTHSTATEX
/AWS1/CX_CEXDATAUNAVAILEX
/AWS1/CX_CEXLIMITEXCEEDEDEX
/AWS1/CX_CEXRESOURCENOTFOUNDEX
/AWS1/CX_CEXUNRESOLVABLEUSAG00
/AWS1/CX_CEXCLIENTEXC
/AWS1/CX_CEXSERVEREXC
/AWS1/CX_RT_TECHNICAL_GENERIC
/AWS1/CX_RT_SERVICE_GENERIC.
IMPORTING¶
Required arguments:¶
io_timeperiod TYPE REF TO /AWS1/CL_CEXDATEINTERVAL /AWS1/CL_CEXDATEINTERVAL¶
The start and end dates of the period that you want to retrieve usage forecast for. The start date is included in the period, but the end date isn't included in the period. For example, if
startis2017-01-01andendis2017-05-01, then the cost and usage data is retrieved from2017-01-01up to and including2017-04-30but not including2017-05-01. The start date must be equal to or later than the current date to avoid a validation error.
iv_metric TYPE /AWS1/CEXMETRIC /AWS1/CEXMETRIC¶
Which metric Cost Explorer uses to create your forecast.
Valid values for a
GetUsageForecastcall are the following:
USAGE_QUANTITY
NORMALIZED_USAGE_AMOUNT
iv_granularity TYPE /AWS1/CEXGRANULARITY /AWS1/CEXGRANULARITY¶
How granular you want the forecast to be. You can get 3 months of
DAILYforecasts or 12 months ofMONTHLYforecasts.The
GetUsageForecastoperation supports onlyDAILYandMONTHLYgranularities.
Optional arguments:¶
io_filter TYPE REF TO /AWS1/CL_CEXEXPRESSION /AWS1/CL_CEXEXPRESSION¶
The filters that you want to use to filter your forecast. The
GetUsageForecastAPI supports filtering by the following dimensions:
AZ
INSTANCE_TYPE
LINKED_ACCOUNT
LINKED_ACCOUNT_NAME
OPERATION
PURCHASE_TYPE
REGION
SERVICE
USAGE_TYPE
USAGE_TYPE_GROUP
RECORD_TYPE
OPERATING_SYSTEM
TENANCY
SCOPE
PLATFORM
SUBSCRIPTION_ID
LEGAL_ENTITY_NAME
DEPLOYMENT_OPTION
DATABASE_ENGINE
INSTANCE_TYPE_FAMILY
BILLING_ENTITY
RESERVATION_ID
SAVINGS_PLAN_ARN
iv_billingviewarn TYPE /AWS1/CEXBILLINGVIEWARN /AWS1/CEXBILLINGVIEWARN¶
The Amazon Resource Name (ARN) that uniquely identifies a specific billing view. The ARN is used to specify which particular billing view you want to interact with or retrieve information from when making API calls related to Amazon Web Services Billing and Cost Management features. The BillingViewArn can be retrieved by calling the ListBillingViews API.
iv_predictionintervallevel TYPE /AWS1/CEXPREDICTIONINTERVALL00 /AWS1/CEXPREDICTIONINTERVALL00¶
Amazon Web Services Cost Explorer always returns the mean forecast as a single point. You can request a prediction interval around the mean by specifying a confidence level. The higher the confidence level, the more confident Cost Explorer is about the actual value falling in the prediction interval. Higher confidence levels result in wider prediction intervals.
RETURNING¶
oo_output TYPE REF TO /aws1/cl_cexgetusagefcresponse /AWS1/CL_CEXGETUSAGEFCRESPONSE¶
Domain /AWS1/RT_ACCOUNT_ID Primitive Type NUMC
Examples¶
Syntax Example¶
This is an example of the syntax for calling the method. It includes every possible argument and initializes every possible value. The data provided is not necessarily semantically accurate (for example the value "string" may be provided for something that is intended to be an instance ID, or in some cases two arguments may be mutually exclusive). The syntax shows the ABAP syntax for creating the various data structures.
DATA(lo_result) = lo_client->getusageforecast(
io_filter = new /aws1/cl_cexexpression(
io_costcategories = new /aws1/cl_cexcostcategoryvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_dimensions = new /aws1/cl_cexdimensionvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_not = new /aws1/cl_cexexpression(
io_costcategories = new /aws1/cl_cexcostcategoryvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_dimensions = new /aws1/cl_cexdimensionvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_tags = new /aws1/cl_cextagvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
it_and = VALUE /aws1/cl_cexexpression=>tt_expressions(
(
new /aws1/cl_cexexpression(
io_costcategories = new /aws1/cl_cexcostcategoryvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_dimensions = new /aws1/cl_cexdimensionvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_tags = new /aws1/cl_cextagvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
it_or = VALUE /aws1/cl_cexexpression=>tt_expressions(
)
)
)
)
it_or = VALUE /aws1/cl_cexexpression=>tt_expressions(
(
new /aws1/cl_cexexpression(
io_costcategories = new /aws1/cl_cexcostcategoryvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_dimensions = new /aws1/cl_cexdimensionvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_tags = new /aws1/cl_cextagvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
it_and = VALUE /aws1/cl_cexexpression=>tt_expressions(
)
)
)
)
)
io_tags = new /aws1/cl_cextagvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
it_and = VALUE /aws1/cl_cexexpression=>tt_expressions(
(
new /aws1/cl_cexexpression(
io_costcategories = new /aws1/cl_cexcostcategoryvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_dimensions = new /aws1/cl_cexdimensionvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_not = new /aws1/cl_cexexpression(
io_costcategories = new /aws1/cl_cexcostcategoryvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_dimensions = new /aws1/cl_cexdimensionvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_tags = new /aws1/cl_cextagvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
it_or = VALUE /aws1/cl_cexexpression=>tt_expressions(
)
)
io_tags = new /aws1/cl_cextagvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
it_or = VALUE /aws1/cl_cexexpression=>tt_expressions(
)
)
)
)
it_or = VALUE /aws1/cl_cexexpression=>tt_expressions(
(
new /aws1/cl_cexexpression(
io_costcategories = new /aws1/cl_cexcostcategoryvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_dimensions = new /aws1/cl_cexdimensionvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_not = new /aws1/cl_cexexpression(
io_costcategories = new /aws1/cl_cexcostcategoryvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_dimensions = new /aws1/cl_cexdimensionvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
io_tags = new /aws1/cl_cextagvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
it_and = VALUE /aws1/cl_cexexpression=>tt_expressions(
)
)
io_tags = new /aws1/cl_cextagvalues(
it_matchoptions = VALUE /aws1/cl_cexmatchoptions_w=>tt_matchoptions(
( new /aws1/cl_cexmatchoptions_w( |string| ) )
)
it_values = VALUE /aws1/cl_cexvalues_w=>tt_values(
( new /aws1/cl_cexvalues_w( |string| ) )
)
iv_key = |string|
)
it_and = VALUE /aws1/cl_cexexpression=>tt_expressions(
)
)
)
)
)
io_timeperiod = new /aws1/cl_cexdateinterval(
iv_end = |string|
iv_start = |string|
)
iv_billingviewarn = |string|
iv_granularity = |string|
iv_metric = |string|
iv_predictionintervallevel = 123
).
This is an example of reading all possible response values
lo_result = lo_result.
IF lo_result IS NOT INITIAL.
lo_metricvalue = lo_result->get_total( ).
IF lo_metricvalue IS NOT INITIAL.
lv_metricamount = lo_metricvalue->get_amount( ).
lv_metricunit = lo_metricvalue->get_unit( ).
ENDIF.
LOOP AT lo_result->get_forecastresultsbytime( ) into lo_row.
lo_row_1 = lo_row.
IF lo_row_1 IS NOT INITIAL.
lo_dateinterval = lo_row_1->get_timeperiod( ).
IF lo_dateinterval IS NOT INITIAL.
lv_yearmonthday = lo_dateinterval->get_start( ).
lv_yearmonthday = lo_dateinterval->get_end( ).
ENDIF.
lv_genericstring = lo_row_1->get_meanvalue( ).
lv_genericstring = lo_row_1->get_predictionintervalwerb00( ).
lv_genericstring = lo_row_1->get_predictionintervaluppe00( ).
ENDIF.
ENDLOOP.
ENDIF.