DescribeBudgets
Lists the budgets that are associated with an account.
Important
The Request Syntax section shows the BudgetLimit syntax. For
               PlannedBudgetLimits, see the Examples section.
Request Syntax
{
   "AccountId": "string",
   "MaxResults": number,
   "NextToken": "string",
   "ShowFilterExpression": boolean
}Request Parameters
For information about the parameters that are common to all actions, see Common Parameters.
The request accepts the following data in JSON format.
- AccountId
- 
               The accountIdthat is associated with the budgets that you want to describe.Type: String Length Constraints: Fixed length of 12. Pattern: \d{12}Required: Yes 
- MaxResults
- 
               An integer that represents how many budgets a paginated response contains. The default is 100. Type: Integer Valid Range: Minimum value of 1. Maximum value of 1000. Required: No 
- NextToken
- 
               The pagination token that you include in your request to indicate the next set of results that you want to retrieve. Type: String Length Constraints: Minimum length of 0. Maximum length of 2147483647. Pattern: .*Required: No 
- ShowFilterExpression
- 
               Specifies whether the response includes the filter expression associated with the budgets. By showing the filter expression, you can see detailed filtering logic applied to the budgets, such as AWS services or tags that are being tracked. Type: Boolean Required: No 
Response Syntax
{
   "Budgets": [ 
      { 
         "AutoAdjustData": { 
            "AutoAdjustType": "string",
            "HistoricalOptions": { 
               "BudgetAdjustmentPeriod": number,
               "LookBackAvailablePeriods": number
            },
            "LastAutoAdjustTime": number
         },
         "BillingViewArn": "string",
         "BudgetLimit": { 
            "Amount": "string",
            "Unit": "string"
         },
         "BudgetName": "string",
         "BudgetType": "string",
         "CalculatedSpend": { 
            "ActualSpend": { 
               "Amount": "string",
               "Unit": "string"
            },
            "ForecastedSpend": { 
               "Amount": "string",
               "Unit": "string"
            }
         },
         "CostFilters": { 
            "string" : [ "string" ]
         },
         "CostTypes": { 
            "IncludeCredit": boolean,
            "IncludeDiscount": boolean,
            "IncludeOtherSubscription": boolean,
            "IncludeRecurring": boolean,
            "IncludeRefund": boolean,
            "IncludeSubscription": boolean,
            "IncludeSupport": boolean,
            "IncludeTax": boolean,
            "IncludeUpfront": boolean,
            "UseAmortized": boolean,
            "UseBlended": boolean
         },
         "FilterExpression": { 
            "And": [ 
               "Expression"
            ],
            "CostCategories": { 
               "Key": "string",
               "MatchOptions": [ "string" ],
               "Values": [ "string" ]
            },
            "Dimensions": { 
               "Key": "string",
               "MatchOptions": [ "string" ],
               "Values": [ "string" ]
            },
            "Not": "Expression",
            "Or": [ 
               "Expression"
            ],
            "Tags": { 
               "Key": "string",
               "MatchOptions": [ "string" ],
               "Values": [ "string" ]
            }
         },
         "HealthStatus": { 
            "LastUpdatedTime": number,
            "Status": "string",
            "StatusReason": "string"
         },
         "LastUpdatedTime": number,
         "Metrics": [ "string" ],
         "PlannedBudgetLimits": { 
            "string" : { 
               "Amount": "string",
               "Unit": "string"
            }
         },
         "TimePeriod": { 
            "End": number,
            "Start": number
         },
         "TimeUnit": "string"
      }
   ],
   "NextToken": "string"
}Response Elements
If the action is successful, the service sends back an HTTP 200 response.
The following data is returned in JSON format by the service.
Errors
For information about the errors that are common to all actions, see Common Errors.
- AccessDeniedException
- 
               You are not authorized to use this operation with the given parameters. - Message
- 
                        The error message the exception carries. 
 HTTP Status Code: 400 
- ExpiredNextTokenException
- 
               The pagination token expired. - Message
- 
                        The error message the exception carries. 
 HTTP Status Code: 400 
- InternalErrorException
- 
               An error on the server occurred during the processing of your request. Try again later. - Message
- 
                        The error message the exception carries. 
 HTTP Status Code: 400 
- InvalidNextTokenException
- 
               The pagination token is invalid. - Message
- 
                        The error message the exception carries. 
 HTTP Status Code: 400 
