Note : This endpoint is in preview and is subject to change.
If you have any feedback, contact Datadog support .
GET https://api.ap1.datadoghq.com/api/v2/cost/commitments/savings/timeseries https://api.ap2.datadoghq.com/api/v2/cost/commitments/savings/timeseries https://api.datadoghq.eu/api/v2/cost/commitments/savings/timeseries https://api.ddog-gov.com/api/v2/cost/commitments/savings/timeseries https://api.us2.ddog-gov.com/api/v2/cost/commitments/savings/timeseries https://api.datadoghq.com/api/v2/cost/commitments/savings/timeseries https://api.us3.datadoghq.com/api/v2/cost/commitments/savings/timeseries https://api.us5.datadoghq.com/api/v2/cost/commitments/savings/timeseries
Overview Get timeseries savings metrics for cloud commitment programs, including actual cost, on-demand equivalent cost, realized savings, and effective savings rate over time.
This endpoint requires the cloud_cost_management_read permission.
OAuth apps require the cloud_cost_management_read authorization scope to access this endpoint.
Arguments Query Strings Cloud provider for commitment programs (aws or azure). Allowed enum values: aws, azure
Cloud product identifier (for example, ec2, rds, virtualmachines).
Start of the query time range in Unix milliseconds.
End of the query time range in Unix milliseconds.
Optional filter expression to narrow down results.
Response OK
Response containing timeseries savings metrics for cloud commitment programs.
Expand All
A timeseries metric containing timestamps, series values, and optional unit metadata.
Timeseries data as a map of series names to their corresponding value arrays.
A series of numeric values for a timeseries metric.
Unix timestamps in seconds for the timeseries data points.
Unit metadata for a numeric metric.
The unit family (for example, percentage or money).
The unit name (for example, percent or dollar).
The plural form of the unit name.
The scale factor for the unit.
The abbreviated unit name (for example, % or $).
effective_savings_rate [required ]
A timeseries metric containing timestamps, series values, and optional unit metadata.
Timeseries data as a map of series names to their corresponding value arrays.
A series of numeric values for a timeseries metric.
Unix timestamps in seconds for the timeseries data points.
Unit metadata for a numeric metric.
The unit family (for example, percentage or money).
The unit name (for example, percent or dollar).
The plural form of the unit name.
The scale factor for the unit.
The abbreviated unit name (for example, % or $).
on_demand_equivalent_cost [required ]
A timeseries metric containing timestamps, series values, and optional unit metadata.
Timeseries data as a map of series names to their corresponding value arrays.
A series of numeric values for a timeseries metric.
Unix timestamps in seconds for the timeseries data points.
Unit metadata for a numeric metric.
The unit family (for example, percentage or money).
The unit name (for example, percent or dollar).
The plural form of the unit name.
The scale factor for the unit.
The abbreviated unit name (for example, % or $).
realized_savings [required ]
A timeseries metric containing timestamps, series values, and optional unit metadata.
Timeseries data as a map of series names to their corresponding value arrays.
A series of numeric values for a timeseries metric.
Unix timestamps in seconds for the timeseries data points.
Unit metadata for a numeric metric.
The unit family (for example, percentage or money).
The unit name (for example, percent or dollar).
The plural form of the unit name.
The scale factor for the unit.
The abbreviated unit name (for example, % or $).
{
"actual_cost" : {
"series" : {
"<any-key>" : []
},
"times" : [
1693526400 ,
1693612800
],
"unit" : {
"family" : "percentage" ,
"id" : 17 ,
"name" : "percent" ,
"plural" : "percent" ,
"scale_factor" : 1 ,
"short_name" : "%"
}
},
"effective_savings_rate" : {
"series" : {
"<any-key>" : []
},
"times" : [
1693526400 ,
1693612800
],
"unit" : {
"family" : "percentage" ,
"id" : 17 ,
"name" : "percent" ,
"plural" : "percent" ,
"scale_factor" : 1 ,
"short_name" : "%"
}
},
"on_demand_equivalent_cost" : {
"series" : {
"<any-key>" : []
},
"times" : [
1693526400 ,
1693612800
],
"unit" : {
"family" : "percentage" ,
"id" : 17 ,
"name" : "percent" ,
"plural" : "percent" ,
"scale_factor" : 1 ,
"short_name" : "%"
}
},
"realized_savings" : {
"series" : {
"<any-key>" : []
},
"times" : [
1693526400 ,
1693612800
],
"unit" : {
"family" : "percentage" ,
"id" : 17 ,
"name" : "percent" ,
"plural" : "percent" ,
"scale_factor" : 1 ,
"short_name" : "%"
}
}
} Bad Request
API error response.
Expand All
A human-readable explanation specific to this occurrence of the error.
Non-standard meta-information about the error
References to the source of the error.
A string indicating the name of a single request header which caused the error.
A string indicating which URI query parameter caused the error.
A JSON pointer to the value in the request document that caused the error.
Status code of the response.
Short human-readable summary of the error.
{
"errors" : [
{
"detail" : "Missing required attribute in body" ,
"meta" : {},
"source" : {
"header" : "Authorization" ,
"parameter" : "limit" ,
"pointer" : "/data/attributes/title"
},
"status" : "400" ,
"title" : "Bad Request"
}
]
} Too many requests
{
"errors" : [
"Bad Request"
]
} Code Example Copy
# Required query arguments export provider = "aws" export product = "ec2" export start = "1.6935264e+12" export end = "1.6961184e+12" # Curl command curl -X GET "https://api.ap1.datadoghq.com "https://api.ap2.datadoghq.com "https://api.datadoghq.eu "https://api.ddog-gov.com "https://api.us2.ddog-gov.com "https://api.datadoghq.com "https://api.us3.datadoghq.com "https://api.us5.datadoghq.com /api/v2/cost/commitments/savings/timeseries ? provider = ${provider} & product = ${product} & start = ${start} & end = ${end} " \
-H "Accept: application/json" \
-H "DD-API-KEY: ${DD_API_KEY} " \
-H "DD-APPLICATION-KEY: ${DD_APP_KEY} "
"""
Get commitments savings (timeseries) returns "OK" response
"""
from datadog_api_client import ApiClient , Configuration
from datadog_api_client.v2.api.cloud_cost_management_api import CloudCostManagementApi
from datadog_api_client.v2.model.commitments_provider import CommitmentsProvider
configuration = Configuration ()
configuration . unstable_operations [ "get_commitments_savings_timeseries" ] = True
with ApiClient ( configuration ) as api_client :
api_instance = CloudCostManagementApi ( api_client )
response = api_instance . get_commitments_savings_timeseries (
provider = CommitmentsProvider . AWS ,
product = "product" ,
start = 9223372036854775807 ,
end = 9223372036854775807 ,
)
print ( response )
Instructions First install the library and its dependencies and then save the example to example.py and run following commands:
DD_SITE = "datadoghq.com us3.datadoghq.com us5.datadoghq.com datadoghq.eu ap1.datadoghq.com ap2.datadoghq.com ddog-gov.com us2.ddog-gov.com " DD_API_KEY = "<DD_API_KEY>" DD_APP_KEY = "<DD_APP_KEY>" python3 "example.py"
# Get commitments savings (timeseries) returns "OK" response
require "datadog_api_client"
DatadogAPIClient . configure do | config |
config . unstable_operations [ "v2.get_commitments_savings_timeseries" . to_sym ] = true
end
api_instance = DatadogAPIClient :: V2 :: CloudCostManagementAPI . new
p api_instance . get_commitments_savings_timeseries ( CommitmentsProvider :: AWS , "product" , 9223372036854775807 , 9223372036854775807 )
Instructions First install the library and its dependencies and then save the example to example.rb and run following commands:
DD_SITE = "datadoghq.com us3.datadoghq.com us5.datadoghq.com datadoghq.eu ap1.datadoghq.com ap2.datadoghq.com ddog-gov.com us2.ddog-gov.com " DD_API_KEY = "<DD_API_KEY>" DD_APP_KEY = "<DD_APP_KEY>" rb "example.rb"
// Get commitments savings (timeseries) returns "OK" response
package main
import (
"context"
"encoding/json"
"fmt"
"os"
"github.com/DataDog/datadog-api-client-go/v2/api/datadog"
"github.com/DataDog/datadog-api-client-go/v2/api/datadogV2"
)
func main () {
ctx := datadog . NewDefaultContext ( context . Background ())
configuration := datadog . NewConfiguration ()
configuration . SetUnstableOperationEnabled ( "v2.GetCommitmentsSavingsTimeseries" , true )
apiClient := datadog . NewAPIClient ( configuration )
api := datadogV2 . NewCloudCostManagementApi ( apiClient )
resp , r , err := api . GetCommitmentsSavingsTimeseries ( ctx , datadogV2 . COMMITMENTSPROVIDER_AWS , "product" , 9223372036854775807 , 9223372036854775807 , * datadogV2 . NewGetCommitmentsSavingsTimeseriesOptionalParameters ())
if err != nil {
fmt . Fprintf ( os . Stderr , "Error when calling `CloudCostManagementApi.GetCommitmentsSavingsTimeseries`: %v\n" , err )
fmt . Fprintf ( os . Stderr , "Full HTTP response: %v\n" , r )
}
responseContent , _ := json . MarshalIndent ( resp , "" , " " )
fmt . Fprintf ( os . Stdout , "Response from `CloudCostManagementApi.GetCommitmentsSavingsTimeseries`:\n%s\n" , responseContent )
}
Instructions First install the library and its dependencies and then save the example to main.go and run following commands:
DD_SITE = "datadoghq.com us3.datadoghq.com us5.datadoghq.com datadoghq.eu ap1.datadoghq.com ap2.datadoghq.com ddog-gov.com us2.ddog-gov.com " DD_API_KEY = "<DD_API_KEY>" DD_APP_KEY = "<DD_APP_KEY>" go run "main.go"
// Get commitments savings (timeseries) returns "OK" response
import com.datadog.api.client.ApiClient ;
import com.datadog.api.client.ApiException ;
import com.datadog.api.client.v2.api.CloudCostManagementApi ;
import com.datadog.api.client.v2.model.CommitmentsProvider ;
import com.datadog.api.client.v2.model.CommitmentsSavingsTimeseriesResponse ;
public class Example {
public static void main ( String [] args ) {
ApiClient defaultClient = ApiClient . getDefaultApiClient ();
defaultClient . setUnstableOperationEnabled ( "v2.getCommitmentsSavingsTimeseries" , true );
CloudCostManagementApi apiInstance = new CloudCostManagementApi ( defaultClient );
try {
CommitmentsSavingsTimeseriesResponse result =
apiInstance . getCommitmentsSavingsTimeseries (
CommitmentsProvider . AWS , "ec2" , 1693526400000L , 1696118400000L );
System . out . println ( result );
} catch ( ApiException e ) {
System . err . println (
"Exception when calling CloudCostManagementApi#getCommitmentsSavingsTimeseries" );
System . err . println ( "Status code: " + e . getCode ());
System . err . println ( "Reason: " + e . getResponseBody ());
System . err . println ( "Response headers: " + e . getResponseHeaders ());
e . printStackTrace ();
}
}
}
Instructions First install the library and its dependencies and then save the example to Example.java and run following commands:
DD_SITE = "datadoghq.com us3.datadoghq.com us5.datadoghq.com datadoghq.eu ap1.datadoghq.com ap2.datadoghq.com ddog-gov.com us2.ddog-gov.com " DD_API_KEY = "<DD_API_KEY>" DD_APP_KEY = "<DD_APP_KEY>" java "Example.java"
// Get commitments savings (timeseries) returns "OK" response
use datadog_api_client ::datadog ;
use datadog_api_client ::datadogV2 ::api_cloud_cost_management ::CloudCostManagementAPI ;
use datadog_api_client ::datadogV2 ::api_cloud_cost_management ::GetCommitmentsSavingsTimeseriesOptionalParams ;
use datadog_api_client ::datadogV2 ::model ::CommitmentsProvider ;
#[tokio::main]
async fn main () {
let mut configuration = datadog ::Configuration ::new ();
configuration . set_unstable_operation_enabled ( "v2.GetCommitmentsSavingsTimeseries" , true );
let api = CloudCostManagementAPI ::with_config ( configuration );
let resp = api
. get_commitments_savings_timeseries (
CommitmentsProvider ::AWS ,
"product" . to_string (),
9223372036854775807 ,
9223372036854775807 ,
GetCommitmentsSavingsTimeseriesOptionalParams ::default (),
)
. await ;
if let Ok ( value ) = resp {
println! ( " {:#?} " , value );
} else {
println! ( " {:#?} " , resp . unwrap_err ());
}
}
Instructions First install the library and its dependencies and then save the example to src/main.rs and run following commands:
DD_SITE = "datadoghq.com us3.datadoghq.com us5.datadoghq.com datadoghq.eu ap1.datadoghq.com ap2.datadoghq.com ddog-gov.com us2.ddog-gov.com " DD_API_KEY = "<DD_API_KEY>" DD_APP_KEY = "<DD_APP_KEY>" cargo run
/**
* Get commitments savings (timeseries) returns "OK" response
*/
import { client , v2 } from "@datadog/datadog-api-client" ;
const configuration = client . createConfiguration ();
configuration . unstableOperations [ "v2.getCommitmentsSavingsTimeseries" ] = true ;
const apiInstance = new v2 . CloudCostManagementApi ( configuration );
const params : v2.CloudCostManagementApiGetCommitmentsSavingsTimeseriesRequest =
{
provider : "aws" ,
product : "product" ,
start : 9223372036854775807 ,
end : 9223372036854775807 ,
};
apiInstance
. getCommitmentsSavingsTimeseries ( params )
. then (( data : v2.CommitmentsSavingsTimeseriesResponse ) => {
console . log (
"API called successfully. Returned data: " + JSON . stringify ( data )
);
})
. catch (( error : any ) => console . error ( error ));
Instructions First install the library and its dependencies and then save the example to example.ts and run following commands:
DD_SITE = "datadoghq.com us3.datadoghq.com us5.datadoghq.com datadoghq.eu ap1.datadoghq.com ap2.datadoghq.com ddog-gov.com us2.ddog-gov.com " DD_API_KEY = "<DD_API_KEY>" DD_APP_KEY = "<DD_APP_KEY>" tsc "example.ts"