List functions
List out all functions. The functions are sorted by creation date, with the most recently-created functions coming first
Authorization
AuthorizationMost Braintrust endpoints are authenticated by providing your API key as a header Authorization: Bearer [api_key] to your HTTP request. You can create an API key in the Braintrust organization settings page.
In: header
Query Parameters
limitintegerLimit the number of objects to return
0starting_afterstringPagination cursor id.
For example, if the final item in the last page you fetched had an id of foo, pass starting_after=foo to fetch the next page. Note: you may only pass one of starting_after and ending_before
"uuid"ending_beforestringPagination cursor id.
For example, if the initial item in the last page you fetched had an id of foo, pass ending_before=foo to fetch the previous page. Note: you may only pass one of starting_after and ending_before
"uuid"idsAny properties in string, array<string>Filter search results to a particular set of object IDs. To specify a list of IDs, include the query param multiple times
function_namestringName of the function to search for
project_namestringName of the project to search for
project_idstringProject id
"uuid"slugstringRetrieve prompt with a specific slug
versionstringRetrieve prompt at a specific version.
The version id can either be a transaction id (e.g. '1000192656880881099') or a version identifier (e.g. '81cd05ee665fdfb3').
org_namestringFilter search results to within a particular organization
Returns a list of function objects
Create function
Create a new function. If there is an existing function in the project with the same slug as the one specified in the request, will return the existing function unmodified
Authorization
AuthorizationMost Braintrust endpoints are authenticated by providing your API key as a header Authorization: Bearer [api_key] to your HTTP request. You can create an API key in the Braintrust organization settings page.
In: header
Request Body
application/jsonOptionalAny desired information about the new function object
project_idUnique identifier for the project that the prompt belongs under
"uuid"nameName of the prompt
1slugUnique identifier for the prompt
1descriptionstringTextual description of the prompt
prompt_dataobjectThe prompt, model, and its parameters
tagsarray<string>A list of tags for the prompt
function_typestring"llm" | "scorer" | "task" | "tool" | nullfunction_dataoriginobjectfunction_schemaobjectJSON schema for the function's parameters and return type
Returns the new function object
Create or replace function
Create or replace function. If there is an existing function in the project with the same slug as the one specified in the request, will replace the existing function with the provided fields
Authorization
AuthorizationMost Braintrust endpoints are authenticated by providing your API key as a header Authorization: Bearer [api_key] to your HTTP request. You can create an API key in the Braintrust organization settings page.
In: header
Request Body
application/jsonOptionalAny desired information about the new function object
project_idUnique identifier for the project that the prompt belongs under
"uuid"nameName of the prompt
1slugUnique identifier for the prompt
1descriptionstringTextual description of the prompt
prompt_dataobjectThe prompt, model, and its parameters
tagsarray<string>A list of tags for the prompt
function_typestring"llm" | "scorer" | "task" | "tool" | nullfunction_dataoriginobjectfunction_schemaobjectJSON schema for the function's parameters and return type
Returns the new function object
Get function
Get a function object by its id
Authorization
AuthorizationMost Braintrust endpoints are authenticated by providing your API key as a header Authorization: Bearer [api_key] to your HTTP request. You can create an API key in the Braintrust organization settings page.
In: header
Path Parameters
function_idFunction id
"uuid"Query Parameters
versionstringRetrieve prompt at a specific version.
The version id can either be a transaction id (e.g. '1000192656880881099') or a version identifier (e.g. '81cd05ee665fdfb3').
Returns the function object
Partially update function
Partially update a function object. Specify the fields to update in the payload. Any object-type fields will be deep-merged with existing content. Currently we do not support removing fields or setting them to null.
Authorization
AuthorizationMost Braintrust endpoints are authenticated by providing your API key as a header Authorization: Bearer [api_key] to your HTTP request. You can create an API key in the Braintrust organization settings page.
In: header
Request Body
application/jsonOptionalFields to update
namestringName of the prompt
descriptionstringTextual description of the prompt
prompt_dataobjectThe prompt, model, and its parameters
function_dataAny properties in prompt, code, globaltagsarray<string>A list of tags for the prompt
Path Parameters
function_idFunction id
"uuid"Returns the function object
Delete function
Delete a function object by its id
Authorization
AuthorizationMost Braintrust endpoints are authenticated by providing your API key as a header Authorization: Bearer [api_key] to your HTTP request. You can create an API key in the Braintrust organization settings page.
In: header
Path Parameters
function_idFunction id
"uuid"Returns the deleted function object
Invoke function
Invoke a function.
Authorization
AuthorizationMost Braintrust endpoints are authenticated by providing your API key as a header Authorization: Bearer [api_key] to your HTTP request. You can create an API key in the Braintrust organization settings page.
In: header
Request Body
application/jsonOptionalFunction invocation parameters
inputunknownArgument to the function, which can be any JSON serializable value
expectedunknownThe expected output of the function
metadataobjectAny relevant metadata
messagesarray<Any properties in system, user, assistant, tool, function, fallback>If the function is an LLM, additional messages to pass along to it
parentAny properties in span_parent_struct, stringOptions for tracing the function call
streambooleanWhether to stream the response. If true, results will be returned in the Braintrust SSE format.
modestringThe mode format of the returned value (defaults to 'auto')
"auto" | "parallel" | nullversionstringThe version of the function
Path Parameters
function_idFunction id
"uuid"Function invocation response