- InvalidParameterException
- 
               An error on the client occurred. Typically, the cause is an invalid input value. - Message
- 
                        The error message the exception carries. 
 HTTP Status Code: 400 
- NotFoundException
- 
               We can’t locate the resource that you specified. - Message
- 
                        The error message the exception carries. 
 HTTP Status Code: 400 
- ThrottlingException
- 
               The number of API requests has exceeded the maximum allowed API request throttling limit for the account. - Message
- 
                        The error message the exception carries. 
 HTTP Status Code: 400 
Examples
Example
The following is the PlannedBudgetLimits syntax.
{ "Budgets": [ { "BudgetLimit": { "Amount": "string", "Unit": "string" }, "PlannedBudgetLimits": { "string": { "Amount": "string", "Unit": "string" } }, "BudgetName": "string", "BudgetType": "string", "CalculatedSpend": { "ActualSpend": { "Amount": "string", "Unit": "string" }, "ForecastedSpend": { "Amount": "string", "Unit": "string" } }, "FilterExpression": { "And": [ "Expression" ], "Dimensions": { "Key": "string", "Values": ["string"] }, "Not": "Expression", "Or": [ "Expression" ], "Tags": { "Key": "string", "Values": ["string"] } }, "Metrics": ["string"], "LastUpdatedTime": number, "TimePeriod": { "End": number, "Start": number }, "TimeUnit": "string" } ], "NextToken": "string" }
Example
This example illustrates one usage of DescribeBudgets.
Sample Request
POST / HTTP/1.1
Host: awsbudgets.<region>.<domain>
x-amz-Date: <Date>
Authorization: AWS4-HMAC-SHA256 Credential=<Credential>, SignedHeaders=contenttype;date;host;user-agent;x-amz-date;x-amz-target;x-amzn-requestid,Signature=<Signature>
User-Agent: <UserAgentString>
Content-Type: application/x-amz-json-1.1
Content-Length: <PayloadSizeBytes>
Connection: Keep-Alive
X-Amz-Target: AWSBudgetServiceGateway.DescribeBudgets
{
   "AccountId": "111122223333",   
   "MaxResults": 20
}
Sample Response
{
   "Budgets": [ 
      { 
         "BudgetLimit": { 
            "Amount": "100",
            "Unit": "USD"
         },
         "BudgetName": "Example Limit Fixed Budget",
         "BudgetType": "COST",
         "CalculatedSpend": { 
            "ActualSpend": { 
               "Amount": "50",
               "Unit": "USD"
            },
            "ForecastedSpend": { 
               "Amount": "100",
               "Unit": "USD"
            }
         },
         "FilterExpression": {
            "Dimensions": {
               "Key": "AZ",
               "Values": ["us-east-1"]
            }
         },
         "Metrics": ["UNBLENDED_COST"],
         "TimePeriod": { 
            "Start": 1477353600,
            "End": 1477958399
         },
         "TimeUnit": "MONTHLY"
      },
      { 
         "BudgetLimit": { 
            "Amount": "100",
            "Unit": "USD"
         },
         "PlannedBudgetLimits":{
            "1583020800": {
               "Amount": "100",
               "Unit": "USD"
            },
            "1564617600": {
               "Amount": "200",
               "Unit": "USD"
            },
            "1569888000": {
               "Amount": "300",
               "Unit": "USD"
            },
            "1556668800": {
               "Amount": "400",
               "Unit": "USD"
            },
            "1575158400": {
               "Amount": "500",
               "Unit": "USD"
            },
            "1580515200": {
               "Amount": "200",
               "Unit": "USD"
            }
         },
         "BudgetName": "Example Planned Limits Budget",
         "BudgetType": "COST",
         "CalculatedSpend": { 
            "ActualSpend": { 
               "Amount": "50",
               "Unit": "USD"
            },
            "ForecastedSpend": { 
               "Amount": "100",
               "Unit": "USD"
            }
         },
         "FilterExpression": {
            "Dimensions": {
               "Key": "AZ",
               "Values": ["us-east-1"]
            }
         },
         "Metrics": ["UNBLENDED_COST"],
         "TimePeriod": { 
            "Start": 1477353600,
            "End": 1477958399
         },
         "TimeUnit": "MONTHLY"
      }
   ],
   "NextToken": "exampleTokenString"
}See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following: