CostandUsageReportService ************************* Client ====== class CostandUsageReportService.Client A low-level client representing AWS Cost and Usage Report Service You can use the Amazon Web Services Cost and Usage Report API to programmatically create, query, and delete Amazon Web Services Cost and Usage Report definitions. Amazon Web Services Cost and Usage Report track the monthly Amazon Web Services costs and usage associated with your Amazon Web Services account. The report contains line items for each unique combination of Amazon Web Services product, usage type, and operation that your Amazon Web Services account uses. You can configure the Amazon Web Services Cost and Usage Report to show only the data that you want, using the Amazon Web Services Cost and Usage Report API. Service Endpoint The Amazon Web Services Cost and Usage Report API provides the following endpoint: * cur.us-east-1.amazonaws.com import boto3 client = boto3.client('cur') These are the available methods: * can_paginate * close * delete_report_definition * describe_report_definitions * get_paginator * get_waiter * list_tags_for_resource * modify_report_definition * put_report_definition * tag_resource * untag_resource Paginators ========== Paginators are available on a client instance via the "get_paginator" method. For more detailed instructions and examples on the usage of paginators, see the paginators user guide. The available paginators are: * DescribeReportDefinitions CostandUsageReportService / Paginator / DescribeReportDefinitions DescribeReportDefinitions ************************* class CostandUsageReportService.Paginator.DescribeReportDefinitions paginator = client.get_paginator('describe_report_definitions') paginate(**kwargs) Creates an iterator that will paginate through responses from " CostandUsageReportService.Client.describe_report_definitions()". See also: AWS API Documentation **Request Syntax** response_iterator = paginator.paginate( PaginationConfig={ 'MaxItems': 123, 'PageSize': 123, 'StartingToken': 'string' } ) Parameters: **PaginationConfig** (*dict*) -- A dictionary that provides parameters to control pagination. * **MaxItems** *(integer) --* The total number of items to return. If the total number of items available is more than the value specified in max- items then a "NextToken" will be provided in the output that you can use to resume pagination. * **PageSize** *(integer) --* The size of each page. * **StartingToken** *(string) --* A token to specify where to start paginating. This is the "NextToken" from a previous response. Return type: dict Returns: **Response Syntax** { 'ReportDefinitions': [ { 'ReportName': 'string', 'TimeUnit': 'HOURLY'|'DAILY'|'MONTHLY', 'Format': 'textORcsv'|'Parquet', 'Compression': 'ZIP'|'GZIP'|'Parquet', 'AdditionalSchemaElements': [ 'RESOURCES'|'SPLIT_COST_ALLOCATION_DATA'|'MANUAL_DISCOUNT_COMPATIBILITY', ], 'S3Bucket': 'string', 'S3Prefix': 'string', 'S3Region': 'af-south-1'|'ap-east-1'|'ap-south-1'|'ap-south-2'|'ap-southeast-1'|'ap-southeast-2'|'ap-southeast-3'|'ap-northeast-1'|'ap-northeast-2'|'ap-northeast-3'|'ca-central-1'|'eu-central-1'|'eu-central-2'|'eu-west-1'|'eu-west-2'|'eu-west-3'|'eu-north-1'|'eu-south-1'|'eu-south-2'|'me-central-1'|'me-south-1'|'sa-east-1'|'us-east-1'|'us-east-2'|'us-west-1'|'us-west-2'|'cn-north-1'|'cn-northwest-1', 'AdditionalArtifacts': [ 'REDSHIFT'|'QUICKSIGHT'|'ATHENA', ], 'RefreshClosedReports': True|False, 'ReportVersioning': 'CREATE_NEW_REPORT'|'OVERWRITE_REPORT', 'BillingViewArn': 'string', 'ReportStatus': { 'lastDelivery': 'string', 'lastStatus': 'SUCCESS'|'ERROR_PERMISSIONS'|'ERROR_NO_BUCKET' } }, ], } **Response Structure** * *(dict) --* If the action is successful, the service sends back an HTTP 200 response. * **ReportDefinitions** *(list) --* An Amazon Web Services Cost and Usage Report list owned by the account. * *(dict) --* The definition of Amazon Web Services Cost and Usage Report. You can specify the report name, time unit, report format, compression format, S3 bucket, additional artifacts, and schema elements in the definition. * **ReportName** *(string) --* The name of the report that you want to create. The name must be unique, is case sensitive, and can't include spaces. * **TimeUnit** *(string) --* The length of time covered by the report. * **Format** *(string) --* The format that Amazon Web Services saves the report in. * **Compression** *(string) --* The compression format that Amazon Web Services uses for the report. * **AdditionalSchemaElements** *(list) --* A list of strings that indicate additional content that Amazon Web Services includes in the report, such as individual resource IDs. * *(string) --* Whether or not Amazon Web Services includes resource IDs in the report. * **S3Bucket** *(string) --* The S3 bucket where Amazon Web Services delivers the report. * **S3Prefix** *(string) --* The prefix that Amazon Web Services adds to the report name when Amazon Web Services delivers the report. Your prefix can't include spaces. * **S3Region** *(string) --* The region of the S3 bucket that Amazon Web Services delivers the report into. * **AdditionalArtifacts** *(list) --* A list of manifests that you want Amazon Web Services to create for this report. * *(string) --* The types of manifest that you want Amazon Web Services to create for this report. * **RefreshClosedReports** *(boolean) --* Whether you want Amazon Web Services to update your reports after they have been finalized if Amazon Web Services detects charges related to previous months. These charges can include refunds, credits, or support fees. * **ReportVersioning** *(string) --* Whether you want Amazon Web Services to overwrite the previous version of each report or to deliver the report in addition to the previous versions. * **BillingViewArn** *(string) --* The Amazon resource name of the billing view. The "BillingViewArn" is needed to create Amazon Web Services Cost and Usage Report for each billing group maintained in the Amazon Web Services Billing Conductor service. The "BillingViewArn" for a billing group can be constructed as: "arn:aws:billing::payer- account-id:billingview/billing-group-primary-account- id" * **ReportStatus** *(dict) --* The status of the report. * **lastDelivery** *(string) --* A timestamp that gives the date of a report delivery. * **lastStatus** *(string) --* An enum that gives the status of a report delivery. CostandUsageReportService / Client / get_paginator get_paginator ************* CostandUsageReportService.Client.get_paginator(operation_name) Create a paginator for an operation. Parameters: **operation_name** (*string*) -- The operation name. This is the same name as the method name on the client. For example, if the method name is "create_foo", and you'd normally invoke the operation as "client.create_foo(**kwargs)", if the "create_foo" operation can be paginated, you can use the call "client.get_paginator("create_foo")". Raises: **OperationNotPageableError** -- Raised if the operation is not pageable. You can use the "client.can_paginate" method to check if an operation is pageable. Return type: "botocore.paginate.Paginator" Returns: A paginator object. CostandUsageReportService / Client / put_report_definition put_report_definition ********************* CostandUsageReportService.Client.put_report_definition(**kwargs) Creates a new report using the description that you provide. See also: AWS API Documentation **Request Syntax** response = client.put_report_definition( ReportDefinition={ 'ReportName': 'string', 'TimeUnit': 'HOURLY'|'DAILY'|'MONTHLY', 'Format': 'textORcsv'|'Parquet', 'Compression': 'ZIP'|'GZIP'|'Parquet', 'AdditionalSchemaElements': [ 'RESOURCES'|'SPLIT_COST_ALLOCATION_DATA'|'MANUAL_DISCOUNT_COMPATIBILITY', ], 'S3Bucket': 'string', 'S3Prefix': 'string', 'S3Region': 'af-south-1'|'ap-east-1'|'ap-south-1'|'ap-south-2'|'ap-southeast-1'|'ap-southeast-2'|'ap-southeast-3'|'ap-northeast-1'|'ap-northeast-2'|'ap-northeast-3'|'ca-central-1'|'eu-central-1'|'eu-central-2'|'eu-west-1'|'eu-west-2'|'eu-west-3'|'eu-north-1'|'eu-south-1'|'eu-south-2'|'me-central-1'|'me-south-1'|'sa-east-1'|'us-east-1'|'us-east-2'|'us-west-1'|'us-west-2'|'cn-north-1'|'cn-northwest-1', 'AdditionalArtifacts': [ 'REDSHIFT'|'QUICKSIGHT'|'ATHENA', ], 'RefreshClosedReports': True|False, 'ReportVersioning': 'CREATE_NEW_REPORT'|'OVERWRITE_REPORT', 'BillingViewArn': 'string', 'ReportStatus': { 'lastDelivery': 'string', 'lastStatus': 'SUCCESS'|'ERROR_PERMISSIONS'|'ERROR_NO_BUCKET' } }, Tags=[ { 'Key': 'string', 'Value': 'string' }, ] ) Parameters: * **ReportDefinition** (*dict*) -- **[REQUIRED]** Represents the output of the PutReportDefinition operation. The content consists of the detailed metadata and data file information. * **ReportName** *(string) --* **[REQUIRED]** The name of the report that you want to create. The name must be unique, is case sensitive, and can't include spaces. * **TimeUnit** *(string) --* **[REQUIRED]** The length of time covered by the report. * **Format** *(string) --* **[REQUIRED]** The format that Amazon Web Services saves the report in. * **Compression** *(string) --* **[REQUIRED]** The compression format that Amazon Web Services uses for the report. * **AdditionalSchemaElements** *(list) --* **[REQUIRED]** A list of strings that indicate additional content that Amazon Web Services includes in the report, such as individual resource IDs. * *(string) --* Whether or not Amazon Web Services includes resource IDs in the report. * **S3Bucket** *(string) --* **[REQUIRED]** The S3 bucket where Amazon Web Services delivers the report. * **S3Prefix** *(string) --* **[REQUIRED]** The prefix that Amazon Web Services adds to the report name when Amazon Web Services delivers the report. Your prefix can't include spaces. * **S3Region** *(string) --* **[REQUIRED]** The region of the S3 bucket that Amazon Web Services delivers the report into. * **AdditionalArtifacts** *(list) --* A list of manifests that you want Amazon Web Services to create for this report. * *(string) --* The types of manifest that you want Amazon Web Services to create for this report. * **RefreshClosedReports** *(boolean) --* Whether you want Amazon Web Services to update your reports after they have been finalized if Amazon Web Services detects charges related to previous months. These charges can include refunds, credits, or support fees. * **ReportVersioning** *(string) --* Whether you want Amazon Web Services to overwrite the previous version of each report or to deliver the report in addition to the previous versions. * **BillingViewArn** *(string) --* The Amazon resource name of the billing view. The "BillingViewArn" is needed to create Amazon Web Services Cost and Usage Report for each billing group maintained in the Amazon Web Services Billing Conductor service. The "BillingViewArn" for a billing group can be constructed as: "arn:aws:billing::payer-account-id:billingview/billing- group-primary-account-id" * **ReportStatus** *(dict) --* The status of the report. * **lastDelivery** *(string) --* A timestamp that gives the date of a report delivery. * **lastStatus** *(string) --* An enum that gives the status of a report delivery. * **Tags** (*list*) -- The tags to be assigned to the report definition resource. * *(dict) --* Describes a tag. A tag is a key-value pair. You can add up to 50 tags to a report definition. * **Key** *(string) --* **[REQUIRED]** The key of the tag. Tag keys are case sensitive. Each report definition can only have up to one tag with the same key. If you try to add an existing tag with the same key, the existing tag value will be updated to the new value. * **Value** *(string) --* **[REQUIRED]** The value of the tag. Tag values are case-sensitive. This can be an empty string. Return type: dict Returns: **Response Syntax** {} **Response Structure** * *(dict) --* If the action is successful, the service sends back an HTTP 200 response with an empty HTTP body. **Exceptions** * "CostandUsageReportService.Client.exceptions.DuplicateReportName Exception" * "CostandUsageReportService.Client.exceptions.ReportLimitReachedE xception" * "CostandUsageReportService.Client.exceptions.InternalErrorExcept ion" * "CostandUsageReportService.Client.exceptions.ValidationException" * "CostandUsageReportService.Client.exceptions.ResourceNotFoundExc eption" **Examples** The following example creates a AWS Cost and Usage report named ExampleReport. response = client.put_report_definition( ReportDefinition={ 'AdditionalArtifacts': [ 'REDSHIFT', 'QUICKSIGHT', ], 'AdditionalSchemaElements': [ 'RESOURCES', ], 'Compression': 'ZIP', 'Format': 'textORcsv', 'ReportName': 'ExampleReport', 'S3Bucket': 'example-s3-bucket', 'S3Prefix': 'exampleprefix', 'S3Region': 'us-east-1', 'TimeUnit': 'DAILY', }, ) print(response) Expected Output: { 'ResponseMetadata': { '...': '...', }, } CostandUsageReportService / Client / can_paginate can_paginate ************ CostandUsageReportService.Client.can_paginate(operation_name) Check if an operation can be paginated. Parameters: **operation_name** (*string*) -- The operation name. This is the same name as the method name on the client. For example, if the method name is "create_foo", and you'd normally invoke the operation as "client.create_foo(**kwargs)", if the "create_foo" operation can be paginated, you can use the call "client.get_paginator("create_foo")". Returns: "True" if the operation can be paginated, "False" otherwise. CostandUsageReportService / Client / list_tags_for_resource list_tags_for_resource ********************** CostandUsageReportService.Client.list_tags_for_resource(**kwargs) Lists the tags associated with the specified report definition. See also: AWS API Documentation **Request Syntax** response = client.list_tags_for_resource( ReportName='string' ) Parameters: **ReportName** (*string*) -- **[REQUIRED]** The report name of the report definition that tags are to be returned for. Return type: dict Returns: **Response Syntax** { 'Tags': [ { 'Key': 'string', 'Value': 'string' }, ] } **Response Structure** * *(dict) --* * **Tags** *(list) --* The tags assigned to the report definition resource. * *(dict) --* Describes a tag. A tag is a key-value pair. You can add up to 50 tags to a report definition. * **Key** *(string) --* The key of the tag. Tag keys are case sensitive. Each report definition can only have up to one tag with the same key. If you try to add an existing tag with the same key, the existing tag value will be updated to the new value. * **Value** *(string) --* The value of the tag. Tag values are case-sensitive. This can be an empty string. **Exceptions** * "CostandUsageReportService.Client.exceptions.ResourceNotFoundExc eption" * "CostandUsageReportService.Client.exceptions.InternalErrorExcept ion" * "CostandUsageReportService.Client.exceptions.ValidationException" CostandUsageReportService / Client / untag_resource untag_resource ************** CostandUsageReportService.Client.untag_resource(**kwargs) Disassociates a set of tags from a report definition. See also: AWS API Documentation **Request Syntax** response = client.untag_resource( ReportName='string', TagKeys=[ 'string', ] ) Parameters: * **ReportName** (*string*) -- **[REQUIRED]** The report name of the report definition that tags are to be disassociated from. * **TagKeys** (*list*) -- **[REQUIRED]** The tags to be disassociated from the report definition resource. * *(string) --* Return type: dict Returns: **Response Syntax** {} **Response Structure** * *(dict) --* **Exceptions** * "CostandUsageReportService.Client.exceptions.ResourceNotFoundExc eption" * "CostandUsageReportService.Client.exceptions.InternalErrorExcept ion" * "CostandUsageReportService.Client.exceptions.ValidationException" CostandUsageReportService / Client / get_waiter get_waiter ********** CostandUsageReportService.Client.get_waiter(waiter_name) Returns an object that can wait for some condition. Parameters: **waiter_name** (*str*) -- The name of the waiter to get. See the waiters section of the service docs for a list of available waiters. Returns: The specified waiter object. Return type: "botocore.waiter.Waiter" CostandUsageReportService / Client / delete_report_definition delete_report_definition ************************ CostandUsageReportService.Client.delete_report_definition(**kwargs) Deletes the specified report. Any tags associated with the report are also deleted. See also: AWS API Documentation **Request Syntax** response = client.delete_report_definition( ReportName='string' ) Parameters: **ReportName** (*string*) -- **[REQUIRED]** The name of the report that you want to delete. The name must be unique, is case sensitive, and can't include spaces. Return type: dict Returns: **Response Syntax** { 'ResponseMessage': 'string' } **Response Structure** * *(dict) --* If the action is successful, the service sends back an HTTP 200 response. * **ResponseMessage** *(string) --* Whether the deletion was successful or not. **Exceptions** * "CostandUsageReportService.Client.exceptions.InternalErrorExcept ion" * "CostandUsageReportService.Client.exceptions.ValidationException" **Examples** The following example deletes the AWS Cost and Usage report named ExampleReport. response = client.delete_report_definition( ReportName='ExampleReport', ) print(response) Expected Output: { 'ResponseMetadata': { '...': '...', }, } CostandUsageReportService / Client / modify_report_definition modify_report_definition ************************ CostandUsageReportService.Client.modify_report_definition(**kwargs) Allows you to programmatically update your report preferences. See also: AWS API Documentation **Request Syntax** response = client.modify_report_definition( ReportName='string', ReportDefinition={ 'ReportName': 'string', 'TimeUnit': 'HOURLY'|'DAILY'|'MONTHLY', 'Format': 'textORcsv'|'Parquet', 'Compression': 'ZIP'|'GZIP'|'Parquet', 'AdditionalSchemaElements': [ 'RESOURCES'|'SPLIT_COST_ALLOCATION_DATA'|'MANUAL_DISCOUNT_COMPATIBILITY', ], 'S3Bucket': 'string', 'S3Prefix': 'string', 'S3Region': 'af-south-1'|'ap-east-1'|'ap-south-1'|'ap-south-2'|'ap-southeast-1'|'ap-southeast-2'|'ap-southeast-3'|'ap-northeast-1'|'ap-northeast-2'|'ap-northeast-3'|'ca-central-1'|'eu-central-1'|'eu-central-2'|'eu-west-1'|'eu-west-2'|'eu-west-3'|'eu-north-1'|'eu-south-1'|'eu-south-2'|'me-central-1'|'me-south-1'|'sa-east-1'|'us-east-1'|'us-east-2'|'us-west-1'|'us-west-2'|'cn-north-1'|'cn-northwest-1', 'AdditionalArtifacts': [ 'REDSHIFT'|'QUICKSIGHT'|'ATHENA', ], 'RefreshClosedReports': True|False, 'ReportVersioning': 'CREATE_NEW_REPORT'|'OVERWRITE_REPORT', 'BillingViewArn': 'string', 'ReportStatus': { 'lastDelivery': 'string', 'lastStatus': 'SUCCESS'|'ERROR_PERMISSIONS'|'ERROR_NO_BUCKET' } } ) Parameters: * **ReportName** (*string*) -- **[REQUIRED]** The name of the report that you want to create. The name must be unique, is case sensitive, and can't include spaces. * **ReportDefinition** (*dict*) -- **[REQUIRED]** The definition of Amazon Web Services Cost and Usage Report. You can specify the report name, time unit, report format, compression format, S3 bucket, additional artifacts, and schema elements in the definition. * **ReportName** *(string) --* **[REQUIRED]** The name of the report that you want to create. The name must be unique, is case sensitive, and can't include spaces. * **TimeUnit** *(string) --* **[REQUIRED]** The length of time covered by the report. * **Format** *(string) --* **[REQUIRED]** The format that Amazon Web Services saves the report in. * **Compression** *(string) --* **[REQUIRED]** The compression format that Amazon Web Services uses for the report. * **AdditionalSchemaElements** *(list) --* **[REQUIRED]** A list of strings that indicate additional content that Amazon Web Services includes in the report, such as individual resource IDs. * *(string) --* Whether or not Amazon Web Services includes resource IDs in the report. * **S3Bucket** *(string) --* **[REQUIRED]** The S3 bucket where Amazon Web Services delivers the report. * **S3Prefix** *(string) --* **[REQUIRED]** The prefix that Amazon Web Services adds to the report name when Amazon Web Services delivers the report. Your prefix can't include spaces. * **S3Region** *(string) --* **[REQUIRED]** The region of the S3 bucket that Amazon Web Services delivers the report into. * **AdditionalArtifacts** *(list) --* A list of manifests that you want Amazon Web Services to create for this report. * *(string) --* The types of manifest that you want Amazon Web Services to create for this report. * **RefreshClosedReports** *(boolean) --* Whether you want Amazon Web Services to update your reports after they have been finalized if Amazon Web Services detects charges related to previous months. These charges can include refunds, credits, or support fees. * **ReportVersioning** *(string) --* Whether you want Amazon Web Services to overwrite the previous version of each report or to deliver the report in addition to the previous versions. * **BillingViewArn** *(string) --* The Amazon resource name of the billing view. The "BillingViewArn" is needed to create Amazon Web Services Cost and Usage Report for each billing group maintained in the Amazon Web Services Billing Conductor service. The "BillingViewArn" for a billing group can be constructed as: "arn:aws:billing::payer-account-id:billingview/billing- group-primary-account-id" * **ReportStatus** *(dict) --* The status of the report. * **lastDelivery** *(string) --* A timestamp that gives the date of a report delivery. * **lastStatus** *(string) --* An enum that gives the status of a report delivery. Return type: dict Returns: **Response Syntax** {} **Response Structure** * *(dict) --* **Exceptions** * "CostandUsageReportService.Client.exceptions.InternalErrorExcept ion" * "CostandUsageReportService.Client.exceptions.ValidationException" CostandUsageReportService / Client / describe_report_definitions describe_report_definitions *************************** CostandUsageReportService.Client.describe_report_definitions(**kwargs) Lists the Amazon Web Services Cost and Usage Report available to this account. See also: AWS API Documentation **Request Syntax** response = client.describe_report_definitions( MaxResults=123, NextToken='string' ) Parameters: * **MaxResults** (*integer*) -- The maximum number of results that Amazon Web Services returns for the operation. * **NextToken** (*string*) -- A generic string. Return type: dict Returns: **Response Syntax** { 'ReportDefinitions': [ { 'ReportName': 'string', 'TimeUnit': 'HOURLY'|'DAILY'|'MONTHLY', 'Format': 'textORcsv'|'Parquet', 'Compression': 'ZIP'|'GZIP'|'Parquet', 'AdditionalSchemaElements': [ 'RESOURCES'|'SPLIT_COST_ALLOCATION_DATA'|'MANUAL_DISCOUNT_COMPATIBILITY', ], 'S3Bucket': 'string', 'S3Prefix': 'string', 'S3Region': 'af-south-1'|'ap-east-1'|'ap-south-1'|'ap-south-2'|'ap-southeast-1'|'ap-southeast-2'|'ap-southeast-3'|'ap-northeast-1'|'ap-northeast-2'|'ap-northeast-3'|'ca-central-1'|'eu-central-1'|'eu-central-2'|'eu-west-1'|'eu-west-2'|'eu-west-3'|'eu-north-1'|'eu-south-1'|'eu-south-2'|'me-central-1'|'me-south-1'|'sa-east-1'|'us-east-1'|'us-east-2'|'us-west-1'|'us-west-2'|'cn-north-1'|'cn-northwest-1', 'AdditionalArtifacts': [ 'REDSHIFT'|'QUICKSIGHT'|'ATHENA', ], 'RefreshClosedReports': True|False, 'ReportVersioning': 'CREATE_NEW_REPORT'|'OVERWRITE_REPORT', 'BillingViewArn': 'string', 'ReportStatus': { 'lastDelivery': 'string', 'lastStatus': 'SUCCESS'|'ERROR_PERMISSIONS'|'ERROR_NO_BUCKET' } }, ], 'NextToken': 'string' } **Response Structure** * *(dict) --* If the action is successful, the service sends back an HTTP 200 response. * **ReportDefinitions** *(list) --* An Amazon Web Services Cost and Usage Report list owned by the account. * *(dict) --* The definition of Amazon Web Services Cost and Usage Report. You can specify the report name, time unit, report format, compression format, S3 bucket, additional artifacts, and schema elements in the definition. * **ReportName** *(string) --* The name of the report that you want to create. The name must be unique, is case sensitive, and can't include spaces. * **TimeUnit** *(string) --* The length of time covered by the report. * **Format** *(string) --* The format that Amazon Web Services saves the report in. * **Compression** *(string) --* The compression format that Amazon Web Services uses for the report. * **AdditionalSchemaElements** *(list) --* A list of strings that indicate additional content that Amazon Web Services includes in the report, such as individual resource IDs. * *(string) --* Whether or not Amazon Web Services includes resource IDs in the report. * **S3Bucket** *(string) --* The S3 bucket where Amazon Web Services delivers the report. * **S3Prefix** *(string) --* The prefix that Amazon Web Services adds to the report name when Amazon Web Services delivers the report. Your prefix can't include spaces. * **S3Region** *(string) --* The region of the S3 bucket that Amazon Web Services delivers the report into. * **AdditionalArtifacts** *(list) --* A list of manifests that you want Amazon Web Services to create for this report. * *(string) --* The types of manifest that you want Amazon Web Services to create for this report. * **RefreshClosedReports** *(boolean) --* Whether you want Amazon Web Services to update your reports after they have been finalized if Amazon Web Services detects charges related to previous months. These charges can include refunds, credits, or support fees. * **ReportVersioning** *(string) --* Whether you want Amazon Web Services to overwrite the previous version of each report or to deliver the report in addition to the previous versions. * **BillingViewArn** *(string) --* The Amazon resource name of the billing view. The "BillingViewArn" is needed to create Amazon Web Services Cost and Usage Report for each billing group maintained in the Amazon Web Services Billing Conductor service. The "BillingViewArn" for a billing group can be constructed as: "arn:aws:billing::payer-account- id:billingview/billing-group-primary-account-id" * **ReportStatus** *(dict) --* The status of the report. * **lastDelivery** *(string) --* A timestamp that gives the date of a report delivery. * **lastStatus** *(string) --* An enum that gives the status of a report delivery. * **NextToken** *(string) --* A generic string. **Exceptions** * "CostandUsageReportService.Client.exceptions.InternalErrorExcept ion" **Examples** The following example lists the AWS Cost and Usage reports for the account. response = client.describe_report_definitions( MaxResults=5, ) print(response) Expected Output: { 'ReportDefinitions': [ { 'AdditionalArtifacts': [ 'QUICKSIGHT', ], 'AdditionalSchemaElements': [ 'RESOURCES', ], 'Compression': 'GZIP', 'Format': 'textORcsv', 'ReportName': 'ExampleReport', 'S3Bucket': 'example-s3-bucket', 'S3Prefix': 'exampleprefix', 'S3Region': 'us-east-1', 'TimeUnit': 'HOURLY', }, { 'AdditionalArtifacts': [ 'QUICKSIGHT', ], 'AdditionalSchemaElements': [ 'RESOURCES', ], 'Compression': 'GZIP', 'Format': 'textORcsv', 'ReportName': 'ExampleReport2', 'S3Bucket': 'example-s3-bucket', 'S3Prefix': 'exampleprefix', 'S3Region': 'us-east-1', 'TimeUnit': 'HOURLY', }, ], 'ResponseMetadata': { '...': '...', }, } CostandUsageReportService / Client / close close ***** CostandUsageReportService.Client.close() Closes underlying endpoint connections. CostandUsageReportService / Client / tag_resource tag_resource ************ CostandUsageReportService.Client.tag_resource(**kwargs) Associates a set of tags with a report definition. See also: AWS API Documentation **Request Syntax** response = client.tag_resource( ReportName='string', Tags=[ { 'Key': 'string', 'Value': 'string' }, ] ) Parameters: * **ReportName** (*string*) -- **[REQUIRED]** The report name of the report definition that tags are to be associated with. * **Tags** (*list*) -- **[REQUIRED]** The tags to be assigned to the report definition resource. * *(dict) --* Describes a tag. A tag is a key-value pair. You can add up to 50 tags to a report definition. * **Key** *(string) --* **[REQUIRED]** The key of the tag. Tag keys are case sensitive. Each report definition can only have up to one tag with the same key. If you try to add an existing tag with the same key, the existing tag value will be updated to the new value. * **Value** *(string) --* **[REQUIRED]** The value of the tag. Tag values are case-sensitive. This can be an empty string. Return type: dict Returns: **Response Syntax** {} **Response Structure** * *(dict) --* **Exceptions** * "CostandUsageReportService.Client.exceptions.ResourceNotFoundExc eption" * "CostandUsageReportService.Client.exceptions.InternalErrorExcept ion" * "CostandUsageReportService.Client.exceptions.ValidationException"