Note : This endpoint is in preview and is subject to change.
If you have any feedback, contact Datadog support .
POST https://api.ap1.datadoghq.com/api/v2/llm-obs/v1/projects https://api.ap2.datadoghq.com/api/v2/llm-obs/v1/projects https://api.datadoghq.eu/api/v2/llm-obs/v1/projects https://api.ddog-gov.com/api/v2/llm-obs/v1/projects https://api.us2.ddog-gov.com/api/v2/llm-obs/v1/projects https://api.datadoghq.com/api/v2/llm-obs/v1/projects https://api.us3.datadoghq.com/api/v2/llm-obs/v1/projects https://api.us5.datadoghq.com/api/v2/llm-obs/v1/projects
Overview Create a new LLM Observability project. Returns the existing project if a name conflict occurs.
Request Body Data (required) Create project payload.
Expand All
Data object for creating an LLM Observability project.
Attributes for creating an LLM Observability project.
Description of the project.
Resource type of an LLM Observability project.
Allowed enum values: projects
{
"data" : {
"attributes" : {
"description" : "string" ,
"name" : "My LLM Project"
},
"type" : "projects"
}
} Response OK
Response containing a single LLM Observability project.
Expand All
Data object for an LLM Observability project.
Attributes of an LLM Observability project.
Timestamp when the project was created.
Description of the project.
Timestamp when the project was last updated.
Unique identifier of the project.
Resource type of an LLM Observability project.
Allowed enum values: projects
{
"data" : {
"attributes" : {
"created_at" : "2024-01-15T10:30:00Z" ,
"description" : "" ,
"name" : "My LLM Project" ,
"updated_at" : "2024-01-15T10:30:00Z"
},
"id" : "a33671aa-24fd-4dcd-9b33-a8ec7dde7751" ,
"type" : "projects"
}
} Created
Response containing a single LLM Observability project.
Expand All
Data object for an LLM Observability project.
Attributes of an LLM Observability project.
Timestamp when the project was created.
Description of the project.
Timestamp when the project was last updated.
Unique identifier of the project.
Resource type of an LLM Observability project.
Allowed enum values: projects
{
"data" : {
"attributes" : {
"created_at" : "2024-01-15T10:30:00Z" ,
"description" : "" ,
"name" : "My LLM Project" ,
"updated_at" : "2024-01-15T10:30:00Z"
},
"id" : "a33671aa-24fd-4dcd-9b33-a8ec7dde7751" ,
"type" : "projects"
}
} 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"
}
]
} Unauthorized
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"
}
]
} Forbidden
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
## default
#
# Curl command curl -X POST "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/llm-obs/v1/projects " \
-H "Accept: application/json" \
-H "Content-Type: application/json" \
-H "DD-API-KEY: ${DD_API_KEY} " \
-H "DD-APPLICATION-KEY: ${DD_APP_KEY} " \
-d @- << EOF
{
"data": {
"attributes": {
"name": "My LLM Project"
},
"type": "projects"
}
}
EOF
"""
Create an LLM Observability project returns "OK" response
"""
from datadog_api_client import ApiClient , Configuration
from datadog_api_client.v2.api.llm_observability_api import LLMObservabilityApi
from datadog_api_client.v2.model.llm_obs_project_data_attributes_request import LLMObsProjectDataAttributesRequest
from datadog_api_client.v2.model.llm_obs_project_data_request import LLMObsProjectDataRequest
from datadog_api_client.v2.model.llm_obs_project_request import LLMObsProjectRequest
from datadog_api_client.v2.model.llm_obs_project_type import LLMObsProjectType
body = LLMObsProjectRequest (
data = LLMObsProjectDataRequest (
attributes = LLMObsProjectDataAttributesRequest (
name = "My LLM Project" ,
),
type = LLMObsProjectType . PROJECTS ,
),
)
configuration = Configuration ()
configuration . unstable_operations [ "create_llm_obs_project" ] = True
with ApiClient ( configuration ) as api_client :
api_instance = LLMObservabilityApi ( api_client )
response = api_instance . create_llm_obs_project ( body = body )
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"
# Create an LLM Observability project returns "OK" response
require "datadog_api_client"
DatadogAPIClient . configure do | config |
config . unstable_operations [ "v2.create_llm_obs_project" . to_sym ] = true
end
api_instance = DatadogAPIClient :: V2 :: LLMObservabilityAPI . new
body = DatadogAPIClient :: V2 :: LLMObsProjectRequest . new ({
data : DatadogAPIClient :: V2 :: LLMObsProjectDataRequest . new ({
attributes : DatadogAPIClient :: V2 :: LLMObsProjectDataAttributesRequest . new ({
name : "My LLM Project" ,
}),
type : DatadogAPIClient :: V2 :: LLMObsProjectType :: PROJECTS ,
}),
})
p api_instance . create_llm_obs_project ( body )
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"
// Create an LLM Observability project 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 () {
body := datadogV2 . LLMObsProjectRequest {
Data : datadogV2 . LLMObsProjectDataRequest {
Attributes : datadogV2 . LLMObsProjectDataAttributesRequest {
Name : "My LLM Project" ,
},
Type : datadogV2 . LLMOBSPROJECTTYPE_PROJECTS ,
},
}
ctx := datadog . NewDefaultContext ( context . Background ())
configuration := datadog . NewConfiguration ()
configuration . SetUnstableOperationEnabled ( "v2.CreateLLMObsProject" , true )
apiClient := datadog . NewAPIClient ( configuration )
api := datadogV2 . NewLLMObservabilityApi ( apiClient )
resp , r , err := api . CreateLLMObsProject ( ctx , body )
if err != nil {
fmt . Fprintf ( os . Stderr , "Error when calling `LLMObservabilityApi.CreateLLMObsProject`: %v\n" , err )
fmt . Fprintf ( os . Stderr , "Full HTTP response: %v\n" , r )
}
responseContent , _ := json . MarshalIndent ( resp , "" , " " )
fmt . Fprintf ( os . Stdout , "Response from `LLMObservabilityApi.CreateLLMObsProject`:\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"
// Create an LLM Observability project returns "OK" response
import com.datadog.api.client.ApiClient ;
import com.datadog.api.client.ApiException ;
import com.datadog.api.client.v2.api.LlmObservabilityApi ;
import com.datadog.api.client.v2.model.LLMObsProjectDataAttributesRequest ;
import com.datadog.api.client.v2.model.LLMObsProjectDataRequest ;
import com.datadog.api.client.v2.model.LLMObsProjectRequest ;
import com.datadog.api.client.v2.model.LLMObsProjectResponse ;
import com.datadog.api.client.v2.model.LLMObsProjectType ;
public class Example {
public static void main ( String [] args ) {
ApiClient defaultClient = ApiClient . getDefaultApiClient ();
defaultClient . setUnstableOperationEnabled ( "v2.createLLMObsProject" , true );
LlmObservabilityApi apiInstance = new LlmObservabilityApi ( defaultClient );
LLMObsProjectRequest body =
new LLMObsProjectRequest ()
. data (
new LLMObsProjectDataRequest ()
. attributes ( new LLMObsProjectDataAttributesRequest (). name ( "My LLM Project" ))
. type ( LLMObsProjectType . PROJECTS ));
try {
LLMObsProjectResponse result = apiInstance . createLLMObsProject ( body );
System . out . println ( result );
} catch ( ApiException e ) {
System . err . println ( "Exception when calling LlmObservabilityApi#createLLMObsProject" );
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"
// Create an LLM Observability project returns "OK" response
use datadog_api_client ::datadog ;
use datadog_api_client ::datadogV2 ::api_llm_observability ::LLMObservabilityAPI ;
use datadog_api_client ::datadogV2 ::model ::LLMObsProjectDataAttributesRequest ;
use datadog_api_client ::datadogV2 ::model ::LLMObsProjectDataRequest ;
use datadog_api_client ::datadogV2 ::model ::LLMObsProjectRequest ;
use datadog_api_client ::datadogV2 ::model ::LLMObsProjectType ;
#[tokio::main]
async fn main () {
let body = LLMObsProjectRequest ::new ( LLMObsProjectDataRequest ::new (
LLMObsProjectDataAttributesRequest ::new ( "My LLM Project" . to_string ()),
LLMObsProjectType ::PROJECTS ,
));
let mut configuration = datadog ::Configuration ::new ();
configuration . set_unstable_operation_enabled ( "v2.CreateLLMObsProject" , true );
let api = LLMObservabilityAPI ::with_config ( configuration );
let resp = api . create_llm_obs_project ( body ). 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
/**
* Create an LLM Observability project returns "OK" response
*/
import { client , v2 } from "@datadog/datadog-api-client" ;
const configuration = client . createConfiguration ();
configuration . unstableOperations [ "v2.createLLMObsProject" ] = true ;
const apiInstance = new v2 . LLMObservabilityApi ( configuration );
const params : v2.LLMObservabilityApiCreateLLMObsProjectRequest = {
body : {
data : {
attributes : {
name : "My LLM Project" ,
},
type : "projects" ,
},
},
};
apiInstance
. createLLMObsProject ( params )
. then (( data : v2.LLMObsProjectResponse ) => {
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"