Beta
ChatKit
Domain Types
ChatKit Workflow
-
class ChatKitWorkflow:Workflow metadata and state returned for the session.
-
String idIdentifier of the workflow backing the session.
-
Optional<StateVariables> stateVariablesState variable key-value pairs applied when invoking the workflow. Defaults to null when no overrides were provided.
-
String -
boolean -
double
-
-
Tracing tracingTracing settings applied to the workflow.
-
boolean enabledIndicates whether tracing is enabled.
-
-
Optional<String> versionSpecific workflow version used for the session. Defaults to null when using the latest deployment.
-
Sessions
Cancel chat session
ChatSession beta().chatkit().sessions().cancel(SessionCancelParamsparams = SessionCancelParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
post /chatkit/sessions/{session_id}/cancel
Cancel an active ChatKit session and return its most recent metadata.
Cancelling prevents new requests from using the issued client secret.
Parameters
-
SessionCancelParams paramsOptional<String> sessionId
Returns
-
class ChatSession:Represents a ChatKit session and its resolved configuration.
-
String idIdentifier for the ChatKit session.
-
ChatSessionChatKitConfiguration chatkitConfigurationResolved ChatKit feature configuration for the session.
-
ChatSessionAutomaticThreadTitling automaticThreadTitlingAutomatic thread titling preferences.
-
boolean enabledWhether automatic thread titling is enabled.
-
-
ChatSessionFileUpload fileUploadUpload settings for the session.
-
boolean enabledIndicates if uploads are enabled for the session.
-
Optional<Long> maxFileSizeMaximum upload size in megabytes.
-
Optional<Long> maxFilesMaximum number of uploads allowed during the session.
-
-
ChatSessionHistory historyHistory retention configuration.
-
boolean enabledIndicates if chat history is persisted for the session.
-
Optional<Long> recentThreadsNumber of prior threads surfaced in history views. Defaults to null when all history is retained.
-
-
-
String clientSecretEphemeral client secret that authenticates session requests.
-
long expiresAtUnix timestamp (in seconds) for when the session expires.
-
long maxRequestsPer1MinuteConvenience copy of the per-minute request limit.
-
JsonValue; object_ "chatkit.session"constantType discriminator that is always
chatkit.session.CHATKIT_SESSION("chatkit.session")
-
ChatSessionRateLimits rateLimitsResolved rate limit values.
-
long maxRequestsPer1MinuteMaximum allowed requests per one-minute window.
-
-
ChatSessionStatus statusCurrent lifecycle state of the session.
-
ACTIVE("active") -
EXPIRED("expired") -
CANCELLED("cancelled")
-
-
String userUser identifier associated with the session.
-
ChatKitWorkflow workflowWorkflow metadata for the session.
-
String idIdentifier of the workflow backing the session.
-
Optional<StateVariables> stateVariablesState variable key-value pairs applied when invoking the workflow. Defaults to null when no overrides were provided.
-
String -
boolean -
double
-
-
Tracing tracingTracing settings applied to the workflow.
-
boolean enabledIndicates whether tracing is enabled.
-
-
Optional<String> versionSpecific workflow version used for the session. Defaults to null when using the latest deployment.
-
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.sessions.SessionCancelParams;
import com.openai.models.beta.chatkit.threads.ChatSession;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ChatSession chatSession = client.beta().chatkit().sessions().cancel("cksess_123");
}
}
Response
{
"id": "id",
"chatkit_configuration": {
"automatic_thread_titling": {
"enabled": true
},
"file_upload": {
"enabled": true,
"max_file_size": 0,
"max_files": 0
},
"history": {
"enabled": true,
"recent_threads": 0
}
},
"client_secret": "client_secret",
"expires_at": 0,
"max_requests_per_1_minute": 0,
"object": "chatkit.session",
"rate_limits": {
"max_requests_per_1_minute": 0
},
"status": "active",
"user": "user",
"workflow": {
"id": "id",
"state_variables": {
"foo": "string"
},
"tracing": {
"enabled": true
},
"version": "version"
}
}
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.sessions.SessionCancelParams;
import com.openai.models.beta.chatkit.threads.ChatSession;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ChatSession chatSession = client.beta().chatkit().sessions().cancel("cksess_123");
}
}
Response
{
"id": "cksess_123",
"object": "chatkit.session",
"workflow": {
"id": "workflow_alpha",
"version": "1"
},
"scope": {
"customer_id": "cust_456"
},
"max_requests_per_1_minute": 30,
"ttl_seconds": 900,
"status": "cancelled",
"cancelled_at": 1712345678
}
Create ChatKit session
ChatSession beta().chatkit().sessions().create(SessionCreateParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
post /chatkit/sessions
Create a ChatKit session.
Parameters
-
SessionCreateParams params-
String userA free-form string that identifies your end user; ensures this Session can access other objects that have the same
userscope. -
ChatSessionWorkflowParam workflowWorkflow that powers the session.
-
Optional<ChatSessionChatKitConfigurationParam> chatkitConfigurationOptional overrides for ChatKit runtime configuration features
-
Optional<ChatSessionExpiresAfterParam> expiresAfterOptional override for session expiration timing in seconds from creation. Defaults to 10 minutes.
-
Optional<ChatSessionRateLimitsParam> rateLimitsOptional override for per-minute request limits. When omitted, defaults to 10.
-
Returns
-
class ChatSession:Represents a ChatKit session and its resolved configuration.
-
String idIdentifier for the ChatKit session.
-
ChatSessionChatKitConfiguration chatkitConfigurationResolved ChatKit feature configuration for the session.
-
ChatSessionAutomaticThreadTitling automaticThreadTitlingAutomatic thread titling preferences.
-
boolean enabledWhether automatic thread titling is enabled.
-
-
ChatSessionFileUpload fileUploadUpload settings for the session.
-
boolean enabledIndicates if uploads are enabled for the session.
-
Optional<Long> maxFileSizeMaximum upload size in megabytes.
-
Optional<Long> maxFilesMaximum number of uploads allowed during the session.
-
-
ChatSessionHistory historyHistory retention configuration.
-
boolean enabledIndicates if chat history is persisted for the session.
-
Optional<Long> recentThreadsNumber of prior threads surfaced in history views. Defaults to null when all history is retained.
-
-
-
String clientSecretEphemeral client secret that authenticates session requests.
-
long expiresAtUnix timestamp (in seconds) for when the session expires.
-
long maxRequestsPer1MinuteConvenience copy of the per-minute request limit.
-
JsonValue; object_ "chatkit.session"constantType discriminator that is always
chatkit.session.CHATKIT_SESSION("chatkit.session")
-
ChatSessionRateLimits rateLimitsResolved rate limit values.
-
long maxRequestsPer1MinuteMaximum allowed requests per one-minute window.
-
-
ChatSessionStatus statusCurrent lifecycle state of the session.
-
ACTIVE("active") -
EXPIRED("expired") -
CANCELLED("cancelled")
-
-
String userUser identifier associated with the session.
-
ChatKitWorkflow workflowWorkflow metadata for the session.
-
String idIdentifier of the workflow backing the session.
-
Optional<StateVariables> stateVariablesState variable key-value pairs applied when invoking the workflow. Defaults to null when no overrides were provided.
-
String -
boolean -
double
-
-
Tracing tracingTracing settings applied to the workflow.
-
boolean enabledIndicates whether tracing is enabled.
-
-
Optional<String> versionSpecific workflow version used for the session. Defaults to null when using the latest deployment.
-
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.sessions.SessionCreateParams;
import com.openai.models.beta.chatkit.threads.ChatSession;
import com.openai.models.beta.chatkit.threads.ChatSessionWorkflowParam;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
SessionCreateParams params = SessionCreateParams.builder()
.user("x")
.workflow(ChatSessionWorkflowParam.builder()
.id("id")
.build())
.build();
ChatSession chatSession = client.beta().chatkit().sessions().create(params);
}
}
Response
{
"id": "id",
"chatkit_configuration": {
"automatic_thread_titling": {
"enabled": true
},
"file_upload": {
"enabled": true,
"max_file_size": 0,
"max_files": 0
},
"history": {
"enabled": true,
"recent_threads": 0
}
},
"client_secret": "client_secret",
"expires_at": 0,
"max_requests_per_1_minute": 0,
"object": "chatkit.session",
"rate_limits": {
"max_requests_per_1_minute": 0
},
"status": "active",
"user": "user",
"workflow": {
"id": "id",
"state_variables": {
"foo": "string"
},
"tracing": {
"enabled": true
},
"version": "version"
}
}
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.sessions.SessionCreateParams;
import com.openai.models.beta.chatkit.threads.ChatSession;
import com.openai.models.beta.chatkit.threads.ChatSessionWorkflowParam;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
SessionCreateParams params = SessionCreateParams.builder()
.user("user")
.workflow(ChatSessionWorkflowParam.builder()
.id("id")
.build())
.build();
ChatSession chatSession = client.beta().chatkit().sessions().create(params);
}
}
Response
{
"client_secret": "chatkit_token_123",
"expires_at": 1735689600,
"workflow": {
"id": "workflow_alpha",
"version": "2024-10-01"
},
"scope": {
"project": "alpha",
"environment": "staging"
},
"max_requests_per_1_minute": 60,
"max_requests_per_session": 500,
"status": "active"
}
Threads
List ChatKit thread items
ThreadListItemsPage beta().chatkit().threads().listItems(ThreadListItemsParamsparams = ThreadListItemsParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
get /chatkit/threads/{thread_id}/items
List items that belong to a ChatKit thread.
Parameters
-
ThreadListItemsParams params-
Optional<String> threadId -
Optional<String> afterList items created after this thread item ID. Defaults to null for the first page.
-
Optional<String> beforeList items created before this thread item ID. Defaults to null for the newest results.
-
Optional<Long> limitMaximum number of thread items to return. Defaults to 20.
-
Optional<Order> orderSort order for results by creation time. Defaults to
desc.-
ASC("asc") -
DESC("desc")
-
-
Returns
-
class Data: A class that can be one of several variants.unionUser-authored messages within a thread.
-
class ChatKitThreadUserMessageItem:User-authored messages within a thread.
-
String idIdentifier of the thread item.
-
List<ChatKitAttachment> attachmentsAttachments associated with the user message. Defaults to an empty list.
-
String idIdentifier for the attachment.
-
String mimeTypeMIME type of the attachment.
-
String nameOriginal display name for the attachment.
-
Optional<String> previewUrlPreview URL for rendering the attachment inline.
-
Type typeAttachment discriminator.
-
IMAGE("image") -
FILE("file")
-
-
-
List<Content> contentOrdered content elements supplied by the user.
-
class InputText:Text block that a user contributed to the thread.
-
String textPlain-text content supplied by the user.
-
JsonValue; type "input_text"constantType discriminator that is always
input_text.INPUT_TEXT("input_text")
-
-
class QuotedText:Quoted snippet that the user referenced in their message.
-
String textQuoted text content.
-
JsonValue; type "quoted_text"constantType discriminator that is always
quoted_text.QUOTED_TEXT("quoted_text")
-
-
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
Optional<InferenceOptions> inferenceOptionsInference overrides applied to the message. Defaults to null when unset.
-
Optional<String> modelModel name that generated the response. Defaults to null when using the session default.
-
Optional<ToolChoice> toolChoicePreferred tool to invoke. Defaults to null when ChatKit should auto-select.
-
String idIdentifier of the requested tool.
-
-
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.user_message"constantCHATKIT_USER_MESSAGE("chatkit.user_message")
-
-
class ChatKitThreadAssistantMessageItem:Assistant-authored message within a thread.
-
String idIdentifier of the thread item.
-
List<ChatKitResponseOutputText> contentOrdered assistant response segments.
-
List<Annotation> annotationsOrdered list of annotations attached to the response text.
-
class File:Annotation that references an uploaded file.
-
Source sourceFile attachment referenced by the annotation.
-
String filenameFilename referenced by the annotation.
-
JsonValue; type "file"constantType discriminator that is always
file.FILE("file")
-
-
JsonValue; type "file"constantType discriminator that is always
filefor this annotation.FILE("file")
-
-
class Url:Annotation that references a URL.
-
Source sourceURL referenced by the annotation.
-
JsonValue; type "url"constantType discriminator that is always
url.URL("url")
-
String urlURL referenced by the annotation.
-
-
JsonValue; type "url"constantType discriminator that is always
urlfor this annotation.URL("url")
-
-
-
String textAssistant generated text.
-
JsonValue; type "output_text"constantType discriminator that is always
output_text.OUTPUT_TEXT("output_text")
-
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.assistant_message"constantType discriminator that is always
chatkit.assistant_message.CHATKIT_ASSISTANT_MESSAGE("chatkit.assistant_message")
-
-
class ChatKitWidgetItem:Thread item that renders a widget payload.
-
String idIdentifier of the thread item.
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.widget"constantType discriminator that is always
chatkit.widget.CHATKIT_WIDGET("chatkit.widget")
-
String widgetSerialized widget payload rendered in the UI.
-
-
class ChatKitClientToolCall:Record of a client side tool invocation initiated by the assistant.
-
String idIdentifier of the thread item.
-
String argumentsJSON-encoded arguments that were sent to the tool.
-
String callIdIdentifier for the client tool call.
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
String nameTool name that was invoked.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
Optional<String> outputJSON-encoded output captured from the tool. Defaults to null while execution is in progress.
-
Status statusExecution status for the tool call.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed")
-
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.client_tool_call"constantType discriminator that is always
chatkit.client_tool_call.CHATKIT_CLIENT_TOOL_CALL("chatkit.client_tool_call")
-
-
class ChatKitTask:Task emitted by the workflow to show progress and status updates.
-
String idIdentifier of the thread item.
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
Optional<String> headingOptional heading for the task. Defaults to null when not provided.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
Optional<String> summaryOptional summary that describes the task. Defaults to null when omitted.
-
TaskType taskTypeSubtype for the task.
-
CUSTOM("custom") -
THOUGHT("thought")
-
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.task"constantType discriminator that is always
chatkit.task.CHATKIT_TASK("chatkit.task")
-
-
class ChatKitTaskGroup:Collection of workflow tasks grouped together in the thread.
-
String idIdentifier of the thread item.
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
List<Task> tasksTasks included in the group.
-
Optional<String> headingOptional heading for the grouped task. Defaults to null when not provided.
-
Optional<String> summaryOptional summary that describes the grouped task. Defaults to null when omitted.
-
Type typeSubtype for the grouped task.
-
CUSTOM("custom") -
THOUGHT("thought")
-
-
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.task_group"constantType discriminator that is always
chatkit.task_group.CHATKIT_TASK_GROUP("chatkit.task_group")
-
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.threads.ThreadListItemsPage;
import com.openai.models.beta.chatkit.threads.ThreadListItemsParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ThreadListItemsPage page = client.beta().chatkit().threads().listItems("cthr_123");
}
}
Response
{
"data": [
{
"id": "id",
"attachments": [
{
"id": "id",
"mime_type": "mime_type",
"name": "name",
"preview_url": "https://example.com",
"type": "image"
}
],
"content": [
{
"text": "text",
"type": "input_text"
}
],
"created_at": 0,
"inference_options": {
"model": "model",
"tool_choice": {
"id": "id"
}
},
"object": "chatkit.thread_item",
"thread_id": "thread_id",
"type": "chatkit.user_message"
}
],
"first_id": "first_id",
"has_more": true,
"last_id": "last_id",
"object": "list"
}
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.threads.ThreadListItemsPage;
import com.openai.models.beta.chatkit.threads.ThreadListItemsParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ThreadListItemsPage page = client.beta().chatkit().threads().listItems("cthr_123");
}
}
Response
{
"data": [
{
"id": "cthi_user_001",
"object": "chatkit.thread_item",
"type": "user_message",
"content": [
{
"type": "input_text",
"text": "I need help debugging an onboarding issue."
}
],
"attachments": []
},
{
"id": "cthi_assistant_002",
"object": "chatkit.thread_item",
"type": "assistant_message",
"content": [
{
"type": "output_text",
"text": "Let's start by confirming the workflow version you deployed."
}
]
}
],
"has_more": false,
"object": "list"
}
Retrieve ChatKit thread
ChatKitThread beta().chatkit().threads().retrieve(ThreadRetrieveParamsparams = ThreadRetrieveParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
get /chatkit/threads/{thread_id}
Retrieve a ChatKit thread by its identifier.
Parameters
-
ThreadRetrieveParams paramsOptional<String> threadId
Returns
-
class ChatKitThread:Represents a ChatKit thread and its current status.
-
String idIdentifier of the thread.
-
long createdAtUnix timestamp (in seconds) for when the thread was created.
-
JsonValue; object_ "chatkit.thread"constantType discriminator that is always
chatkit.thread.CHATKIT_THREAD("chatkit.thread")
-
Status statusCurrent status for the thread. Defaults to
activefor newly created threads.-
JsonValue;-
JsonValue; type "active"constantStatus discriminator that is always
active.ACTIVE("active")
-
-
class Locked:Indicates that a thread is locked and cannot accept new input.
-
Optional<String> reasonReason that the thread was locked. Defaults to null when no reason is recorded.
-
JsonValue; type "locked"constantStatus discriminator that is always
locked.LOCKED("locked")
-
-
class Closed:Indicates that a thread has been closed.
-
Optional<String> reasonReason that the thread was closed. Defaults to null when no reason is recorded.
-
JsonValue; type "closed"constantStatus discriminator that is always
closed.CLOSED("closed")
-
-
-
Optional<String> titleOptional human-readable title for the thread. Defaults to null when no title has been generated.
-
String userFree-form string that identifies your end user who owns the thread.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.threads.ChatKitThread;
import com.openai.models.beta.chatkit.threads.ThreadRetrieveParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ChatKitThread chatkitThread = client.beta().chatkit().threads().retrieve("cthr_123");
}
}
Response
{
"id": "cthr_def456",
"created_at": 1712345600,
"object": "chatkit.thread",
"status": {
"type": "active"
},
"title": "Demo feedback",
"user": "user_456"
}
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.threads.ChatKitThread;
import com.openai.models.beta.chatkit.threads.ThreadRetrieveParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ChatKitThread chatkitThread = client.beta().chatkit().threads().retrieve("cthr_123");
}
}
Response
{
"id": "cthr_abc123",
"object": "chatkit.thread",
"title": "Customer escalation",
"items": {
"data": [
{
"id": "cthi_user_001",
"object": "chatkit.thread_item",
"type": "user_message",
"content": [
{
"type": "input_text",
"text": "I need help debugging an onboarding issue."
}
],
"attachments": []
},
{
"id": "cthi_assistant_002",
"object": "chatkit.thread_item",
"type": "assistant_message",
"content": [
{
"type": "output_text",
"text": "Let's start by confirming the workflow version you deployed."
}
]
}
],
"has_more": false
}
}
Delete ChatKit thread
ThreadDeleteResponse beta().chatkit().threads().delete(ThreadDeleteParamsparams = ThreadDeleteParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
delete /chatkit/threads/{thread_id}
Delete a ChatKit thread along with its items and stored attachments.
Parameters
-
ThreadDeleteParams paramsOptional<String> threadId
Returns
-
class ThreadDeleteResponse:Confirmation payload returned after deleting a thread.
-
String idIdentifier of the deleted thread.
-
boolean deletedIndicates that the thread has been deleted.
-
JsonValue; object_ "chatkit.thread.deleted"constantType discriminator that is always
chatkit.thread.deleted.CHATKIT_THREAD_DELETED("chatkit.thread.deleted")
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.threads.ThreadDeleteParams;
import com.openai.models.beta.chatkit.threads.ThreadDeleteResponse;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ThreadDeleteResponse thread = client.beta().chatkit().threads().delete("cthr_123");
}
}
Response
{
"id": "id",
"deleted": true,
"object": "chatkit.thread.deleted"
}
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chat_kit.threads.ThreadDeleteParams;
import com.openai.models.beta.chat_kit.threads.ThreadDeleteResponse;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ThreadDeleteResponse thread = client.beta().chat_kit().threads().delete("cthr_123");
}
}
List ChatKit threads
ThreadListPage beta().chatkit().threads().list(ThreadListParamsparams = ThreadListParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
get /chatkit/threads
List ChatKit threads with optional pagination and user filters.
Parameters
-
ThreadListParams params-
Optional<String> afterList items created after this thread item ID. Defaults to null for the first page.
-
Optional<String> beforeList items created before this thread item ID. Defaults to null for the newest results.
-
Optional<Long> limitMaximum number of thread items to return. Defaults to 20.
-
Optional<Order> orderSort order for results by creation time. Defaults to
desc.-
ASC("asc") -
DESC("desc")
-
-
Optional<String> userFilter threads that belong to this user identifier. Defaults to null to return all users.
-
Returns
-
class ChatKitThread:Represents a ChatKit thread and its current status.
-
String idIdentifier of the thread.
-
long createdAtUnix timestamp (in seconds) for when the thread was created.
-
JsonValue; object_ "chatkit.thread"constantType discriminator that is always
chatkit.thread.CHATKIT_THREAD("chatkit.thread")
-
Status statusCurrent status for the thread. Defaults to
activefor newly created threads.-
JsonValue;-
JsonValue; type "active"constantStatus discriminator that is always
active.ACTIVE("active")
-
-
class Locked:Indicates that a thread is locked and cannot accept new input.
-
Optional<String> reasonReason that the thread was locked. Defaults to null when no reason is recorded.
-
JsonValue; type "locked"constantStatus discriminator that is always
locked.LOCKED("locked")
-
-
class Closed:Indicates that a thread has been closed.
-
Optional<String> reasonReason that the thread was closed. Defaults to null when no reason is recorded.
-
JsonValue; type "closed"constantStatus discriminator that is always
closed.CLOSED("closed")
-
-
-
Optional<String> titleOptional human-readable title for the thread. Defaults to null when no title has been generated.
-
String userFree-form string that identifies your end user who owns the thread.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.threads.ThreadListPage;
import com.openai.models.beta.chatkit.threads.ThreadListParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ThreadListPage page = client.beta().chatkit().threads().list();
}
}
Response
{
"data": [
{
"id": "cthr_def456",
"created_at": 1712345600,
"object": "chatkit.thread",
"status": {
"type": "active"
},
"title": "Demo feedback",
"user": "user_456"
}
],
"first_id": "first_id",
"has_more": true,
"last_id": "last_id",
"object": "list"
}
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.chatkit.threads.ThreadListPage;
import com.openai.models.beta.chatkit.threads.ThreadListParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ThreadListPage page = client.beta().chatkit().threads().list();
}
}
Response
{
"data": [
{
"id": "cthr_abc123",
"object": "chatkit.thread",
"title": "Customer escalation"
},
{
"id": "cthr_def456",
"object": "chatkit.thread",
"title": "Demo feedback"
}
],
"has_more": false,
"object": "list"
}
Domain Types
Chat Session
-
class ChatSession:Represents a ChatKit session and its resolved configuration.
-
String idIdentifier for the ChatKit session.
-
ChatSessionChatKitConfiguration chatkitConfigurationResolved ChatKit feature configuration for the session.
-
ChatSessionAutomaticThreadTitling automaticThreadTitlingAutomatic thread titling preferences.
-
boolean enabledWhether automatic thread titling is enabled.
-
-
ChatSessionFileUpload fileUploadUpload settings for the session.
-
boolean enabledIndicates if uploads are enabled for the session.
-
Optional<Long> maxFileSizeMaximum upload size in megabytes.
-
Optional<Long> maxFilesMaximum number of uploads allowed during the session.
-
-
ChatSessionHistory historyHistory retention configuration.
-
boolean enabledIndicates if chat history is persisted for the session.
-
Optional<Long> recentThreadsNumber of prior threads surfaced in history views. Defaults to null when all history is retained.
-
-
-
String clientSecretEphemeral client secret that authenticates session requests.
-
long expiresAtUnix timestamp (in seconds) for when the session expires.
-
long maxRequestsPer1MinuteConvenience copy of the per-minute request limit.
-
JsonValue; object_ "chatkit.session"constantType discriminator that is always
chatkit.session.CHATKIT_SESSION("chatkit.session")
-
ChatSessionRateLimits rateLimitsResolved rate limit values.
-
long maxRequestsPer1MinuteMaximum allowed requests per one-minute window.
-
-
ChatSessionStatus statusCurrent lifecycle state of the session.
-
ACTIVE("active") -
EXPIRED("expired") -
CANCELLED("cancelled")
-
-
String userUser identifier associated with the session.
-
ChatKitWorkflow workflowWorkflow metadata for the session.
-
String idIdentifier of the workflow backing the session.
-
Optional<StateVariables> stateVariablesState variable key-value pairs applied when invoking the workflow. Defaults to null when no overrides were provided.
-
String -
boolean -
double
-
-
Tracing tracingTracing settings applied to the workflow.
-
boolean enabledIndicates whether tracing is enabled.
-
-
Optional<String> versionSpecific workflow version used for the session. Defaults to null when using the latest deployment.
-
-
Chat Session Automatic Thread Titling
-
class ChatSessionAutomaticThreadTitling:Automatic thread title preferences for the session.
-
boolean enabledWhether automatic thread titling is enabled.
-
Chat Session ChatKit Configuration
-
class ChatSessionChatKitConfiguration:ChatKit configuration for the session.
-
ChatSessionAutomaticThreadTitling automaticThreadTitlingAutomatic thread titling preferences.
-
boolean enabledWhether automatic thread titling is enabled.
-
-
ChatSessionFileUpload fileUploadUpload settings for the session.
-
boolean enabledIndicates if uploads are enabled for the session.
-
Optional<Long> maxFileSizeMaximum upload size in megabytes.
-
Optional<Long> maxFilesMaximum number of uploads allowed during the session.
-
-
ChatSessionHistory historyHistory retention configuration.
-
boolean enabledIndicates if chat history is persisted for the session.
-
Optional<Long> recentThreadsNumber of prior threads surfaced in history views. Defaults to null when all history is retained.
-
-
Chat Session ChatKit Configuration Param
-
class ChatSessionChatKitConfigurationParam:Optional per-session configuration settings for ChatKit behavior.
-
Optional<AutomaticThreadTitling> automaticThreadTitlingConfiguration for automatic thread titling. When omitted, automatic thread titling is enabled by default.
-
Optional<Boolean> enabledEnable automatic thread title generation. Defaults to true.
-
-
Optional<FileUpload> fileUploadConfiguration for upload enablement and limits. When omitted, uploads are disabled by default (max_files 10, max_file_size 512 MB).
-
Optional<Boolean> enabledEnable uploads for this session. Defaults to false.
-
Optional<Long> maxFileSizeMaximum size in megabytes for each uploaded file. Defaults to 512 MB, which is the maximum allowable size.
-
Optional<Long> maxFilesMaximum number of files that can be uploaded to the session. Defaults to 10.
-
-
Optional<History> historyConfiguration for chat history retention. When omitted, history is enabled by default with no limit on recent_threads (null).
-
Optional<Boolean> enabledEnables chat users to access previous ChatKit threads. Defaults to true.
-
Optional<Long> recentThreadsNumber of recent ChatKit threads users have access to. Defaults to unlimited when unset.
-
-
Chat Session Expires After Param
-
class ChatSessionExpiresAfterParam:Controls when the session expires relative to an anchor timestamp.
-
JsonValue; anchor "created_at"constantBase timestamp used to calculate expiration. Currently fixed to
created_at.CREATED_AT("created_at")
-
long secondsNumber of seconds after the anchor when the session expires.
-
Chat Session File Upload
-
class ChatSessionFileUpload:Upload permissions and limits applied to the session.
-
boolean enabledIndicates if uploads are enabled for the session.
-
Optional<Long> maxFileSizeMaximum upload size in megabytes.
-
Optional<Long> maxFilesMaximum number of uploads allowed during the session.
-
Chat Session History
-
class ChatSessionHistory:History retention preferences returned for the session.
-
boolean enabledIndicates if chat history is persisted for the session.
-
Optional<Long> recentThreadsNumber of prior threads surfaced in history views. Defaults to null when all history is retained.
-
Chat Session Rate Limits
-
class ChatSessionRateLimits:Active per-minute request limit for the session.
-
long maxRequestsPer1MinuteMaximum allowed requests per one-minute window.
-
Chat Session Rate Limits Param
-
class ChatSessionRateLimitsParam:Controls request rate limits for the session.
-
Optional<Long> maxRequestsPer1MinuteMaximum number of requests allowed per minute for the session. Defaults to 10.
-
Chat Session Status
-
enum ChatSessionStatus:-
ACTIVE("active") -
EXPIRED("expired") -
CANCELLED("cancelled")
-
Chat Session Workflow Param
-
class ChatSessionWorkflowParam:Workflow reference and overrides applied to the chat session.
-
String idIdentifier for the workflow invoked by the session.
-
Optional<StateVariables> stateVariablesState variables forwarded to the workflow. Keys may be up to 64 characters, values must be primitive types, and the map defaults to an empty object.
-
String -
boolean -
double
-
-
Optional<Tracing> tracingOptional tracing overrides for the workflow invocation. When omitted, tracing is enabled by default.
-
Optional<Boolean> enabledWhether tracing is enabled during the session. Defaults to true.
-
-
Optional<String> versionSpecific workflow version to run. Defaults to the latest deployed version.
-
ChatKit Attachment
-
class ChatKitAttachment:Attachment metadata included on thread items.
-
String idIdentifier for the attachment.
-
String mimeTypeMIME type of the attachment.
-
String nameOriginal display name for the attachment.
-
Optional<String> previewUrlPreview URL for rendering the attachment inline.
-
Type typeAttachment discriminator.
-
IMAGE("image") -
FILE("file")
-
-
ChatKit Response Output Text
-
class ChatKitResponseOutputText:Assistant response text accompanied by optional annotations.
-
List<Annotation> annotationsOrdered list of annotations attached to the response text.
-
class File:Annotation that references an uploaded file.
-
Source sourceFile attachment referenced by the annotation.
-
String filenameFilename referenced by the annotation.
-
JsonValue; type "file"constantType discriminator that is always
file.FILE("file")
-
-
JsonValue; type "file"constantType discriminator that is always
filefor this annotation.FILE("file")
-
-
class Url:Annotation that references a URL.
-
Source sourceURL referenced by the annotation.
-
JsonValue; type "url"constantType discriminator that is always
url.URL("url")
-
String urlURL referenced by the annotation.
-
-
JsonValue; type "url"constantType discriminator that is always
urlfor this annotation.URL("url")
-
-
-
String textAssistant generated text.
-
JsonValue; type "output_text"constantType discriminator that is always
output_text.OUTPUT_TEXT("output_text")
-
ChatKit Thread
-
class ChatKitThread:Represents a ChatKit thread and its current status.
-
String idIdentifier of the thread.
-
long createdAtUnix timestamp (in seconds) for when the thread was created.
-
JsonValue; object_ "chatkit.thread"constantType discriminator that is always
chatkit.thread.CHATKIT_THREAD("chatkit.thread")
-
Status statusCurrent status for the thread. Defaults to
activefor newly created threads.-
JsonValue;-
JsonValue; type "active"constantStatus discriminator that is always
active.ACTIVE("active")
-
-
class Locked:Indicates that a thread is locked and cannot accept new input.
-
Optional<String> reasonReason that the thread was locked. Defaults to null when no reason is recorded.
-
JsonValue; type "locked"constantStatus discriminator that is always
locked.LOCKED("locked")
-
-
class Closed:Indicates that a thread has been closed.
-
Optional<String> reasonReason that the thread was closed. Defaults to null when no reason is recorded.
-
JsonValue; type "closed"constantStatus discriminator that is always
closed.CLOSED("closed")
-
-
-
Optional<String> titleOptional human-readable title for the thread. Defaults to null when no title has been generated.
-
String userFree-form string that identifies your end user who owns the thread.
-
ChatKit Thread Assistant Message Item
-
class ChatKitThreadAssistantMessageItem:Assistant-authored message within a thread.
-
String idIdentifier of the thread item.
-
List<ChatKitResponseOutputText> contentOrdered assistant response segments.
-
List<Annotation> annotationsOrdered list of annotations attached to the response text.
-
class File:Annotation that references an uploaded file.
-
Source sourceFile attachment referenced by the annotation.
-
String filenameFilename referenced by the annotation.
-
JsonValue; type "file"constantType discriminator that is always
file.FILE("file")
-
-
JsonValue; type "file"constantType discriminator that is always
filefor this annotation.FILE("file")
-
-
class Url:Annotation that references a URL.
-
Source sourceURL referenced by the annotation.
-
JsonValue; type "url"constantType discriminator that is always
url.URL("url")
-
String urlURL referenced by the annotation.
-
-
JsonValue; type "url"constantType discriminator that is always
urlfor this annotation.URL("url")
-
-
-
String textAssistant generated text.
-
JsonValue; type "output_text"constantType discriminator that is always
output_text.OUTPUT_TEXT("output_text")
-
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.assistant_message"constantType discriminator that is always
chatkit.assistant_message.CHATKIT_ASSISTANT_MESSAGE("chatkit.assistant_message")
-
ChatKit Thread Item List
-
class ChatKitThreadItemList:A paginated list of thread items rendered for the ChatKit API.
-
List<Data> dataA list of items
-
class ChatKitThreadUserMessageItem:User-authored messages within a thread.
-
String idIdentifier of the thread item.
-
List<ChatKitAttachment> attachmentsAttachments associated with the user message. Defaults to an empty list.
-
String idIdentifier for the attachment.
-
String mimeTypeMIME type of the attachment.
-
String nameOriginal display name for the attachment.
-
Optional<String> previewUrlPreview URL for rendering the attachment inline.
-
Type typeAttachment discriminator.
-
IMAGE("image") -
FILE("file")
-
-
-
List<Content> contentOrdered content elements supplied by the user.
-
class InputText:Text block that a user contributed to the thread.
-
String textPlain-text content supplied by the user.
-
JsonValue; type "input_text"constantType discriminator that is always
input_text.INPUT_TEXT("input_text")
-
-
class QuotedText:Quoted snippet that the user referenced in their message.
-
String textQuoted text content.
-
JsonValue; type "quoted_text"constantType discriminator that is always
quoted_text.QUOTED_TEXT("quoted_text")
-
-
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
Optional<InferenceOptions> inferenceOptionsInference overrides applied to the message. Defaults to null when unset.
-
Optional<String> modelModel name that generated the response. Defaults to null when using the session default.
-
Optional<ToolChoice> toolChoicePreferred tool to invoke. Defaults to null when ChatKit should auto-select.
-
String idIdentifier of the requested tool.
-
-
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.user_message"constantCHATKIT_USER_MESSAGE("chatkit.user_message")
-
-
class ChatKitThreadAssistantMessageItem:Assistant-authored message within a thread.
-
String idIdentifier of the thread item.
-
List<ChatKitResponseOutputText> contentOrdered assistant response segments.
-
List<Annotation> annotationsOrdered list of annotations attached to the response text.
-
class File:Annotation that references an uploaded file.
-
Source sourceFile attachment referenced by the annotation.
-
String filenameFilename referenced by the annotation.
-
JsonValue; type "file"constantType discriminator that is always
file.FILE("file")
-
-
JsonValue; type "file"constantType discriminator that is always
filefor this annotation.FILE("file")
-
-
class Url:Annotation that references a URL.
-
Source sourceURL referenced by the annotation.
-
JsonValue; type "url"constantType discriminator that is always
url.URL("url")
-
String urlURL referenced by the annotation.
-
-
JsonValue; type "url"constantType discriminator that is always
urlfor this annotation.URL("url")
-
-
-
String textAssistant generated text.
-
JsonValue; type "output_text"constantType discriminator that is always
output_text.OUTPUT_TEXT("output_text")
-
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.assistant_message"constantType discriminator that is always
chatkit.assistant_message.CHATKIT_ASSISTANT_MESSAGE("chatkit.assistant_message")
-
-
class ChatKitWidgetItem:Thread item that renders a widget payload.
-
String idIdentifier of the thread item.
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.widget"constantType discriminator that is always
chatkit.widget.CHATKIT_WIDGET("chatkit.widget")
-
String widgetSerialized widget payload rendered in the UI.
-
-
class ChatKitClientToolCall:Record of a client side tool invocation initiated by the assistant.
-
String idIdentifier of the thread item.
-
String argumentsJSON-encoded arguments that were sent to the tool.
-
String callIdIdentifier for the client tool call.
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
String nameTool name that was invoked.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
Optional<String> outputJSON-encoded output captured from the tool. Defaults to null while execution is in progress.
-
Status statusExecution status for the tool call.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed")
-
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.client_tool_call"constantType discriminator that is always
chatkit.client_tool_call.CHATKIT_CLIENT_TOOL_CALL("chatkit.client_tool_call")
-
-
class ChatKitTask:Task emitted by the workflow to show progress and status updates.
-
String idIdentifier of the thread item.
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
Optional<String> headingOptional heading for the task. Defaults to null when not provided.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
Optional<String> summaryOptional summary that describes the task. Defaults to null when omitted.
-
TaskType taskTypeSubtype for the task.
-
CUSTOM("custom") -
THOUGHT("thought")
-
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.task"constantType discriminator that is always
chatkit.task.CHATKIT_TASK("chatkit.task")
-
-
class ChatKitTaskGroup:Collection of workflow tasks grouped together in the thread.
-
String idIdentifier of the thread item.
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
List<Task> tasksTasks included in the group.
-
Optional<String> headingOptional heading for the grouped task. Defaults to null when not provided.
-
Optional<String> summaryOptional summary that describes the grouped task. Defaults to null when omitted.
-
Type typeSubtype for the grouped task.
-
CUSTOM("custom") -
THOUGHT("thought")
-
-
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.task_group"constantType discriminator that is always
chatkit.task_group.CHATKIT_TASK_GROUP("chatkit.task_group")
-
-
-
Optional<String> firstIdThe ID of the first item in the list.
-
boolean hasMoreWhether there are more items available.
-
Optional<String> lastIdThe ID of the last item in the list.
-
JsonValue; object_ "list"constantThe type of object returned, must be
list.LIST("list")
-
ChatKit Thread User Message Item
-
class ChatKitThreadUserMessageItem:User-authored messages within a thread.
-
String idIdentifier of the thread item.
-
List<ChatKitAttachment> attachmentsAttachments associated with the user message. Defaults to an empty list.
-
String idIdentifier for the attachment.
-
String mimeTypeMIME type of the attachment.
-
String nameOriginal display name for the attachment.
-
Optional<String> previewUrlPreview URL for rendering the attachment inline.
-
Type typeAttachment discriminator.
-
IMAGE("image") -
FILE("file")
-
-
-
List<Content> contentOrdered content elements supplied by the user.
-
class InputText:Text block that a user contributed to the thread.
-
String textPlain-text content supplied by the user.
-
JsonValue; type "input_text"constantType discriminator that is always
input_text.INPUT_TEXT("input_text")
-
-
class QuotedText:Quoted snippet that the user referenced in their message.
-
String textQuoted text content.
-
JsonValue; type "quoted_text"constantType discriminator that is always
quoted_text.QUOTED_TEXT("quoted_text")
-
-
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
Optional<InferenceOptions> inferenceOptionsInference overrides applied to the message. Defaults to null when unset.
-
Optional<String> modelModel name that generated the response. Defaults to null when using the session default.
-
Optional<ToolChoice> toolChoicePreferred tool to invoke. Defaults to null when ChatKit should auto-select.
-
String idIdentifier of the requested tool.
-
-
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.user_message"constantCHATKIT_USER_MESSAGE("chatkit.user_message")
-
ChatKit Widget Item
-
class ChatKitWidgetItem:Thread item that renders a widget payload.
-
String idIdentifier of the thread item.
-
long createdAtUnix timestamp (in seconds) for when the item was created.
-
JsonValue; object_ "chatkit.thread_item"constantType discriminator that is always
chatkit.thread_item.CHATKIT_THREAD_ITEM("chatkit.thread_item")
-
String threadIdIdentifier of the parent thread.
-
JsonValue; type "chatkit.widget"constantType discriminator that is always
chatkit.widget.CHATKIT_WIDGET("chatkit.widget")
-
String widgetSerialized widget payload rendered in the UI.
-
Assistants
List assistants
AssistantListPage beta().assistants().list(AssistantListParamsparams = AssistantListParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
get /assistants
Returns a list of assistants.
Parameters
-
AssistantListParams params-
Optional<String> afterA cursor for use in pagination.
afteris an object ID that defines your place in the list. For instance, if you make a list request and receive 100 objects, ending with obj_foo, your subsequent call can include after=obj_foo in order to fetch the next page of the list. -
Optional<String> beforeA cursor for use in pagination.
beforeis an object ID that defines your place in the list. For instance, if you make a list request and receive 100 objects, starting with obj_foo, your subsequent call can include before=obj_foo in order to fetch the previous page of the list. -
Optional<Long> limitA limit on the number of objects to be returned. Limit can range between 1 and 100, and the default is 20.
-
Optional<Order> orderSort order by the
created_attimestamp of the objects.ascfor ascending order anddescfor descending order.-
ASC("asc") -
DESC("desc")
-
-
Returns
-
class Assistant:Represents an
assistantthat can call the model and use tools.-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the assistant was created.
-
Optional<String> descriptionThe description of the assistant. The maximum length is 512 characters.
-
Optional<String> instructionsThe system instructions that the assistant uses. The maximum length is 256,000 characters.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelID of the model to use. You can use the List models API to see all of your available models, or see our Model overview for descriptions of them.
-
Optional<String> nameThe name of the assistant. The maximum length is 256 characters.
-
JsonValue; object_ "assistant"constantThe object type, which is always
assistant.ASSISTANT("assistant")
-
List<AssistantTool> toolsA list of tool enabled on the assistant. There can be a maximum of 128 tools per assistant. Tools can be of types
code_interpreter,file_search, orfunction.-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Double> temperatureWhat sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic.
-
Optional<ToolResources> toolResourcesA set of resources that are used by the assistant's tools. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the `code_interpreter`` tool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe ID of the vector store attached to this assistant. There can be a maximum of 1 vector store attached to the assistant.
-
-
-
Optional<Double> topPAn alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered.
We generally recommend altering this or temperature but not both.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.assistants.AssistantListPage;
import com.openai.models.beta.assistants.AssistantListParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
AssistantListPage page = client.beta().assistants().list();
}
}
Response
{
"data": [
{
"id": "id",
"created_at": 0,
"description": "description",
"instructions": "instructions",
"metadata": {
"foo": "string"
},
"model": "model",
"name": "name",
"object": "assistant",
"tools": [
{
"type": "code_interpreter"
}
],
"response_format": "auto",
"temperature": 1,
"tool_resources": {
"code_interpreter": {
"file_ids": [
"string"
]
},
"file_search": {
"vector_store_ids": [
"string"
]
}
},
"top_p": 1
}
],
"first_id": "asst_abc123",
"has_more": false,
"last_id": "asst_abc456",
"object": "list"
}
Create assistant
Assistant beta().assistants().create(AssistantCreateParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
post /assistants
Create an assistant with a model and instructions.
Parameters
-
AssistantCreateParams params-
ChatModel modelID of the model to use. You can use the List models API to see all of your available models, or see our Model overview for descriptions of them.
-
Optional<String> descriptionThe description of the assistant. The maximum length is 512 characters.
-
Optional<String> instructionsThe system instructions that the assistant uses. The maximum length is 256,000 characters.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
Optional<String> nameThe name of the assistant. The maximum length is 256 characters.
-
Optional<ReasoningEffort> reasoningEffortConstrains effort on reasoning for reasoning models. Currently supported values are
none,minimal,low,medium,high, andxhigh. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response.gpt-5.1defaults tonone, which does not perform reasoning. The supported reasoning values forgpt-5.1arenone,low,medium, andhigh. Tool calls are supported for all reasoning values in gpt-5.1.- All models before
gpt-5.1default tomediumreasoning effort, and do not supportnone. - The
gpt-5-promodel defaults to (and only supports)highreasoning effort. xhighis supported for all models aftergpt-5.1-codex-max.
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length. -
Optional<Double> temperatureWhat sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic.
-
Optional<ToolResources> toolResourcesA set of resources that are used by the assistant's tools. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe vector store attached to this assistant. There can be a maximum of 1 vector store attached to the assistant.
-
Optional<List<VectorStore>> vectorStoresA helper to create a vector store with file_ids and attach it to this assistant. There can be a maximum of 1 vector store attached to the assistant.
-
Optional<ChunkingStrategy> chunkingStrategyThe chunking strategy used to chunk the file(s). If not set, will use the
autostrategy.-
JsonValue;-
JsonValue; type "auto"constantAlways
auto.AUTO("auto")
-
-
class Static:-
InnerStatic static_-
long chunkOverlapTokensThe number of tokens that overlap between chunks. The default value is
400.Note that the overlap must not exceed half of
max_chunk_size_tokens. -
long maxChunkSizeTokensThe maximum number of tokens in each chunk. The default value is
800. The minimum value is100and the maximum value is4096.
-
-
JsonValue; type "static"constantAlways
static.STATIC("static")
-
-
-
Optional<List<String>> fileIdsA list of file IDs to add to the vector store. For vector stores created before Nov 2025, there can be a maximum of 10,000 files in a vector store. For vector stores created starting in Nov 2025, the limit is 100,000,000 files.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
-
-
-
Optional<List<AssistantTool>> toolsA list of tool enabled on the assistant. There can be a maximum of 128 tools per assistant. Tools can be of types
code_interpreter,file_search, orfunction.-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<Double> topPAn alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered.
We generally recommend altering this or temperature but not both.
-
Returns
-
class Assistant:Represents an
assistantthat can call the model and use tools.-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the assistant was created.
-
Optional<String> descriptionThe description of the assistant. The maximum length is 512 characters.
-
Optional<String> instructionsThe system instructions that the assistant uses. The maximum length is 256,000 characters.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelID of the model to use. You can use the List models API to see all of your available models, or see our Model overview for descriptions of them.
-
Optional<String> nameThe name of the assistant. The maximum length is 256 characters.
-
JsonValue; object_ "assistant"constantThe object type, which is always
assistant.ASSISTANT("assistant")
-
List<AssistantTool> toolsA list of tool enabled on the assistant. There can be a maximum of 128 tools per assistant. Tools can be of types
code_interpreter,file_search, orfunction.-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Double> temperatureWhat sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic.
-
Optional<ToolResources> toolResourcesA set of resources that are used by the assistant's tools. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the `code_interpreter`` tool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe ID of the vector store attached to this assistant. There can be a maximum of 1 vector store attached to the assistant.
-
-
-
Optional<Double> topPAn alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered.
We generally recommend altering this or temperature but not both.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.ChatModel;
import com.openai.models.beta.assistants.Assistant;
import com.openai.models.beta.assistants.AssistantCreateParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
AssistantCreateParams params = AssistantCreateParams.builder()
.model(ChatModel.GPT_4O)
.build();
Assistant assistant = client.beta().assistants().create(params);
}
}
Response
{
"id": "id",
"created_at": 0,
"description": "description",
"instructions": "instructions",
"metadata": {
"foo": "string"
},
"model": "model",
"name": "name",
"object": "assistant",
"tools": [
{
"type": "code_interpreter"
}
],
"response_format": "auto",
"temperature": 1,
"tool_resources": {
"code_interpreter": {
"file_ids": [
"string"
]
},
"file_search": {
"vector_store_ids": [
"string"
]
}
},
"top_p": 1
}
Retrieve assistant
Assistant beta().assistants().retrieve(AssistantRetrieveParamsparams = AssistantRetrieveParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
get /assistants/{assistant_id}
Retrieves an assistant.
Parameters
-
AssistantRetrieveParams paramsOptional<String> assistantId
Returns
-
class Assistant:Represents an
assistantthat can call the model and use tools.-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the assistant was created.
-
Optional<String> descriptionThe description of the assistant. The maximum length is 512 characters.
-
Optional<String> instructionsThe system instructions that the assistant uses. The maximum length is 256,000 characters.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelID of the model to use. You can use the List models API to see all of your available models, or see our Model overview for descriptions of them.
-
Optional<String> nameThe name of the assistant. The maximum length is 256 characters.
-
JsonValue; object_ "assistant"constantThe object type, which is always
assistant.ASSISTANT("assistant")
-
List<AssistantTool> toolsA list of tool enabled on the assistant. There can be a maximum of 128 tools per assistant. Tools can be of types
code_interpreter,file_search, orfunction.-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Double> temperatureWhat sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic.
-
Optional<ToolResources> toolResourcesA set of resources that are used by the assistant's tools. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the `code_interpreter`` tool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe ID of the vector store attached to this assistant. There can be a maximum of 1 vector store attached to the assistant.
-
-
-
Optional<Double> topPAn alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered.
We generally recommend altering this or temperature but not both.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.assistants.Assistant;
import com.openai.models.beta.assistants.AssistantRetrieveParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
Assistant assistant = client.beta().assistants().retrieve("assistant_id");
}
}
Response
{
"id": "id",
"created_at": 0,
"description": "description",
"instructions": "instructions",
"metadata": {
"foo": "string"
},
"model": "model",
"name": "name",
"object": "assistant",
"tools": [
{
"type": "code_interpreter"
}
],
"response_format": "auto",
"temperature": 1,
"tool_resources": {
"code_interpreter": {
"file_ids": [
"string"
]
},
"file_search": {
"vector_store_ids": [
"string"
]
}
},
"top_p": 1
}
Modify assistant
Assistant beta().assistants().update(AssistantUpdateParamsparams = AssistantUpdateParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
post /assistants/{assistant_id}
Modifies an assistant.
Parameters
-
AssistantUpdateParams params-
Optional<String> assistantId -
Optional<String> descriptionThe description of the assistant. The maximum length is 512 characters.
-
Optional<String> instructionsThe system instructions that the assistant uses. The maximum length is 256,000 characters.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
Optional<Model> modelID of the model to use. You can use the List models API to see all of your available models, or see our Model overview for descriptions of them.
-
GPT_5("gpt-5") -
GPT_5_MINI("gpt-5-mini") -
GPT_5_NANO("gpt-5-nano") -
GPT_5_2025_08_07("gpt-5-2025-08-07") -
GPT_5_MINI_2025_08_07("gpt-5-mini-2025-08-07") -
GPT_5_NANO_2025_08_07("gpt-5-nano-2025-08-07") -
GPT_4_1("gpt-4.1") -
GPT_4_1_MINI("gpt-4.1-mini") -
GPT_4_1_NANO("gpt-4.1-nano") -
GPT_4_1_2025_04_14("gpt-4.1-2025-04-14") -
GPT_4_1_MINI_2025_04_14("gpt-4.1-mini-2025-04-14") -
GPT_4_1_NANO_2025_04_14("gpt-4.1-nano-2025-04-14") -
O3_MINI("o3-mini") -
O3_MINI_2025_01_31("o3-mini-2025-01-31") -
O1("o1") -
O1_2024_12_17("o1-2024-12-17") -
GPT_4O("gpt-4o") -
GPT_4O_2024_11_20("gpt-4o-2024-11-20") -
GPT_4O_2024_08_06("gpt-4o-2024-08-06") -
GPT_4O_2024_05_13("gpt-4o-2024-05-13") -
GPT_4O_MINI("gpt-4o-mini") -
GPT_4O_MINI_2024_07_18("gpt-4o-mini-2024-07-18") -
GPT_4_5_PREVIEW("gpt-4.5-preview") -
GPT_4_5_PREVIEW_2025_02_27("gpt-4.5-preview-2025-02-27") -
GPT_4_TURBO("gpt-4-turbo") -
GPT_4_TURBO_2024_04_09("gpt-4-turbo-2024-04-09") -
GPT_4_0125_PREVIEW("gpt-4-0125-preview") -
GPT_4_TURBO_PREVIEW("gpt-4-turbo-preview") -
GPT_4_1106_PREVIEW("gpt-4-1106-preview") -
GPT_4_VISION_PREVIEW("gpt-4-vision-preview") -
GPT_4("gpt-4") -
GPT_4_0314("gpt-4-0314") -
GPT_4_0613("gpt-4-0613") -
GPT_4_32K("gpt-4-32k") -
GPT_4_32K_0314("gpt-4-32k-0314") -
GPT_4_32K_0613("gpt-4-32k-0613") -
GPT_3_5_TURBO("gpt-3.5-turbo") -
GPT_3_5_TURBO_16K("gpt-3.5-turbo-16k") -
GPT_3_5_TURBO_0613("gpt-3.5-turbo-0613") -
GPT_3_5_TURBO_1106("gpt-3.5-turbo-1106") -
GPT_3_5_TURBO_0125("gpt-3.5-turbo-0125") -
GPT_3_5_TURBO_16K_0613("gpt-3.5-turbo-16k-0613")
-
-
Optional<String> nameThe name of the assistant. The maximum length is 256 characters.
-
Optional<ReasoningEffort> reasoningEffortConstrains effort on reasoning for reasoning models. Currently supported values are
none,minimal,low,medium,high, andxhigh. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response.gpt-5.1defaults tonone, which does not perform reasoning. The supported reasoning values forgpt-5.1arenone,low,medium, andhigh. Tool calls are supported for all reasoning values in gpt-5.1.- All models before
gpt-5.1default tomediumreasoning effort, and do not supportnone. - The
gpt-5-promodel defaults to (and only supports)highreasoning effort. xhighis supported for all models aftergpt-5.1-codex-max.
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length. -
Optional<Double> temperatureWhat sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic.
-
Optional<ToolResources> toolResourcesA set of resources that are used by the assistant's tools. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsOverrides the list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsOverrides the vector store attached to this assistant. There can be a maximum of 1 vector store attached to the assistant.
-
-
-
Optional<List<AssistantTool>> toolsA list of tool enabled on the assistant. There can be a maximum of 128 tools per assistant. Tools can be of types
code_interpreter,file_search, orfunction.-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<Double> topPAn alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered.
We generally recommend altering this or temperature but not both.
-
Returns
-
class Assistant:Represents an
assistantthat can call the model and use tools.-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the assistant was created.
-
Optional<String> descriptionThe description of the assistant. The maximum length is 512 characters.
-
Optional<String> instructionsThe system instructions that the assistant uses. The maximum length is 256,000 characters.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelID of the model to use. You can use the List models API to see all of your available models, or see our Model overview for descriptions of them.
-
Optional<String> nameThe name of the assistant. The maximum length is 256 characters.
-
JsonValue; object_ "assistant"constantThe object type, which is always
assistant.ASSISTANT("assistant")
-
List<AssistantTool> toolsA list of tool enabled on the assistant. There can be a maximum of 128 tools per assistant. Tools can be of types
code_interpreter,file_search, orfunction.-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Double> temperatureWhat sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic.
-
Optional<ToolResources> toolResourcesA set of resources that are used by the assistant's tools. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the `code_interpreter`` tool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe ID of the vector store attached to this assistant. There can be a maximum of 1 vector store attached to the assistant.
-
-
-
Optional<Double> topPAn alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered.
We generally recommend altering this or temperature but not both.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.assistants.Assistant;
import com.openai.models.beta.assistants.AssistantUpdateParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
Assistant assistant = client.beta().assistants().update("assistant_id");
}
}
Response
{
"id": "id",
"created_at": 0,
"description": "description",
"instructions": "instructions",
"metadata": {
"foo": "string"
},
"model": "model",
"name": "name",
"object": "assistant",
"tools": [
{
"type": "code_interpreter"
}
],
"response_format": "auto",
"temperature": 1,
"tool_resources": {
"code_interpreter": {
"file_ids": [
"string"
]
},
"file_search": {
"vector_store_ids": [
"string"
]
}
},
"top_p": 1
}
Delete assistant
AssistantDeleted beta().assistants().delete(AssistantDeleteParamsparams = AssistantDeleteParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
delete /assistants/{assistant_id}
Delete an assistant.
Parameters
-
AssistantDeleteParams paramsOptional<String> assistantId
Returns
-
class AssistantDeleted:-
String id -
boolean deleted -
JsonValue; object_ "assistant.deleted"constantASSISTANT_DELETED("assistant.deleted")
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.assistants.AssistantDeleteParams;
import com.openai.models.beta.assistants.AssistantDeleted;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
AssistantDeleted assistantDeleted = client.beta().assistants().delete("assistant_id");
}
}
Response
{
"id": "id",
"deleted": true,
"object": "assistant.deleted"
}
Domain Types
Assistant
-
class Assistant:Represents an
assistantthat can call the model and use tools.-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the assistant was created.
-
Optional<String> descriptionThe description of the assistant. The maximum length is 512 characters.
-
Optional<String> instructionsThe system instructions that the assistant uses. The maximum length is 256,000 characters.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelID of the model to use. You can use the List models API to see all of your available models, or see our Model overview for descriptions of them.
-
Optional<String> nameThe name of the assistant. The maximum length is 256 characters.
-
JsonValue; object_ "assistant"constantThe object type, which is always
assistant.ASSISTANT("assistant")
-
List<AssistantTool> toolsA list of tool enabled on the assistant. There can be a maximum of 128 tools per assistant. Tools can be of types
code_interpreter,file_search, orfunction.-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Double> temperatureWhat sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic.
-
Optional<ToolResources> toolResourcesA set of resources that are used by the assistant's tools. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the `code_interpreter`` tool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe ID of the vector store attached to this assistant. There can be a maximum of 1 vector store attached to the assistant.
-
-
-
Optional<Double> topPAn alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered.
We generally recommend altering this or temperature but not both.
-
Assistant Deleted
-
class AssistantDeleted:-
String id -
boolean deleted -
JsonValue; object_ "assistant.deleted"constantASSISTANT_DELETED("assistant.deleted")
-
Assistant Stream Event
-
class AssistantStreamEvent: A class that can be one of several variants.unionRepresents an event emitted when streaming a Run.
Each event in a server-sent events stream has an
eventanddataproperty:event: thread.created data: {"id": "thread_123", "object": "thread", ...}We emit events whenever a new object is created, transitions to a new state, or is being streamed in parts (deltas). For example, we emit
thread.run.createdwhen a new run is created,thread.run.completedwhen a run completes, and so on. When an Assistant chooses to create a message during a run, we emit athread.message.created event, athread.message.in_progressevent, manythread.message.deltaevents, and finally athread.message.completedevent.We may add additional events over time, so we recommend handling unknown events gracefully in your code. See the Assistants API quickstart to learn how to integrate the Assistants API with streaming.
-
ThreadCreated-
Thread dataRepresents a thread that contains messages.
-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the thread was created.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread"constantThe object type, which is always
thread.THREAD("thread")
-
Optional<ToolResources> toolResourcesA set of resources that are made available to the assistant's tools in this thread. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe vector store attached to this thread. There can be a maximum of 1 vector store attached to the thread.
-
-
-
-
JsonValue; event "thread.created"constantTHREAD_CREATED("thread.created")
-
Optional<Boolean> enabledWhether to enable input audio transcription.
-
-
ThreadRunCreated-
Run dataRepresents an execution run on a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant used for execution of this run.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run was completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run was created.
-
Optional<Long> expiresAtThe Unix timestamp (in seconds) for when the run will expire.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run failed.
-
Optional<IncompleteDetails> incompleteDetailsDetails on why the run is incomplete. Will be
nullif the run is not incomplete.-
Optional<Reason> reasonThe reason why the run is incomplete. This will point to which specific token limit was reached over the course of the run.
-
MAX_COMPLETION_TOKENS("max_completion_tokens") -
MAX_PROMPT_TOKENS("max_prompt_tokens")
-
-
-
String instructionsThe instructions that the assistant used for this run.
-
Optional<LastError> lastErrorThe last error associated with this run. Will be
nullif there are no errors.-
Code codeOne of
server_error,rate_limit_exceeded, orinvalid_prompt.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded") -
INVALID_PROMPT("invalid_prompt")
-
-
String messageA human-readable description of the error.
-
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens specified to have been used over the course of the run.
-
Optional<Long> maxPromptTokensThe maximum number of prompt tokens specified to have been used over the course of the run.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelThe model that the assistant used for this run.
-
JsonValue; object_ "thread.run"constantThe object type, which is always
thread.run.THREAD_RUN("thread.run")
-
boolean parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<RequiredAction> requiredActionDetails on the action required to continue the run. Will be
nullif no action is required.-
SubmitToolOutputs submitToolOutputsDetails on the tool outputs needed for this run to continue.
-
List<RequiredActionFunctionToolCall> toolCallsA list of the relevant tool calls.
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
-
-
JsonValue; type "submit_tool_outputs"constantFor now, this is always
submit_tool_outputs.SUBMIT_TOOL_OUTPUTS("submit_tool_outputs")
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Long> startedAtThe Unix timestamp (in seconds) for when the run was started.
-
RunStatus statusThe status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
-
String threadIdThe ID of the thread that was executed on as a part of this run.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
-
List<AssistantTool> toolsThe list of tools that the assistant used for this run.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Optional<Usage> usageUsage statistics related to the run. This value will be
nullif the run is not in a terminal state (i.e.in_progress,queued, etc.).-
long completionTokensNumber of completion tokens used over the course of the run.
-
long promptTokensNumber of prompt tokens used over the course of the run.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Optional<Double> temperatureThe sampling temperature used for this run. If not set, defaults to 1.
-
Optional<Double> topPThe nucleus sampling value used for this run. If not set, defaults to 1.
-
-
JsonValue; event "thread.run.created"constantTHREAD_RUN_CREATED("thread.run.created")
-
-
ThreadRunQueued-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.queued"constantTHREAD_RUN_QUEUED("thread.run.queued")
-
-
ThreadRunInProgress-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.in_progress"constantTHREAD_RUN_IN_PROGRESS("thread.run.in_progress")
-
-
ThreadRunRequiresAction-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.requires_action"constantTHREAD_RUN_REQUIRES_ACTION("thread.run.requires_action")
-
-
ThreadRunCompleted-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.completed"constantTHREAD_RUN_COMPLETED("thread.run.completed")
-
-
ThreadRunIncomplete-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.incomplete"constantTHREAD_RUN_INCOMPLETE("thread.run.incomplete")
-
-
ThreadRunFailed-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.failed"constantTHREAD_RUN_FAILED("thread.run.failed")
-
-
ThreadRunCancelling-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.cancelling"constantTHREAD_RUN_CANCELLING("thread.run.cancelling")
-
-
ThreadRunCancelled-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.cancelled"constantTHREAD_RUN_CANCELLED("thread.run.cancelled")
-
-
ThreadRunExpired-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.expired"constantTHREAD_RUN_EXPIRED("thread.run.expired")
-
-
ThreadRunStepCreated-
RunStep dataRepresents a step in execution of a run.
-
String idThe identifier of the run step, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant associated with the run step.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run step was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run step completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run step was created.
-
Optional<Long> expiredAtThe Unix timestamp (in seconds) for when the run step expired. A step is considered expired if the parent run is expired.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run step failed.
-
Optional<LastError> lastErrorThe last error associated with this run step. Will be
nullif there are no errors.-
Code codeOne of
server_errororrate_limit_exceeded.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded")
-
-
String messageA human-readable description of the error.
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.run.step"constantThe object type, which is always
thread.run.step.THREAD_RUN_STEP("thread.run.step")
-
String runIdThe ID of the run that this run step is a part of.
-
Status statusThe status of the run step, which can be either
in_progress,cancelled,failed,completed, orexpired.-
IN_PROGRESS("in_progress") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
EXPIRED("expired")
-
-
StepDetails stepDetailsThe details of the run step.
-
class MessageCreationStepDetails:Details of the message creation by the run step.
-
MessageCreation messageCreation-
String messageIdThe ID of the message that was created by this run step.
-
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
-
class ToolCallsStepDetails:Details of the tool call.
-
List<ToolCall> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCall:Details of the Code Interpreter tool call the run step was involved in.
-
String idThe ID of the tool call.
-
CodeInterpreter codeInterpreterThe Code Interpreter tool call definition.
-
String inputThe input to the Code Interpreter tool call.
-
List<Output> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class LogsOutput:Text output from the Code Interpreter tool call as part of a run step.
-
String logsThe text output from the Code Interpreter tool call.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
-
class ImageOutput:-
Image image-
String fileIdThe file ID of the image.
-
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
-
-
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
-
class FileSearchToolCall:-
String idThe ID of the tool call object.
-
FileSearch fileSearchFor now, this is always going to be an empty object.
-
Optional<RankingOptions> rankingOptionsThe ranking options for the file search.
-
Ranker rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
-
Optional<List<Result>> resultsThe results of the file search.
-
String fileIdThe ID of the file that result was found in.
-
String fileNameThe name of the file that result was found in.
-
double scoreThe score of the result. All values must be a floating point number between 0 and 1.
-
Optional<List<Content>> contentThe content of the result that was found. The content is only included if requested via the include query parameter.
-
Optional<String> textThe text content of the file.
-
Optional<Type> typeThe type of the content.
TEXT("text")
-
-
-
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
-
class FunctionToolCall:-
String idThe ID of the tool call object.
-
Function functionThe definition of the function that was called.
-
String argumentsThe arguments passed to the function.
-
String nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
-
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
-
-
String threadIdThe ID of the thread that was run.
-
Type typeThe type of run step, which can be either
message_creationortool_calls.-
MESSAGE_CREATION("message_creation") -
TOOL_CALLS("tool_calls")
-
-
Optional<Usage> usageUsage statistics related to the run step. This value will be
nullwhile the run step's status isin_progress.-
long completionTokensNumber of completion tokens used over the course of the run step.
-
long promptTokensNumber of prompt tokens used over the course of the run step.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
-
JsonValue; event "thread.run.step.created"constantTHREAD_RUN_STEP_CREATED("thread.run.step.created")
-
-
ThreadRunStepInProgress-
RunStep dataRepresents a step in execution of a run.
-
JsonValue; event "thread.run.step.in_progress"constantTHREAD_RUN_STEP_IN_PROGRESS("thread.run.step.in_progress")
-
-
ThreadRunStepDelta-
RunStepDeltaEvent dataRepresents a run step delta i.e. any changed fields on a run step during streaming.
-
String idThe identifier of the run step, which can be referenced in API endpoints.
-
RunStepDelta deltaThe delta containing the fields that have changed on the run step.
-
Optional<StepDetails> stepDetailsThe details of the run step.
-
class RunStepDeltaMessageDelta:Details of the message creation by the run step.
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
Optional<MessageCreation> messageCreation-
Optional<String> messageIdThe ID of the message that was created by this run step.
-
-
-
class ToolCallDeltaObject:Details of the tool call.
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
Optional<List<ToolCallDelta>> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCallDelta:Details of the Code Interpreter tool call the run step was involved in.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
Optional<String> idThe ID of the tool call.
-
Optional<CodeInterpreter> codeInterpreterThe Code Interpreter tool call definition.
-
Optional<String> inputThe input to the Code Interpreter tool call.
-
Optional<List<Output>> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class CodeInterpreterLogs:Text output from the Code Interpreter tool call as part of a run step.
-
long indexThe index of the output in the outputs array.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
Optional<String> logsThe text output from the Code Interpreter tool call.
-
-
class CodeInterpreterOutputImage:-
long indexThe index of the output in the outputs array.
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
Optional<Image> image-
Optional<String> fileIdThe file ID of the image.
-
-
-
-
-
-
class FileSearchToolCallDelta:-
JsonValue fileSearchFor now, this is always going to be an empty object.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
Optional<String> idThe ID of the tool call object.
-
-
class FunctionToolCallDelta:-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
Optional<String> idThe ID of the tool call object.
-
Optional<Function> functionThe definition of the function that was called.
-
Optional<String> argumentsThe arguments passed to the function.
-
Optional<String> nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
-
-
-
-
-
JsonValue; object_ "thread.run.step.delta"constantThe object type, which is always
thread.run.step.delta.THREAD_RUN_STEP_DELTA("thread.run.step.delta")
-
-
JsonValue; event "thread.run.step.delta"constantTHREAD_RUN_STEP_DELTA("thread.run.step.delta")
-
-
ThreadRunStepCompleted-
RunStep dataRepresents a step in execution of a run.
-
JsonValue; event "thread.run.step.completed"constantTHREAD_RUN_STEP_COMPLETED("thread.run.step.completed")
-
-
ThreadRunStepFailed-
RunStep dataRepresents a step in execution of a run.
-
JsonValue; event "thread.run.step.failed"constantTHREAD_RUN_STEP_FAILED("thread.run.step.failed")
-
-
ThreadRunStepCancelled-
RunStep dataRepresents a step in execution of a run.
-
JsonValue; event "thread.run.step.cancelled"constantTHREAD_RUN_STEP_CANCELLED("thread.run.step.cancelled")
-
-
ThreadRunStepExpired-
RunStep dataRepresents a step in execution of a run.
-
JsonValue; event "thread.run.step.expired"constantTHREAD_RUN_STEP_EXPIRED("thread.run.step.expired")
-
-
ThreadMessageCreated-
Message dataRepresents a message within a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
Optional<String> assistantIdIf applicable, the ID of the assistant that authored this message.
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they were added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool: -
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the message was completed.
-
List<MessageContent> contentThe content of the message in array of text and/or images.
-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlock:The text content that is part of a message.
-
Text text-
List<Annotation> annotations-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
-
String valueThe data that makes up the text.
-
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
class RefusalContentBlock:The refusal content generated by the assistant.
-
String refusal -
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
-
-
long createdAtThe Unix timestamp (in seconds) for when the message was created.
-
Optional<Long> incompleteAtThe Unix timestamp (in seconds) for when the message was marked as incomplete.
-
Optional<IncompleteDetails> incompleteDetailsOn an incomplete message, details about why the message is incomplete.
-
Reason reasonThe reason the message is incomplete.
-
CONTENT_FILTER("content_filter") -
MAX_TOKENS("max_tokens") -
RUN_CANCELLED("run_cancelled") -
RUN_EXPIRED("run_expired") -
RUN_FAILED("run_failed")
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.message"constantThe object type, which is always
thread.message.THREAD_MESSAGE("thread.message")
-
Role roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
Optional<String> runIdThe ID of the run associated with the creation of this message. Value is
nullwhen messages are created manually using the create message or create thread endpoints. -
Status statusThe status of the message, which can be either
in_progress,incomplete, orcompleted.-
IN_PROGRESS("in_progress") -
INCOMPLETE("incomplete") -
COMPLETED("completed")
-
-
String threadIdThe thread ID that this message belongs to.
-
-
JsonValue; event "thread.message.created"constantTHREAD_MESSAGE_CREATED("thread.message.created")
-
-
ThreadMessageInProgress-
Message dataRepresents a message within a thread.
-
JsonValue; event "thread.message.in_progress"constantTHREAD_MESSAGE_IN_PROGRESS("thread.message.in_progress")
-
-
ThreadMessageDelta-
MessageDeltaEvent dataRepresents a message delta i.e. any changed fields on a message during streaming.
-
String idThe identifier of the message, which can be referenced in API endpoints.
-
MessageDelta deltaThe delta containing the fields that have changed on the Message.
-
Optional<List<MessageContentDelta>> contentThe content of the message in array of text and/or images.
-
class ImageFileDeltaBlock:References an image File in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
Optional<ImageFileDelta> imageFile-
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content.
-
-
-
class TextDeltaBlock:The text content that is part of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
Optional<TextDelta> text-
Optional<List<AnnotationDelta>> annotations-
class FileCitationDeltaAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
Optional<Long> endIndex -
Optional<FileCitation> fileCitation-
Optional<String> fileIdThe ID of the specific File the citation is from.
-
Optional<String> quoteThe specific quote in the file.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
class FilePathDeltaAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
Optional<Long> endIndex -
Optional<FilePath> filePath-
Optional<String> fileIdThe ID of the file that was generated.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
-
Optional<String> valueThe data that makes up the text.
-
-
-
class RefusalDeltaBlock:The refusal content that is part of a message.
-
long indexThe index of the refusal part in the message.
-
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
Optional<String> refusal
-
-
class ImageUrlDeltaBlock:References an image URL in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_url"constantAlways
image_url.IMAGE_URL("image_url")
-
Optional<ImageUrlDelta> imageUrl-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> urlThe URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
-
-
-
Optional<Role> roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
-
JsonValue; object_ "thread.message.delta"constantThe object type, which is always
thread.message.delta.THREAD_MESSAGE_DELTA("thread.message.delta")
-
-
JsonValue; event "thread.message.delta"constantTHREAD_MESSAGE_DELTA("thread.message.delta")
-
-
ThreadMessageCompleted-
Message dataRepresents a message within a thread.
-
JsonValue; event "thread.message.completed"constantTHREAD_MESSAGE_COMPLETED("thread.message.completed")
-
-
ThreadMessageIncomplete-
Message dataRepresents a message within a thread.
-
JsonValue; event "thread.message.incomplete"constantTHREAD_MESSAGE_INCOMPLETE("thread.message.incomplete")
-
-
ErrorEvent-
ErrorObject data-
Optional<String> code -
String message -
Optional<String> param -
String type
-
-
JsonValue; event "error"constantERROR("error")
-
-
Assistant Tool
-
class AssistantTool: A class that can be one of several variants.union-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
Code Interpreter Tool
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
File Search Tool
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
Function Tool
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
Message Stream Event
-
class MessageStreamEvent: A class that can be one of several variants.unionOccurs when a message is created.
-
ThreadMessageCreated-
Message dataRepresents a message within a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
Optional<String> assistantIdIf applicable, the ID of the assistant that authored this message.
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they were added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the message was completed.
-
List<MessageContent> contentThe content of the message in array of text and/or images.
-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlock:The text content that is part of a message.
-
Text text-
List<Annotation> annotations-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
-
String valueThe data that makes up the text.
-
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
class RefusalContentBlock:The refusal content generated by the assistant.
-
String refusal -
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
-
-
long createdAtThe Unix timestamp (in seconds) for when the message was created.
-
Optional<Long> incompleteAtThe Unix timestamp (in seconds) for when the message was marked as incomplete.
-
Optional<IncompleteDetails> incompleteDetailsOn an incomplete message, details about why the message is incomplete.
-
Reason reasonThe reason the message is incomplete.
-
CONTENT_FILTER("content_filter") -
MAX_TOKENS("max_tokens") -
RUN_CANCELLED("run_cancelled") -
RUN_EXPIRED("run_expired") -
RUN_FAILED("run_failed")
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.message"constantThe object type, which is always
thread.message.THREAD_MESSAGE("thread.message")
-
Role roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
Optional<String> runIdThe ID of the run associated with the creation of this message. Value is
nullwhen messages are created manually using the create message or create thread endpoints. -
Status statusThe status of the message, which can be either
in_progress,incomplete, orcompleted.-
IN_PROGRESS("in_progress") -
INCOMPLETE("incomplete") -
COMPLETED("completed")
-
-
String threadIdThe thread ID that this message belongs to.
-
-
JsonValue; event "thread.message.created"constantTHREAD_MESSAGE_CREATED("thread.message.created")
-
-
ThreadMessageInProgress-
Message dataRepresents a message within a thread.
-
JsonValue; event "thread.message.in_progress"constantTHREAD_MESSAGE_IN_PROGRESS("thread.message.in_progress")
-
-
ThreadMessageDelta-
MessageDeltaEvent dataRepresents a message delta i.e. any changed fields on a message during streaming.
-
String idThe identifier of the message, which can be referenced in API endpoints.
-
MessageDelta deltaThe delta containing the fields that have changed on the Message.
-
Optional<List<MessageContentDelta>> contentThe content of the message in array of text and/or images.
-
class ImageFileDeltaBlock:References an image File in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
Optional<ImageFileDelta> imageFile-
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content.
-
-
-
class TextDeltaBlock:The text content that is part of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
Optional<TextDelta> text-
Optional<List<AnnotationDelta>> annotations-
class FileCitationDeltaAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
Optional<Long> endIndex -
Optional<FileCitation> fileCitation-
Optional<String> fileIdThe ID of the specific File the citation is from.
-
Optional<String> quoteThe specific quote in the file.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
class FilePathDeltaAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
Optional<Long> endIndex -
Optional<FilePath> filePath-
Optional<String> fileIdThe ID of the file that was generated.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
-
Optional<String> valueThe data that makes up the text.
-
-
-
class RefusalDeltaBlock:The refusal content that is part of a message.
-
long indexThe index of the refusal part in the message.
-
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
Optional<String> refusal
-
-
class ImageUrlDeltaBlock:References an image URL in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_url"constantAlways
image_url.IMAGE_URL("image_url")
-
Optional<ImageUrlDelta> imageUrl-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> urlThe URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
-
-
-
Optional<Role> roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
-
JsonValue; object_ "thread.message.delta"constantThe object type, which is always
thread.message.delta.THREAD_MESSAGE_DELTA("thread.message.delta")
-
-
JsonValue; event "thread.message.delta"constantTHREAD_MESSAGE_DELTA("thread.message.delta")
-
-
ThreadMessageCompleted-
Message dataRepresents a message within a thread.
-
JsonValue; event "thread.message.completed"constantTHREAD_MESSAGE_COMPLETED("thread.message.completed")
-
-
ThreadMessageIncomplete-
Message dataRepresents a message within a thread.
-
JsonValue; event "thread.message.incomplete"constantTHREAD_MESSAGE_INCOMPLETE("thread.message.incomplete")
-
-
Run Step Stream Event
-
class RunStepStreamEvent: A class that can be one of several variants.unionOccurs when a run step is created.
-
ThreadRunStepCreated-
RunStep dataRepresents a step in execution of a run.
-
String idThe identifier of the run step, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant associated with the run step.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run step was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run step completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run step was created.
-
Optional<Long> expiredAtThe Unix timestamp (in seconds) for when the run step expired. A step is considered expired if the parent run is expired.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run step failed.
-
Optional<LastError> lastErrorThe last error associated with this run step. Will be
nullif there are no errors.-
Code codeOne of
server_errororrate_limit_exceeded.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded")
-
-
String messageA human-readable description of the error.
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.run.step"constantThe object type, which is always
thread.run.step.THREAD_RUN_STEP("thread.run.step")
-
String runIdThe ID of the run that this run step is a part of.
-
Status statusThe status of the run step, which can be either
in_progress,cancelled,failed,completed, orexpired.-
IN_PROGRESS("in_progress") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
EXPIRED("expired")
-
-
StepDetails stepDetailsThe details of the run step.
-
class MessageCreationStepDetails:Details of the message creation by the run step.
-
MessageCreation messageCreation-
String messageIdThe ID of the message that was created by this run step.
-
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
-
class ToolCallsStepDetails:Details of the tool call.
-
List<ToolCall> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCall:Details of the Code Interpreter tool call the run step was involved in.
-
String idThe ID of the tool call.
-
CodeInterpreter codeInterpreterThe Code Interpreter tool call definition.
-
String inputThe input to the Code Interpreter tool call.
-
List<Output> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class LogsOutput:Text output from the Code Interpreter tool call as part of a run step.
-
String logsThe text output from the Code Interpreter tool call.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
-
class ImageOutput:-
Image image-
String fileIdThe file ID of the image.
-
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
-
-
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
-
class FileSearchToolCall:-
String idThe ID of the tool call object.
-
FileSearch fileSearchFor now, this is always going to be an empty object.
-
Optional<RankingOptions> rankingOptionsThe ranking options for the file search.
-
Ranker rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
-
Optional<List<Result>> resultsThe results of the file search.
-
String fileIdThe ID of the file that result was found in.
-
String fileNameThe name of the file that result was found in.
-
double scoreThe score of the result. All values must be a floating point number between 0 and 1.
-
Optional<List<Content>> contentThe content of the result that was found. The content is only included if requested via the include query parameter.
-
Optional<String> textThe text content of the file.
-
Optional<Type> typeThe type of the content.
TEXT("text")
-
-
-
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
-
class FunctionToolCall:-
String idThe ID of the tool call object.
-
Function functionThe definition of the function that was called.
-
String argumentsThe arguments passed to the function.
-
String nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
-
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
-
-
String threadIdThe ID of the thread that was run.
-
Type typeThe type of run step, which can be either
message_creationortool_calls.-
MESSAGE_CREATION("message_creation") -
TOOL_CALLS("tool_calls")
-
-
Optional<Usage> usageUsage statistics related to the run step. This value will be
nullwhile the run step's status isin_progress.-
long completionTokensNumber of completion tokens used over the course of the run step.
-
long promptTokensNumber of prompt tokens used over the course of the run step.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
-
JsonValue; event "thread.run.step.created"constantTHREAD_RUN_STEP_CREATED("thread.run.step.created")
-
-
ThreadRunStepInProgress-
RunStep dataRepresents a step in execution of a run.
-
JsonValue; event "thread.run.step.in_progress"constantTHREAD_RUN_STEP_IN_PROGRESS("thread.run.step.in_progress")
-
-
ThreadRunStepDelta-
RunStepDeltaEvent dataRepresents a run step delta i.e. any changed fields on a run step during streaming.
-
String idThe identifier of the run step, which can be referenced in API endpoints.
-
RunStepDelta deltaThe delta containing the fields that have changed on the run step.
-
Optional<StepDetails> stepDetailsThe details of the run step.
-
class RunStepDeltaMessageDelta:Details of the message creation by the run step.
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
Optional<MessageCreation> messageCreation-
Optional<String> messageIdThe ID of the message that was created by this run step.
-
-
-
class ToolCallDeltaObject:Details of the tool call.
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
Optional<List<ToolCallDelta>> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCallDelta:Details of the Code Interpreter tool call the run step was involved in.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
Optional<String> idThe ID of the tool call.
-
Optional<CodeInterpreter> codeInterpreterThe Code Interpreter tool call definition.
-
Optional<String> inputThe input to the Code Interpreter tool call.
-
Optional<List<Output>> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class CodeInterpreterLogs:Text output from the Code Interpreter tool call as part of a run step.
-
long indexThe index of the output in the outputs array.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
Optional<String> logsThe text output from the Code Interpreter tool call.
-
-
class CodeInterpreterOutputImage:-
long indexThe index of the output in the outputs array.
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
Optional<Image> image-
Optional<String> fileIdThe file ID of the image.
-
-
-
-
-
-
class FileSearchToolCallDelta:-
JsonValue fileSearchFor now, this is always going to be an empty object.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
Optional<String> idThe ID of the tool call object.
-
-
class FunctionToolCallDelta:-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
Optional<String> idThe ID of the tool call object.
-
Optional<Function> functionThe definition of the function that was called.
-
Optional<String> argumentsThe arguments passed to the function.
-
Optional<String> nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
-
-
-
-
-
JsonValue; object_ "thread.run.step.delta"constantThe object type, which is always
thread.run.step.delta.THREAD_RUN_STEP_DELTA("thread.run.step.delta")
-
-
JsonValue; event "thread.run.step.delta"constantTHREAD_RUN_STEP_DELTA("thread.run.step.delta")
-
-
ThreadRunStepCompleted-
RunStep dataRepresents a step in execution of a run.
-
JsonValue; event "thread.run.step.completed"constantTHREAD_RUN_STEP_COMPLETED("thread.run.step.completed")
-
-
ThreadRunStepFailed-
RunStep dataRepresents a step in execution of a run.
-
JsonValue; event "thread.run.step.failed"constantTHREAD_RUN_STEP_FAILED("thread.run.step.failed")
-
-
ThreadRunStepCancelled-
RunStep dataRepresents a step in execution of a run.
-
JsonValue; event "thread.run.step.cancelled"constantTHREAD_RUN_STEP_CANCELLED("thread.run.step.cancelled")
-
-
ThreadRunStepExpired-
RunStep dataRepresents a step in execution of a run.
-
JsonValue; event "thread.run.step.expired"constantTHREAD_RUN_STEP_EXPIRED("thread.run.step.expired")
-
-
Run Stream Event
-
class RunStreamEvent: A class that can be one of several variants.unionOccurs when a new run is created.
-
ThreadRunCreated-
Run dataRepresents an execution run on a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant used for execution of this run.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run was completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run was created.
-
Optional<Long> expiresAtThe Unix timestamp (in seconds) for when the run will expire.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run failed.
-
Optional<IncompleteDetails> incompleteDetailsDetails on why the run is incomplete. Will be
nullif the run is not incomplete.-
Optional<Reason> reasonThe reason why the run is incomplete. This will point to which specific token limit was reached over the course of the run.
-
MAX_COMPLETION_TOKENS("max_completion_tokens") -
MAX_PROMPT_TOKENS("max_prompt_tokens")
-
-
-
String instructionsThe instructions that the assistant used for this run.
-
Optional<LastError> lastErrorThe last error associated with this run. Will be
nullif there are no errors.-
Code codeOne of
server_error,rate_limit_exceeded, orinvalid_prompt.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded") -
INVALID_PROMPT("invalid_prompt")
-
-
String messageA human-readable description of the error.
-
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens specified to have been used over the course of the run.
-
Optional<Long> maxPromptTokensThe maximum number of prompt tokens specified to have been used over the course of the run.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelThe model that the assistant used for this run.
-
JsonValue; object_ "thread.run"constantThe object type, which is always
thread.run.THREAD_RUN("thread.run")
-
boolean parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<RequiredAction> requiredActionDetails on the action required to continue the run. Will be
nullif no action is required.-
SubmitToolOutputs submitToolOutputsDetails on the tool outputs needed for this run to continue.
-
List<RequiredActionFunctionToolCall> toolCallsA list of the relevant tool calls.
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
-
-
JsonValue; type "submit_tool_outputs"constantFor now, this is always
submit_tool_outputs.SUBMIT_TOOL_OUTPUTS("submit_tool_outputs")
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Long> startedAtThe Unix timestamp (in seconds) for when the run was started.
-
RunStatus statusThe status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
-
String threadIdThe ID of the thread that was executed on as a part of this run.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
-
List<AssistantTool> toolsThe list of tools that the assistant used for this run.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Optional<Usage> usageUsage statistics related to the run. This value will be
nullif the run is not in a terminal state (i.e.in_progress,queued, etc.).-
long completionTokensNumber of completion tokens used over the course of the run.
-
long promptTokensNumber of prompt tokens used over the course of the run.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Optional<Double> temperatureThe sampling temperature used for this run. If not set, defaults to 1.
-
Optional<Double> topPThe nucleus sampling value used for this run. If not set, defaults to 1.
-
-
JsonValue; event "thread.run.created"constantTHREAD_RUN_CREATED("thread.run.created")
-
-
ThreadRunQueued-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.queued"constantTHREAD_RUN_QUEUED("thread.run.queued")
-
-
ThreadRunInProgress-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.in_progress"constantTHREAD_RUN_IN_PROGRESS("thread.run.in_progress")
-
-
ThreadRunRequiresAction-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.requires_action"constantTHREAD_RUN_REQUIRES_ACTION("thread.run.requires_action")
-
-
ThreadRunCompleted-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.completed"constantTHREAD_RUN_COMPLETED("thread.run.completed")
-
-
ThreadRunIncomplete-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.incomplete"constantTHREAD_RUN_INCOMPLETE("thread.run.incomplete")
-
-
ThreadRunFailed-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.failed"constantTHREAD_RUN_FAILED("thread.run.failed")
-
-
ThreadRunCancelling-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.cancelling"constantTHREAD_RUN_CANCELLING("thread.run.cancelling")
-
-
ThreadRunCancelled-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.cancelled"constantTHREAD_RUN_CANCELLED("thread.run.cancelled")
-
-
ThreadRunExpired-
Run dataRepresents an execution run on a thread.
-
JsonValue; event "thread.run.expired"constantTHREAD_RUN_EXPIRED("thread.run.expired")
-
-
Thread Stream Event
-
class ThreadStreamEvent:Occurs when a new thread is created.
-
Thread dataRepresents a thread that contains messages.
-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the thread was created.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread"constantThe object type, which is always
thread.THREAD("thread")
-
Optional<ToolResources> toolResourcesA set of resources that are made available to the assistant's tools in this thread. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe vector store attached to this thread. There can be a maximum of 1 vector store attached to the thread.
-
-
-
-
JsonValue; event "thread.created"constantTHREAD_CREATED("thread.created")
-
Optional<Boolean> enabledWhether to enable input audio transcription.
-
Threads
Create thread
Thread beta().threads().create(ThreadCreateParamsparams = ThreadCreateParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
post /threads
Create a thread.
Parameters
-
ThreadCreateParams params-
Optional<List<Message>> messagesA list of messages to start the thread with.
-
Content contentThe text contents of the message.
-
String -
List<MessageContentPartParam>-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlockParam:The text content that is part of a message.
-
String textText content to be sent to the model
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
-
-
Role roleThe role of the entity that is creating the message. Allowed values include:
-
user: Indicates the message is sent by an actual user and should be used in most cases to represent user-generated messages. -
assistant: Indicates the message is generated by the assistant. Use this value to insert messages from the assistant into the conversation. -
USER("user") -
ASSISTANT("assistant")
-
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they should be added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
Optional<ToolResources> toolResourcesA set of resources that are made available to the assistant's tools in this thread. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe vector store attached to this thread. There can be a maximum of 1 vector store attached to the thread.
-
Optional<List<VectorStore>> vectorStoresA helper to create a vector store with file_ids and attach it to this thread. There can be a maximum of 1 vector store attached to the thread.
-
Optional<ChunkingStrategy> chunkingStrategyThe chunking strategy used to chunk the file(s). If not set, will use the
autostrategy.-
JsonValue;-
JsonValue; type "auto"constantAlways
auto.AUTO("auto")
-
-
class Static:-
InnerStatic static_-
long chunkOverlapTokensThe number of tokens that overlap between chunks. The default value is
400.Note that the overlap must not exceed half of
max_chunk_size_tokens. -
long maxChunkSizeTokensThe maximum number of tokens in each chunk. The default value is
800. The minimum value is100and the maximum value is4096.
-
-
JsonValue; type "static"constantAlways
static.STATIC("static")
-
-
-
Optional<List<String>> fileIdsA list of file IDs to add to the vector store. For vector stores created before Nov 2025, there can be a maximum of 10,000 files in a vector store. For vector stores created starting in Nov 2025, the limit is 100,000,000 files.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
-
-
-
Returns
-
class Thread:Represents a thread that contains messages.
-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the thread was created.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread"constantThe object type, which is always
thread.THREAD("thread")
-
Optional<ToolResources> toolResourcesA set of resources that are made available to the assistant's tools in this thread. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe vector store attached to this thread. There can be a maximum of 1 vector store attached to the thread.
-
-
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.Thread;
import com.openai.models.beta.threads.ThreadCreateParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
Thread thread = client.beta().threads().create();
}
}
Response
{
"id": "id",
"created_at": 0,
"metadata": {
"foo": "string"
},
"object": "thread",
"tool_resources": {
"code_interpreter": {
"file_ids": [
"string"
]
},
"file_search": {
"vector_store_ids": [
"string"
]
}
}
}
Create thread and run
Run beta().threads().createAndRun(ThreadCreateAndRunParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
post /threads/runs
Create a thread and run it in one request.
Parameters
-
ThreadCreateAndRunParams params-
String assistantIdThe ID of the assistant to use to execute this run.
-
Optional<String> instructionsOverride the default system message of the assistant. This is useful for modifying the behavior on a per-run basis.
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens that may be used over the course of the run. The run will make a best effort to use only the number of completion tokens specified, across multiple turns of the run. If the run exceeds the number of completion tokens specified, the run will end with status
incomplete. Seeincomplete_detailsfor more info. -
Optional<Long> maxPromptTokensThe maximum number of prompt tokens that may be used over the course of the run. The run will make a best effort to use only the number of prompt tokens specified, across multiple turns of the run. If the run exceeds the number of prompt tokens specified, the run will end with status
incomplete. Seeincomplete_detailsfor more info. -
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
Optional<ChatModel> modelThe ID of the Model to be used to execute this run. If a value is provided here, it will override the model associated with the assistant. If not, the model associated with the assistant will be used.
-
Optional<Boolean> parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length. -
Optional<Double> temperatureWhat sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic.
-
Optional<Thread> threadOptions to create a new thread. If no thread is provided when running a request, an empty thread will be created.
-
Optional<List<Message>> messagesA list of messages to start the thread with.
-
Content contentThe text contents of the message.
-
String -
List<MessageContentPartParam>-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlockParam:The text content that is part of a message.
-
String textText content to be sent to the model
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
-
-
Role roleThe role of the entity that is creating the message. Allowed values include:
-
user: Indicates the message is sent by an actual user and should be used in most cases to represent user-generated messages. -
assistant: Indicates the message is generated by the assistant. Use this value to insert messages from the assistant into the conversation. -
USER("user") -
ASSISTANT("assistant")
-
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they should be added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
Optional<ToolResources> toolResourcesA set of resources that are made available to the assistant's tools in this thread. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe vector store attached to this thread. There can be a maximum of 1 vector store attached to the thread.
-
Optional<List<VectorStore>> vectorStoresA helper to create a vector store with file_ids and attach it to this thread. There can be a maximum of 1 vector store attached to the thread.
-
Optional<ChunkingStrategy> chunkingStrategyThe chunking strategy used to chunk the file(s). If not set, will use the
autostrategy.-
JsonValue;-
JsonValue; type "auto"constantAlways
auto.AUTO("auto")
-
-
class Static:-
InnerStatic static_-
long chunkOverlapTokensThe number of tokens that overlap between chunks. The default value is
400.Note that the overlap must not exceed half of
max_chunk_size_tokens. -
long maxChunkSizeTokensThe maximum number of tokens in each chunk. The default value is
800. The minimum value is100and the maximum value is4096.
-
-
JsonValue; type "static"constantAlways
static.STATIC("static")
-
-
-
Optional<List<String>> fileIdsA list of file IDs to add to the vector store. For vector stores created before Nov 2025, there can be a maximum of 10,000 files in a vector store. For vector stores created starting in Nov 2025, the limit is 100,000,000 files.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
-
-
-
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool. -
Optional<ToolResources> toolResourcesA set of resources that are used by the assistant's tools. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe ID of the vector store attached to this assistant. There can be a maximum of 1 vector store attached to the assistant.
-
-
-
Optional<List<AssistantTool>> toolsOverride the tools the assistant can use for this run. This is useful for modifying the behavior on a per-run basis.
-
class CodeInterpreterTool: -
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<Double> topPAn alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered.
We generally recommend altering this or temperature but not both.
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Returns
-
class Run:Represents an execution run on a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant used for execution of this run.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run was completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run was created.
-
Optional<Long> expiresAtThe Unix timestamp (in seconds) for when the run will expire.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run failed.
-
Optional<IncompleteDetails> incompleteDetailsDetails on why the run is incomplete. Will be
nullif the run is not incomplete.-
Optional<Reason> reasonThe reason why the run is incomplete. This will point to which specific token limit was reached over the course of the run.
-
MAX_COMPLETION_TOKENS("max_completion_tokens") -
MAX_PROMPT_TOKENS("max_prompt_tokens")
-
-
-
String instructionsThe instructions that the assistant used for this run.
-
Optional<LastError> lastErrorThe last error associated with this run. Will be
nullif there are no errors.-
Code codeOne of
server_error,rate_limit_exceeded, orinvalid_prompt.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded") -
INVALID_PROMPT("invalid_prompt")
-
-
String messageA human-readable description of the error.
-
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens specified to have been used over the course of the run.
-
Optional<Long> maxPromptTokensThe maximum number of prompt tokens specified to have been used over the course of the run.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelThe model that the assistant used for this run.
-
JsonValue; object_ "thread.run"constantThe object type, which is always
thread.run.THREAD_RUN("thread.run")
-
boolean parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<RequiredAction> requiredActionDetails on the action required to continue the run. Will be
nullif no action is required.-
SubmitToolOutputs submitToolOutputsDetails on the tool outputs needed for this run to continue.
-
List<RequiredActionFunctionToolCall> toolCallsA list of the relevant tool calls.
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
-
-
JsonValue; type "submit_tool_outputs"constantFor now, this is always
submit_tool_outputs.SUBMIT_TOOL_OUTPUTS("submit_tool_outputs")
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Long> startedAtThe Unix timestamp (in seconds) for when the run was started.
-
RunStatus statusThe status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
-
String threadIdThe ID of the thread that was executed on as a part of this run.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
-
List<AssistantTool> toolsThe list of tools that the assistant used for this run.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Optional<Usage> usageUsage statistics related to the run. This value will be
nullif the run is not in a terminal state (i.e.in_progress,queued, etc.).-
long completionTokensNumber of completion tokens used over the course of the run.
-
long promptTokensNumber of prompt tokens used over the course of the run.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Optional<Double> temperatureThe sampling temperature used for this run. If not set, defaults to 1.
-
Optional<Double> topPThe nucleus sampling value used for this run. If not set, defaults to 1.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.ThreadCreateAndRunParams;
import com.openai.models.beta.threads.runs.Run;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ThreadCreateAndRunParams params = ThreadCreateAndRunParams.builder()
.assistantId("assistant_id")
.build();
Run run = client.beta().threads().createAndRun(params);
}
}
Response
{
"id": "id",
"assistant_id": "assistant_id",
"cancelled_at": 0,
"completed_at": 0,
"created_at": 0,
"expires_at": 0,
"failed_at": 0,
"incomplete_details": {
"reason": "max_completion_tokens"
},
"instructions": "instructions",
"last_error": {
"code": "server_error",
"message": "message"
},
"max_completion_tokens": 256,
"max_prompt_tokens": 256,
"metadata": {
"foo": "string"
},
"model": "model",
"object": "thread.run",
"parallel_tool_calls": true,
"required_action": {
"submit_tool_outputs": {
"tool_calls": [
{
"id": "id",
"function": {
"arguments": "arguments",
"name": "name"
},
"type": "function"
}
]
},
"type": "submit_tool_outputs"
},
"response_format": "auto",
"started_at": 0,
"status": "queued",
"thread_id": "thread_id",
"tool_choice": "none",
"tools": [
{
"type": "code_interpreter"
}
],
"truncation_strategy": {
"type": "auto",
"last_messages": 1
},
"usage": {
"completion_tokens": 0,
"prompt_tokens": 0,
"total_tokens": 0
},
"temperature": 0,
"top_p": 0
}
Retrieve thread
Thread beta().threads().retrieve(ThreadRetrieveParamsparams = ThreadRetrieveParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
get /threads/{thread_id}
Retrieves a thread.
Parameters
-
ThreadRetrieveParams paramsOptional<String> threadId
Returns
-
class Thread:Represents a thread that contains messages.
-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the thread was created.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread"constantThe object type, which is always
thread.THREAD("thread")
-
Optional<ToolResources> toolResourcesA set of resources that are made available to the assistant's tools in this thread. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe vector store attached to this thread. There can be a maximum of 1 vector store attached to the thread.
-
-
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.Thread;
import com.openai.models.beta.threads.ThreadRetrieveParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
Thread thread = client.beta().threads().retrieve("thread_id");
}
}
Response
{
"id": "id",
"created_at": 0,
"metadata": {
"foo": "string"
},
"object": "thread",
"tool_resources": {
"code_interpreter": {
"file_ids": [
"string"
]
},
"file_search": {
"vector_store_ids": [
"string"
]
}
}
}
Modify thread
Thread beta().threads().update(ThreadUpdateParamsparams = ThreadUpdateParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
post /threads/{thread_id}
Modifies a thread.
Parameters
-
ThreadUpdateParams params-
Optional<String> threadId -
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
Optional<ToolResources> toolResourcesA set of resources that are made available to the assistant's tools in this thread. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe vector store attached to this thread. There can be a maximum of 1 vector store attached to the thread.
-
-
-
Returns
-
class Thread:Represents a thread that contains messages.
-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the thread was created.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread"constantThe object type, which is always
thread.THREAD("thread")
-
Optional<ToolResources> toolResourcesA set of resources that are made available to the assistant's tools in this thread. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe vector store attached to this thread. There can be a maximum of 1 vector store attached to the thread.
-
-
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.Thread;
import com.openai.models.beta.threads.ThreadUpdateParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
Thread thread = client.beta().threads().update("thread_id");
}
}
Response
{
"id": "id",
"created_at": 0,
"metadata": {
"foo": "string"
},
"object": "thread",
"tool_resources": {
"code_interpreter": {
"file_ids": [
"string"
]
},
"file_search": {
"vector_store_ids": [
"string"
]
}
}
}
Delete thread
ThreadDeleted beta().threads().delete(ThreadDeleteParamsparams = ThreadDeleteParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
delete /threads/{thread_id}
Delete a thread.
Parameters
-
ThreadDeleteParams paramsOptional<String> threadId
Returns
-
class ThreadDeleted:-
String id -
boolean deleted -
JsonValue; object_ "thread.deleted"constantTHREAD_DELETED("thread.deleted")
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.ThreadDeleteParams;
import com.openai.models.beta.threads.ThreadDeleted;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ThreadDeleted threadDeleted = client.beta().threads().delete("thread_id");
}
}
Response
{
"id": "id",
"deleted": true,
"object": "thread.deleted"
}
Domain Types
Assistant Response Format Option
-
class AssistantResponseFormatOption: A class that can be one of several variants.unionSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
Assistant Tool Choice
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
Assistant Tool Choice Function
-
class AssistantToolChoiceFunction:-
String nameThe name of the function to call.
-
Assistant Tool Choice Option
-
class AssistantToolChoiceOption: A class that can be one of several variants.unionControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
Thread
-
class Thread:Represents a thread that contains messages.
-
String idThe identifier, which can be referenced in API endpoints.
-
long createdAtThe Unix timestamp (in seconds) for when the thread was created.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread"constantThe object type, which is always
thread.THREAD("thread")
-
Optional<ToolResources> toolResourcesA set of resources that are made available to the assistant's tools in this thread. The resources are specific to the type of tool. For example, the
code_interpretertool requires a list of file IDs, while thefile_searchtool requires a list of vector store IDs.-
Optional<CodeInterpreter> codeInterpreter-
Optional<List<String>> fileIdsA list of file IDs made available to the
code_interpretertool. There can be a maximum of 20 files associated with the tool.
-
-
Optional<FileSearch> fileSearch-
Optional<List<String>> vectorStoreIdsThe vector store attached to this thread. There can be a maximum of 1 vector store attached to the thread.
-
-
-
Thread Deleted
-
class ThreadDeleted:-
String id -
boolean deleted -
JsonValue; object_ "thread.deleted"constantTHREAD_DELETED("thread.deleted")
-
Runs
List runs
RunListPage beta().threads().runs().list(RunListParamsparams = RunListParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
get /threads/{thread_id}/runs
Returns a list of runs belonging to a thread.
Parameters
-
RunListParams params-
Optional<String> threadId -
Optional<String> afterA cursor for use in pagination.
afteris an object ID that defines your place in the list. For instance, if you make a list request and receive 100 objects, ending with obj_foo, your subsequent call can include after=obj_foo in order to fetch the next page of the list. -
Optional<String> beforeA cursor for use in pagination.
beforeis an object ID that defines your place in the list. For instance, if you make a list request and receive 100 objects, starting with obj_foo, your subsequent call can include before=obj_foo in order to fetch the previous page of the list. -
Optional<Long> limitA limit on the number of objects to be returned. Limit can range between 1 and 100, and the default is 20.
-
Optional<Order> orderSort order by the
created_attimestamp of the objects.ascfor ascending order anddescfor descending order.-
ASC("asc") -
DESC("desc")
-
-
Returns
-
class Run:Represents an execution run on a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant used for execution of this run.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run was completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run was created.
-
Optional<Long> expiresAtThe Unix timestamp (in seconds) for when the run will expire.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run failed.
-
Optional<IncompleteDetails> incompleteDetailsDetails on why the run is incomplete. Will be
nullif the run is not incomplete.-
Optional<Reason> reasonThe reason why the run is incomplete. This will point to which specific token limit was reached over the course of the run.
-
MAX_COMPLETION_TOKENS("max_completion_tokens") -
MAX_PROMPT_TOKENS("max_prompt_tokens")
-
-
-
String instructionsThe instructions that the assistant used for this run.
-
Optional<LastError> lastErrorThe last error associated with this run. Will be
nullif there are no errors.-
Code codeOne of
server_error,rate_limit_exceeded, orinvalid_prompt.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded") -
INVALID_PROMPT("invalid_prompt")
-
-
String messageA human-readable description of the error.
-
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens specified to have been used over the course of the run.
-
Optional<Long> maxPromptTokensThe maximum number of prompt tokens specified to have been used over the course of the run.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelThe model that the assistant used for this run.
-
JsonValue; object_ "thread.run"constantThe object type, which is always
thread.run.THREAD_RUN("thread.run")
-
boolean parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<RequiredAction> requiredActionDetails on the action required to continue the run. Will be
nullif no action is required.-
SubmitToolOutputs submitToolOutputsDetails on the tool outputs needed for this run to continue.
-
List<RequiredActionFunctionToolCall> toolCallsA list of the relevant tool calls.
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
-
-
JsonValue; type "submit_tool_outputs"constantFor now, this is always
submit_tool_outputs.SUBMIT_TOOL_OUTPUTS("submit_tool_outputs")
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Long> startedAtThe Unix timestamp (in seconds) for when the run was started.
-
RunStatus statusThe status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
-
String threadIdThe ID of the thread that was executed on as a part of this run.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
-
List<AssistantTool> toolsThe list of tools that the assistant used for this run.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Optional<Usage> usageUsage statistics related to the run. This value will be
nullif the run is not in a terminal state (i.e.in_progress,queued, etc.).-
long completionTokensNumber of completion tokens used over the course of the run.
-
long promptTokensNumber of prompt tokens used over the course of the run.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Optional<Double> temperatureThe sampling temperature used for this run. If not set, defaults to 1.
-
Optional<Double> topPThe nucleus sampling value used for this run. If not set, defaults to 1.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.runs.RunListPage;
import com.openai.models.beta.threads.runs.RunListParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
RunListPage page = client.beta().threads().runs().list("thread_id");
}
}
Response
{
"data": [
{
"id": "id",
"assistant_id": "assistant_id",
"cancelled_at": 0,
"completed_at": 0,
"created_at": 0,
"expires_at": 0,
"failed_at": 0,
"incomplete_details": {
"reason": "max_completion_tokens"
},
"instructions": "instructions",
"last_error": {
"code": "server_error",
"message": "message"
},
"max_completion_tokens": 256,
"max_prompt_tokens": 256,
"metadata": {
"foo": "string"
},
"model": "model",
"object": "thread.run",
"parallel_tool_calls": true,
"required_action": {
"submit_tool_outputs": {
"tool_calls": [
{
"id": "id",
"function": {
"arguments": "arguments",
"name": "name"
},
"type": "function"
}
]
},
"type": "submit_tool_outputs"
},
"response_format": "auto",
"started_at": 0,
"status": "queued",
"thread_id": "thread_id",
"tool_choice": "none",
"tools": [
{
"type": "code_interpreter"
}
],
"truncation_strategy": {
"type": "auto",
"last_messages": 1
},
"usage": {
"completion_tokens": 0,
"prompt_tokens": 0,
"total_tokens": 0
},
"temperature": 0,
"top_p": 0
}
],
"first_id": "run_abc123",
"has_more": false,
"last_id": "run_abc456",
"object": "list"
}
Create run
Run beta().threads().runs().create(RunCreateParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
post /threads/{thread_id}/runs
Create a run.
Parameters
-
RunCreateParams params-
Optional<String> threadId -
Optional<List<RunStepInclude>> includeA list of additional fields to include in the response. Currently the only supported value is
step_details.tool_calls[*].file_search.results[*].contentto fetch the file search result content.See the file search tool documentation for more information.
STEP_DETAILS_TOOL_CALLS_FILE_SEARCH_RESULTS_CONTENT("step_details.tool_calls[*].file_search.results[*].content")
-
String assistantIdThe ID of the assistant to use to execute this run.
-
Optional<String> additionalInstructionsAppends additional instructions at the end of the instructions for the run. This is useful for modifying the behavior on a per-run basis without overriding other instructions.
-
Optional<List<AdditionalMessage>> additionalMessagesAdds additional messages to the thread before creating the run.
-
Content contentThe text contents of the message.
-
String -
List<MessageContentPartParam>-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlockParam:The text content that is part of a message.
-
String textText content to be sent to the model
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
-
-
Role roleThe role of the entity that is creating the message. Allowed values include:
-
user: Indicates the message is sent by an actual user and should be used in most cases to represent user-generated messages. -
assistant: Indicates the message is generated by the assistant. Use this value to insert messages from the assistant into the conversation. -
USER("user") -
ASSISTANT("assistant")
-
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they should be added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
-
Optional<String> instructionsOverrides the instructions of the assistant. This is useful for modifying the behavior on a per-run basis.
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens that may be used over the course of the run. The run will make a best effort to use only the number of completion tokens specified, across multiple turns of the run. If the run exceeds the number of completion tokens specified, the run will end with status
incomplete. Seeincomplete_detailsfor more info. -
Optional<Long> maxPromptTokensThe maximum number of prompt tokens that may be used over the course of the run. The run will make a best effort to use only the number of prompt tokens specified, across multiple turns of the run. If the run exceeds the number of prompt tokens specified, the run will end with status
incomplete. Seeincomplete_detailsfor more info. -
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
Optional<ChatModel> modelThe ID of the Model to be used to execute this run. If a value is provided here, it will override the model associated with the assistant. If not, the model associated with the assistant will be used.
-
Optional<Boolean> parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<ReasoningEffort> reasoningEffortConstrains effort on reasoning for reasoning models. Currently supported values are
none,minimal,low,medium,high, andxhigh. Reducing reasoning effort can result in faster responses and fewer tokens used on reasoning in a response.gpt-5.1defaults tonone, which does not perform reasoning. The supported reasoning values forgpt-5.1arenone,low,medium, andhigh. Tool calls are supported for all reasoning values in gpt-5.1.- All models before
gpt-5.1default tomediumreasoning effort, and do not supportnone. - The
gpt-5-promodel defaults to (and only supports)highreasoning effort. xhighis supported for all models aftergpt-5.1-codex-max.
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length. -
Optional<Double> temperatureWhat sampling temperature to use, between 0 and 2. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool. -
Optional<List<AssistantTool>> toolsOverride the tools the assistant can use for this run. This is useful for modifying the behavior on a per-run basis.
-
class CodeInterpreterTool: -
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<Double> topPAn alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered.
We generally recommend altering this or temperature but not both.
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Returns
-
class Run:Represents an execution run on a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant used for execution of this run.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run was completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run was created.
-
Optional<Long> expiresAtThe Unix timestamp (in seconds) for when the run will expire.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run failed.
-
Optional<IncompleteDetails> incompleteDetailsDetails on why the run is incomplete. Will be
nullif the run is not incomplete.-
Optional<Reason> reasonThe reason why the run is incomplete. This will point to which specific token limit was reached over the course of the run.
-
MAX_COMPLETION_TOKENS("max_completion_tokens") -
MAX_PROMPT_TOKENS("max_prompt_tokens")
-
-
-
String instructionsThe instructions that the assistant used for this run.
-
Optional<LastError> lastErrorThe last error associated with this run. Will be
nullif there are no errors.-
Code codeOne of
server_error,rate_limit_exceeded, orinvalid_prompt.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded") -
INVALID_PROMPT("invalid_prompt")
-
-
String messageA human-readable description of the error.
-
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens specified to have been used over the course of the run.
-
Optional<Long> maxPromptTokensThe maximum number of prompt tokens specified to have been used over the course of the run.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelThe model that the assistant used for this run.
-
JsonValue; object_ "thread.run"constantThe object type, which is always
thread.run.THREAD_RUN("thread.run")
-
boolean parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<RequiredAction> requiredActionDetails on the action required to continue the run. Will be
nullif no action is required.-
SubmitToolOutputs submitToolOutputsDetails on the tool outputs needed for this run to continue.
-
List<RequiredActionFunctionToolCall> toolCallsA list of the relevant tool calls.
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
-
-
JsonValue; type "submit_tool_outputs"constantFor now, this is always
submit_tool_outputs.SUBMIT_TOOL_OUTPUTS("submit_tool_outputs")
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Long> startedAtThe Unix timestamp (in seconds) for when the run was started.
-
RunStatus statusThe status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
-
String threadIdThe ID of the thread that was executed on as a part of this run.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
-
List<AssistantTool> toolsThe list of tools that the assistant used for this run.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Optional<Usage> usageUsage statistics related to the run. This value will be
nullif the run is not in a terminal state (i.e.in_progress,queued, etc.).-
long completionTokensNumber of completion tokens used over the course of the run.
-
long promptTokensNumber of prompt tokens used over the course of the run.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Optional<Double> temperatureThe sampling temperature used for this run. If not set, defaults to 1.
-
Optional<Double> topPThe nucleus sampling value used for this run. If not set, defaults to 1.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.runs.Run;
import com.openai.models.beta.threads.runs.RunCreateParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
RunCreateParams params = RunCreateParams.builder()
.threadId("thread_id")
.assistantId("assistant_id")
.build();
Run run = client.beta().threads().runs().create(params);
}
}
Response
{
"id": "id",
"assistant_id": "assistant_id",
"cancelled_at": 0,
"completed_at": 0,
"created_at": 0,
"expires_at": 0,
"failed_at": 0,
"incomplete_details": {
"reason": "max_completion_tokens"
},
"instructions": "instructions",
"last_error": {
"code": "server_error",
"message": "message"
},
"max_completion_tokens": 256,
"max_prompt_tokens": 256,
"metadata": {
"foo": "string"
},
"model": "model",
"object": "thread.run",
"parallel_tool_calls": true,
"required_action": {
"submit_tool_outputs": {
"tool_calls": [
{
"id": "id",
"function": {
"arguments": "arguments",
"name": "name"
},
"type": "function"
}
]
},
"type": "submit_tool_outputs"
},
"response_format": "auto",
"started_at": 0,
"status": "queued",
"thread_id": "thread_id",
"tool_choice": "none",
"tools": [
{
"type": "code_interpreter"
}
],
"truncation_strategy": {
"type": "auto",
"last_messages": 1
},
"usage": {
"completion_tokens": 0,
"prompt_tokens": 0,
"total_tokens": 0
},
"temperature": 0,
"top_p": 0
}
Retrieve run
Run beta().threads().runs().retrieve(RunRetrieveParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
get /threads/{thread_id}/runs/{run_id}
Retrieves a run.
Parameters
-
RunRetrieveParams params-
String threadId -
Optional<String> runId
-
Returns
-
class Run:Represents an execution run on a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant used for execution of this run.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run was completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run was created.
-
Optional<Long> expiresAtThe Unix timestamp (in seconds) for when the run will expire.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run failed.
-
Optional<IncompleteDetails> incompleteDetailsDetails on why the run is incomplete. Will be
nullif the run is not incomplete.-
Optional<Reason> reasonThe reason why the run is incomplete. This will point to which specific token limit was reached over the course of the run.
-
MAX_COMPLETION_TOKENS("max_completion_tokens") -
MAX_PROMPT_TOKENS("max_prompt_tokens")
-
-
-
String instructionsThe instructions that the assistant used for this run.
-
Optional<LastError> lastErrorThe last error associated with this run. Will be
nullif there are no errors.-
Code codeOne of
server_error,rate_limit_exceeded, orinvalid_prompt.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded") -
INVALID_PROMPT("invalid_prompt")
-
-
String messageA human-readable description of the error.
-
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens specified to have been used over the course of the run.
-
Optional<Long> maxPromptTokensThe maximum number of prompt tokens specified to have been used over the course of the run.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelThe model that the assistant used for this run.
-
JsonValue; object_ "thread.run"constantThe object type, which is always
thread.run.THREAD_RUN("thread.run")
-
boolean parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<RequiredAction> requiredActionDetails on the action required to continue the run. Will be
nullif no action is required.-
SubmitToolOutputs submitToolOutputsDetails on the tool outputs needed for this run to continue.
-
List<RequiredActionFunctionToolCall> toolCallsA list of the relevant tool calls.
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
-
-
JsonValue; type "submit_tool_outputs"constantFor now, this is always
submit_tool_outputs.SUBMIT_TOOL_OUTPUTS("submit_tool_outputs")
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Long> startedAtThe Unix timestamp (in seconds) for when the run was started.
-
RunStatus statusThe status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
-
String threadIdThe ID of the thread that was executed on as a part of this run.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
-
List<AssistantTool> toolsThe list of tools that the assistant used for this run.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Optional<Usage> usageUsage statistics related to the run. This value will be
nullif the run is not in a terminal state (i.e.in_progress,queued, etc.).-
long completionTokensNumber of completion tokens used over the course of the run.
-
long promptTokensNumber of prompt tokens used over the course of the run.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Optional<Double> temperatureThe sampling temperature used for this run. If not set, defaults to 1.
-
Optional<Double> topPThe nucleus sampling value used for this run. If not set, defaults to 1.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.runs.Run;
import com.openai.models.beta.threads.runs.RunRetrieveParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
RunRetrieveParams params = RunRetrieveParams.builder()
.threadId("thread_id")
.runId("run_id")
.build();
Run run = client.beta().threads().runs().retrieve(params);
}
}
Response
{
"id": "id",
"assistant_id": "assistant_id",
"cancelled_at": 0,
"completed_at": 0,
"created_at": 0,
"expires_at": 0,
"failed_at": 0,
"incomplete_details": {
"reason": "max_completion_tokens"
},
"instructions": "instructions",
"last_error": {
"code": "server_error",
"message": "message"
},
"max_completion_tokens": 256,
"max_prompt_tokens": 256,
"metadata": {
"foo": "string"
},
"model": "model",
"object": "thread.run",
"parallel_tool_calls": true,
"required_action": {
"submit_tool_outputs": {
"tool_calls": [
{
"id": "id",
"function": {
"arguments": "arguments",
"name": "name"
},
"type": "function"
}
]
},
"type": "submit_tool_outputs"
},
"response_format": "auto",
"started_at": 0,
"status": "queued",
"thread_id": "thread_id",
"tool_choice": "none",
"tools": [
{
"type": "code_interpreter"
}
],
"truncation_strategy": {
"type": "auto",
"last_messages": 1
},
"usage": {
"completion_tokens": 0,
"prompt_tokens": 0,
"total_tokens": 0
},
"temperature": 0,
"top_p": 0
}
Modify run
Run beta().threads().runs().update(RunUpdateParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
post /threads/{thread_id}/runs/{run_id}
Modifies a run.
Parameters
-
RunUpdateParams params-
String threadId -
Optional<String> runId -
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
Returns
-
class Run:Represents an execution run on a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant used for execution of this run.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run was completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run was created.
-
Optional<Long> expiresAtThe Unix timestamp (in seconds) for when the run will expire.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run failed.
-
Optional<IncompleteDetails> incompleteDetailsDetails on why the run is incomplete. Will be
nullif the run is not incomplete.-
Optional<Reason> reasonThe reason why the run is incomplete. This will point to which specific token limit was reached over the course of the run.
-
MAX_COMPLETION_TOKENS("max_completion_tokens") -
MAX_PROMPT_TOKENS("max_prompt_tokens")
-
-
-
String instructionsThe instructions that the assistant used for this run.
-
Optional<LastError> lastErrorThe last error associated with this run. Will be
nullif there are no errors.-
Code codeOne of
server_error,rate_limit_exceeded, orinvalid_prompt.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded") -
INVALID_PROMPT("invalid_prompt")
-
-
String messageA human-readable description of the error.
-
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens specified to have been used over the course of the run.
-
Optional<Long> maxPromptTokensThe maximum number of prompt tokens specified to have been used over the course of the run.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelThe model that the assistant used for this run.
-
JsonValue; object_ "thread.run"constantThe object type, which is always
thread.run.THREAD_RUN("thread.run")
-
boolean parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<RequiredAction> requiredActionDetails on the action required to continue the run. Will be
nullif no action is required.-
SubmitToolOutputs submitToolOutputsDetails on the tool outputs needed for this run to continue.
-
List<RequiredActionFunctionToolCall> toolCallsA list of the relevant tool calls.
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
-
-
JsonValue; type "submit_tool_outputs"constantFor now, this is always
submit_tool_outputs.SUBMIT_TOOL_OUTPUTS("submit_tool_outputs")
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Long> startedAtThe Unix timestamp (in seconds) for when the run was started.
-
RunStatus statusThe status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
-
String threadIdThe ID of the thread that was executed on as a part of this run.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
-
List<AssistantTool> toolsThe list of tools that the assistant used for this run.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Optional<Usage> usageUsage statistics related to the run. This value will be
nullif the run is not in a terminal state (i.e.in_progress,queued, etc.).-
long completionTokensNumber of completion tokens used over the course of the run.
-
long promptTokensNumber of prompt tokens used over the course of the run.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Optional<Double> temperatureThe sampling temperature used for this run. If not set, defaults to 1.
-
Optional<Double> topPThe nucleus sampling value used for this run. If not set, defaults to 1.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.runs.Run;
import com.openai.models.beta.threads.runs.RunUpdateParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
RunUpdateParams params = RunUpdateParams.builder()
.threadId("thread_id")
.runId("run_id")
.build();
Run run = client.beta().threads().runs().update(params);
}
}
Response
{
"id": "id",
"assistant_id": "assistant_id",
"cancelled_at": 0,
"completed_at": 0,
"created_at": 0,
"expires_at": 0,
"failed_at": 0,
"incomplete_details": {
"reason": "max_completion_tokens"
},
"instructions": "instructions",
"last_error": {
"code": "server_error",
"message": "message"
},
"max_completion_tokens": 256,
"max_prompt_tokens": 256,
"metadata": {
"foo": "string"
},
"model": "model",
"object": "thread.run",
"parallel_tool_calls": true,
"required_action": {
"submit_tool_outputs": {
"tool_calls": [
{
"id": "id",
"function": {
"arguments": "arguments",
"name": "name"
},
"type": "function"
}
]
},
"type": "submit_tool_outputs"
},
"response_format": "auto",
"started_at": 0,
"status": "queued",
"thread_id": "thread_id",
"tool_choice": "none",
"tools": [
{
"type": "code_interpreter"
}
],
"truncation_strategy": {
"type": "auto",
"last_messages": 1
},
"usage": {
"completion_tokens": 0,
"prompt_tokens": 0,
"total_tokens": 0
},
"temperature": 0,
"top_p": 0
}
Submit tool outputs to run
Run beta().threads().runs().submitToolOutputs(RunSubmitToolOutputsParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
post /threads/{thread_id}/runs/{run_id}/submit_tool_outputs
When a run has the status: "requires_action" and required_action.type is submit_tool_outputs, this endpoint can be used to submit the outputs from the tool calls once they're all completed. All outputs must be submitted in a single request.
Parameters
-
RunSubmitToolOutputsParams params-
String threadId -
Optional<String> runId -
List<ToolOutput> toolOutputsA list of tools for which the outputs are being submitted.
-
Optional<String> outputThe output of the tool call to be submitted to continue the run.
-
Optional<String> toolCallIdThe ID of the tool call in the
required_actionobject within the run object the output is being submitted for.
-
-
Returns
-
class Run:Represents an execution run on a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant used for execution of this run.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run was completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run was created.
-
Optional<Long> expiresAtThe Unix timestamp (in seconds) for when the run will expire.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run failed.
-
Optional<IncompleteDetails> incompleteDetailsDetails on why the run is incomplete. Will be
nullif the run is not incomplete.-
Optional<Reason> reasonThe reason why the run is incomplete. This will point to which specific token limit was reached over the course of the run.
-
MAX_COMPLETION_TOKENS("max_completion_tokens") -
MAX_PROMPT_TOKENS("max_prompt_tokens")
-
-
-
String instructionsThe instructions that the assistant used for this run.
-
Optional<LastError> lastErrorThe last error associated with this run. Will be
nullif there are no errors.-
Code codeOne of
server_error,rate_limit_exceeded, orinvalid_prompt.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded") -
INVALID_PROMPT("invalid_prompt")
-
-
String messageA human-readable description of the error.
-
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens specified to have been used over the course of the run.
-
Optional<Long> maxPromptTokensThe maximum number of prompt tokens specified to have been used over the course of the run.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelThe model that the assistant used for this run.
-
JsonValue; object_ "thread.run"constantThe object type, which is always
thread.run.THREAD_RUN("thread.run")
-
boolean parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<RequiredAction> requiredActionDetails on the action required to continue the run. Will be
nullif no action is required.-
SubmitToolOutputs submitToolOutputsDetails on the tool outputs needed for this run to continue.
-
List<RequiredActionFunctionToolCall> toolCallsA list of the relevant tool calls.
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
-
-
JsonValue; type "submit_tool_outputs"constantFor now, this is always
submit_tool_outputs.SUBMIT_TOOL_OUTPUTS("submit_tool_outputs")
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Long> startedAtThe Unix timestamp (in seconds) for when the run was started.
-
RunStatus statusThe status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
-
String threadIdThe ID of the thread that was executed on as a part of this run.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
-
List<AssistantTool> toolsThe list of tools that the assistant used for this run.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Optional<Usage> usageUsage statistics related to the run. This value will be
nullif the run is not in a terminal state (i.e.in_progress,queued, etc.).-
long completionTokensNumber of completion tokens used over the course of the run.
-
long promptTokensNumber of prompt tokens used over the course of the run.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Optional<Double> temperatureThe sampling temperature used for this run. If not set, defaults to 1.
-
Optional<Double> topPThe nucleus sampling value used for this run. If not set, defaults to 1.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.runs.Run;
import com.openai.models.beta.threads.runs.RunSubmitToolOutputsParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
RunSubmitToolOutputsParams params = RunSubmitToolOutputsParams.builder()
.threadId("thread_id")
.runId("run_id")
.addToolOutput(RunSubmitToolOutputsParams.ToolOutput.builder().build())
.build();
Run run = client.beta().threads().runs().submitToolOutputs(params);
}
}
Response
{
"id": "id",
"assistant_id": "assistant_id",
"cancelled_at": 0,
"completed_at": 0,
"created_at": 0,
"expires_at": 0,
"failed_at": 0,
"incomplete_details": {
"reason": "max_completion_tokens"
},
"instructions": "instructions",
"last_error": {
"code": "server_error",
"message": "message"
},
"max_completion_tokens": 256,
"max_prompt_tokens": 256,
"metadata": {
"foo": "string"
},
"model": "model",
"object": "thread.run",
"parallel_tool_calls": true,
"required_action": {
"submit_tool_outputs": {
"tool_calls": [
{
"id": "id",
"function": {
"arguments": "arguments",
"name": "name"
},
"type": "function"
}
]
},
"type": "submit_tool_outputs"
},
"response_format": "auto",
"started_at": 0,
"status": "queued",
"thread_id": "thread_id",
"tool_choice": "none",
"tools": [
{
"type": "code_interpreter"
}
],
"truncation_strategy": {
"type": "auto",
"last_messages": 1
},
"usage": {
"completion_tokens": 0,
"prompt_tokens": 0,
"total_tokens": 0
},
"temperature": 0,
"top_p": 0
}
Cancel a run
Run beta().threads().runs().cancel(RunCancelParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
post /threads/{thread_id}/runs/{run_id}/cancel
Cancels a run that is in_progress.
Parameters
-
RunCancelParams params-
String threadId -
Optional<String> runId
-
Returns
-
class Run:Represents an execution run on a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant used for execution of this run.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run was completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run was created.
-
Optional<Long> expiresAtThe Unix timestamp (in seconds) for when the run will expire.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run failed.
-
Optional<IncompleteDetails> incompleteDetailsDetails on why the run is incomplete. Will be
nullif the run is not incomplete.-
Optional<Reason> reasonThe reason why the run is incomplete. This will point to which specific token limit was reached over the course of the run.
-
MAX_COMPLETION_TOKENS("max_completion_tokens") -
MAX_PROMPT_TOKENS("max_prompt_tokens")
-
-
-
String instructionsThe instructions that the assistant used for this run.
-
Optional<LastError> lastErrorThe last error associated with this run. Will be
nullif there are no errors.-
Code codeOne of
server_error,rate_limit_exceeded, orinvalid_prompt.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded") -
INVALID_PROMPT("invalid_prompt")
-
-
String messageA human-readable description of the error.
-
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens specified to have been used over the course of the run.
-
Optional<Long> maxPromptTokensThe maximum number of prompt tokens specified to have been used over the course of the run.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelThe model that the assistant used for this run.
-
JsonValue; object_ "thread.run"constantThe object type, which is always
thread.run.THREAD_RUN("thread.run")
-
boolean parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<RequiredAction> requiredActionDetails on the action required to continue the run. Will be
nullif no action is required.-
SubmitToolOutputs submitToolOutputsDetails on the tool outputs needed for this run to continue.
-
List<RequiredActionFunctionToolCall> toolCallsA list of the relevant tool calls.
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
-
-
JsonValue; type "submit_tool_outputs"constantFor now, this is always
submit_tool_outputs.SUBMIT_TOOL_OUTPUTS("submit_tool_outputs")
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Long> startedAtThe Unix timestamp (in seconds) for when the run was started.
-
RunStatus statusThe status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
-
String threadIdThe ID of the thread that was executed on as a part of this run.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
-
List<AssistantTool> toolsThe list of tools that the assistant used for this run.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Optional<Usage> usageUsage statistics related to the run. This value will be
nullif the run is not in a terminal state (i.e.in_progress,queued, etc.).-
long completionTokensNumber of completion tokens used over the course of the run.
-
long promptTokensNumber of prompt tokens used over the course of the run.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Optional<Double> temperatureThe sampling temperature used for this run. If not set, defaults to 1.
-
Optional<Double> topPThe nucleus sampling value used for this run. If not set, defaults to 1.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.runs.Run;
import com.openai.models.beta.threads.runs.RunCancelParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
RunCancelParams params = RunCancelParams.builder()
.threadId("thread_id")
.runId("run_id")
.build();
Run run = client.beta().threads().runs().cancel(params);
}
}
Response
{
"id": "id",
"assistant_id": "assistant_id",
"cancelled_at": 0,
"completed_at": 0,
"created_at": 0,
"expires_at": 0,
"failed_at": 0,
"incomplete_details": {
"reason": "max_completion_tokens"
},
"instructions": "instructions",
"last_error": {
"code": "server_error",
"message": "message"
},
"max_completion_tokens": 256,
"max_prompt_tokens": 256,
"metadata": {
"foo": "string"
},
"model": "model",
"object": "thread.run",
"parallel_tool_calls": true,
"required_action": {
"submit_tool_outputs": {
"tool_calls": [
{
"id": "id",
"function": {
"arguments": "arguments",
"name": "name"
},
"type": "function"
}
]
},
"type": "submit_tool_outputs"
},
"response_format": "auto",
"started_at": 0,
"status": "queued",
"thread_id": "thread_id",
"tool_choice": "none",
"tools": [
{
"type": "code_interpreter"
}
],
"truncation_strategy": {
"type": "auto",
"last_messages": 1
},
"usage": {
"completion_tokens": 0,
"prompt_tokens": 0,
"total_tokens": 0
},
"temperature": 0,
"top_p": 0
}
Domain Types
Required Action Function Tool Call
-
class RequiredActionFunctionToolCall:Tool call objects
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
Run
-
class Run:Represents an execution run on a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant used for execution of this run.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run was completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run was created.
-
Optional<Long> expiresAtThe Unix timestamp (in seconds) for when the run will expire.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run failed.
-
Optional<IncompleteDetails> incompleteDetailsDetails on why the run is incomplete. Will be
nullif the run is not incomplete.-
Optional<Reason> reasonThe reason why the run is incomplete. This will point to which specific token limit was reached over the course of the run.
-
MAX_COMPLETION_TOKENS("max_completion_tokens") -
MAX_PROMPT_TOKENS("max_prompt_tokens")
-
-
-
String instructionsThe instructions that the assistant used for this run.
-
Optional<LastError> lastErrorThe last error associated with this run. Will be
nullif there are no errors.-
Code codeOne of
server_error,rate_limit_exceeded, orinvalid_prompt.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded") -
INVALID_PROMPT("invalid_prompt")
-
-
String messageA human-readable description of the error.
-
-
Optional<Long> maxCompletionTokensThe maximum number of completion tokens specified to have been used over the course of the run.
-
Optional<Long> maxPromptTokensThe maximum number of prompt tokens specified to have been used over the course of the run.
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
String modelThe model that the assistant used for this run.
-
JsonValue; object_ "thread.run"constantThe object type, which is always
thread.run.THREAD_RUN("thread.run")
-
boolean parallelToolCallsWhether to enable parallel function calling during tool use.
-
Optional<RequiredAction> requiredActionDetails on the action required to continue the run. Will be
nullif no action is required.-
SubmitToolOutputs submitToolOutputsDetails on the tool outputs needed for this run to continue.
-
List<RequiredActionFunctionToolCall> toolCallsA list of the relevant tool calls.
-
String idThe ID of the tool call. This ID must be referenced when you submit the tool outputs in using the Submit tool outputs to run endpoint.
-
Function functionThe function definition.
-
String argumentsThe arguments that the model expects you to pass to the function.
-
String nameThe name of the function.
-
-
JsonValue; type "function"constantThe type of tool call the output is required for. For now, this is always
function.FUNCTION("function")
-
-
-
JsonValue; type "submit_tool_outputs"constantFor now, this is always
submit_tool_outputs.SUBMIT_TOOL_OUTPUTS("submit_tool_outputs")
-
-
Optional<AssistantResponseFormatOption> responseFormatSpecifies the format that the model must output. Compatible with GPT-4o, GPT-4 Turbo, and all GPT-3.5 Turbo models since
gpt-3.5-turbo-1106.Setting to
{ "type": "json_schema", "json_schema": {...} }enables Structured Outputs which ensures the model will match your supplied JSON schema. Learn more in the Structured Outputs guide.Setting to
{ "type": "json_object" }enables JSON mode, which ensures the message the model generates is valid JSON.Important: when using JSON mode, you must also instruct the model to produce JSON yourself via a system or user message. Without this, the model may generate an unending stream of whitespace until the generation reaches the token limit, resulting in a long-running and seemingly "stuck" request. Also note that the message content may be partially cut off if
finish_reason="length", which indicates the generation exceededmax_tokensor the conversation exceeded the max context length.-
JsonValue;AUTO("auto")
-
class ResponseFormatText:Default response format. Used to generate text responses.
-
JsonValue; type "text"constantThe type of response format being defined. Always
text.TEXT("text")
-
-
class ResponseFormatJsonObject:JSON object response format. An older method of generating JSON responses. Using
json_schemais recommended for models that support it. Note that the model will not generate JSON without a system or user message instructing it to do so.-
JsonValue; type "json_object"constantThe type of response format being defined. Always
json_object.JSON_OBJECT("json_object")
-
-
class ResponseFormatJsonSchema:JSON Schema response format. Used to generate structured JSON responses. Learn more about Structured Outputs.
-
JsonSchema jsonSchemaStructured Outputs configuration options, including a JSON Schema.
-
String nameThe name of the response format. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the response format is for, used by the model to determine how to respond in the format.
-
Optional<Schema> schemaThe schema for the response format, described as a JSON Schema object. Learn how to build JSON schemas here.
-
Optional<Boolean> strictWhether to enable strict schema adherence when generating the output. If set to true, the model will always follow the exact schema defined in the
schemafield. Only a subset of JSON Schema is supported whenstrictistrue. To learn more, read the Structured Outputs guide.
-
-
JsonValue; type "json_schema"constantThe type of response format being defined. Always
json_schema.JSON_SCHEMA("json_schema")
-
-
-
Optional<Long> startedAtThe Unix timestamp (in seconds) for when the run was started.
-
RunStatus statusThe status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
-
String threadIdThe ID of the thread that was executed on as a part of this run.
-
Optional<AssistantToolChoiceOption> toolChoiceControls which (if any) tool is called by the model.
nonemeans the model will not call any tools and instead generates a message.autois the default value and means the model can pick between generating a message or calling one or more tools.requiredmeans the model must call one or more tools before responding to the user. Specifying a particular tool like{"type": "file_search"}or{"type": "function", "function": {"name": "my_function"}}forces the model to call that tool.-
Auto-
NONE("none") -
AUTO("auto") -
REQUIRED("required")
-
-
class AssistantToolChoice:Specifies a tool the model should use. Use to force the model to call a specific tool.
-
Type typeThe type of the tool. If type is
function, the function name must be set-
FUNCTION("function") -
CODE_INTERPRETER("code_interpreter") -
FILE_SEARCH("file_search")
-
-
Optional<AssistantToolChoiceFunction> function-
String nameThe name of the function to call.
-
-
-
-
List<AssistantTool> toolsThe list of tools that the assistant used for this run.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
class FileSearchTool:-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
Optional<FileSearch> fileSearchOverrides for the file search tool.
-
Optional<Long> maxNumResultsThe maximum number of results the file search tool should output. The default is 20 for
gpt-4*models and 5 forgpt-3.5-turbo. This number should be between 1 and 50 inclusive.Note that the file search tool may output fewer than
max_num_resultsresults. See the file search tool documentation for more information. -
Optional<RankingOptions> rankingOptionsThe ranking options for the file search. If not specified, the file search tool will use the
autoranker and a score_threshold of 0.See the file search tool documentation for more information.
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
Optional<Ranker> rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
-
-
-
class FunctionTool:-
FunctionDefinition function-
String nameThe name of the function to be called. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 64.
-
Optional<String> descriptionA description of what the function does, used by the model to choose when and how to call the function.
-
Optional<FunctionParameters> parametersThe parameters the functions accepts, described as a JSON Schema object. See the guide for examples, and the JSON Schema reference for documentation about the format.
Omitting
parametersdefines a function with an empty parameter list. -
Optional<Boolean> strictWhether to enable strict schema adherence when generating the function call. If set to true, the model will follow the exact schema defined in the
parametersfield. Only a subset of JSON Schema is supported whenstrictistrue. Learn more about Structured Outputs in the function calling guide.
-
-
JsonValue; type "function"constantThe type of tool being defined:
functionFUNCTION("function")
-
-
-
Optional<TruncationStrategy> truncationStrategyControls for how a thread will be truncated prior to the run. Use this to control the initial context window of the run.
-
Type typeThe truncation strategy to use for the thread. The default is
auto. If set tolast_messages, the thread will be truncated to the n most recent messages in the thread. When set toauto, messages in the middle of the thread will be dropped to fit the context length of the model,max_prompt_tokens.-
AUTO("auto") -
LAST_MESSAGES("last_messages")
-
-
Optional<Long> lastMessagesThe number of most recent messages from the thread when constructing the context for the run.
-
-
Optional<Usage> usageUsage statistics related to the run. This value will be
nullif the run is not in a terminal state (i.e.in_progress,queued, etc.).-
long completionTokensNumber of completion tokens used over the course of the run.
-
long promptTokensNumber of prompt tokens used over the course of the run.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Optional<Double> temperatureThe sampling temperature used for this run. If not set, defaults to 1.
-
Optional<Double> topPThe nucleus sampling value used for this run. If not set, defaults to 1.
-
Run Status
-
enum RunStatus:The status of the run, which can be either
queued,in_progress,requires_action,cancelling,cancelled,failed,completed,incomplete, orexpired.-
QUEUED("queued") -
IN_PROGRESS("in_progress") -
REQUIRES_ACTION("requires_action") -
CANCELLING("cancelling") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
EXPIRED("expired")
-
Steps
List run steps
StepListPage beta().threads().runs().steps().list(StepListParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
get /threads/{thread_id}/runs/{run_id}/steps
Returns a list of run steps belonging to a run.
Parameters
-
StepListParams params-
String threadId -
Optional<String> runId -
Optional<String> afterA cursor for use in pagination.
afteris an object ID that defines your place in the list. For instance, if you make a list request and receive 100 objects, ending with obj_foo, your subsequent call can include after=obj_foo in order to fetch the next page of the list. -
Optional<String> beforeA cursor for use in pagination.
beforeis an object ID that defines your place in the list. For instance, if you make a list request and receive 100 objects, starting with obj_foo, your subsequent call can include before=obj_foo in order to fetch the previous page of the list. -
Optional<List<RunStepInclude>> includeA list of additional fields to include in the response. Currently the only supported value is
step_details.tool_calls[*].file_search.results[*].contentto fetch the file search result content.See the file search tool documentation for more information.
STEP_DETAILS_TOOL_CALLS_FILE_SEARCH_RESULTS_CONTENT("step_details.tool_calls[*].file_search.results[*].content")
-
Optional<Long> limitA limit on the number of objects to be returned. Limit can range between 1 and 100, and the default is 20.
-
Optional<Order> orderSort order by the
created_attimestamp of the objects.ascfor ascending order anddescfor descending order.-
ASC("asc") -
DESC("desc")
-
-
Returns
-
class RunStep:Represents a step in execution of a run.
-
String idThe identifier of the run step, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant associated with the run step.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run step was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run step completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run step was created.
-
Optional<Long> expiredAtThe Unix timestamp (in seconds) for when the run step expired. A step is considered expired if the parent run is expired.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run step failed.
-
Optional<LastError> lastErrorThe last error associated with this run step. Will be
nullif there are no errors.-
Code codeOne of
server_errororrate_limit_exceeded.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded")
-
-
String messageA human-readable description of the error.
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.run.step"constantThe object type, which is always
thread.run.step.THREAD_RUN_STEP("thread.run.step")
-
String runIdThe ID of the run that this run step is a part of.
-
Status statusThe status of the run step, which can be either
in_progress,cancelled,failed,completed, orexpired.-
IN_PROGRESS("in_progress") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
EXPIRED("expired")
-
-
StepDetails stepDetailsThe details of the run step.
-
class MessageCreationStepDetails:Details of the message creation by the run step.
-
MessageCreation messageCreation-
String messageIdThe ID of the message that was created by this run step.
-
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
-
class ToolCallsStepDetails:Details of the tool call.
-
List<ToolCall> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCall:Details of the Code Interpreter tool call the run step was involved in.
-
String idThe ID of the tool call.
-
CodeInterpreter codeInterpreterThe Code Interpreter tool call definition.
-
String inputThe input to the Code Interpreter tool call.
-
List<Output> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class LogsOutput:Text output from the Code Interpreter tool call as part of a run step.
-
String logsThe text output from the Code Interpreter tool call.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
-
class ImageOutput:-
Image image-
String fileIdThe file ID of the image.
-
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
-
-
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
-
class FileSearchToolCall:-
String idThe ID of the tool call object.
-
FileSearch fileSearchFor now, this is always going to be an empty object.
-
Optional<RankingOptions> rankingOptionsThe ranking options for the file search.
-
Ranker rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
-
Optional<List<Result>> resultsThe results of the file search.
-
String fileIdThe ID of the file that result was found in.
-
String fileNameThe name of the file that result was found in.
-
double scoreThe score of the result. All values must be a floating point number between 0 and 1.
-
Optional<List<Content>> contentThe content of the result that was found. The content is only included if requested via the include query parameter.
-
Optional<String> textThe text content of the file.
-
Optional<Type> typeThe type of the content.
TEXT("text")
-
-
-
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
-
class FunctionToolCall:-
String idThe ID of the tool call object.
-
Function functionThe definition of the function that was called.
-
String argumentsThe arguments passed to the function.
-
String nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
-
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
-
-
String threadIdThe ID of the thread that was run.
-
Type typeThe type of run step, which can be either
message_creationortool_calls.-
MESSAGE_CREATION("message_creation") -
TOOL_CALLS("tool_calls")
-
-
Optional<Usage> usageUsage statistics related to the run step. This value will be
nullwhile the run step's status isin_progress.-
long completionTokensNumber of completion tokens used over the course of the run step.
-
long promptTokensNumber of prompt tokens used over the course of the run step.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.runs.steps.StepListPage;
import com.openai.models.beta.threads.runs.steps.StepListParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
StepListParams params = StepListParams.builder()
.threadId("thread_id")
.runId("run_id")
.build();
StepListPage page = client.beta().threads().runs().steps().list(params);
}
}
Response
{
"data": [
{
"id": "id",
"assistant_id": "assistant_id",
"cancelled_at": 0,
"completed_at": 0,
"created_at": 0,
"expired_at": 0,
"failed_at": 0,
"last_error": {
"code": "server_error",
"message": "message"
},
"metadata": {
"foo": "string"
},
"object": "thread.run.step",
"run_id": "run_id",
"status": "in_progress",
"step_details": {
"message_creation": {
"message_id": "message_id"
},
"type": "message_creation"
},
"thread_id": "thread_id",
"type": "message_creation",
"usage": {
"completion_tokens": 0,
"prompt_tokens": 0,
"total_tokens": 0
}
}
],
"first_id": "step_abc123",
"has_more": false,
"last_id": "step_abc456",
"object": "list"
}
Retrieve run step
RunStep beta().threads().runs().steps().retrieve(StepRetrieveParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
get /threads/{thread_id}/runs/{run_id}/steps/{step_id}
Retrieves a run step.
Parameters
-
StepRetrieveParams params-
String threadId -
String runId -
Optional<String> stepId -
Optional<List<RunStepInclude>> includeA list of additional fields to include in the response. Currently the only supported value is
step_details.tool_calls[*].file_search.results[*].contentto fetch the file search result content.See the file search tool documentation for more information.
STEP_DETAILS_TOOL_CALLS_FILE_SEARCH_RESULTS_CONTENT("step_details.tool_calls[*].file_search.results[*].content")
-
Returns
-
class RunStep:Represents a step in execution of a run.
-
String idThe identifier of the run step, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant associated with the run step.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run step was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run step completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run step was created.
-
Optional<Long> expiredAtThe Unix timestamp (in seconds) for when the run step expired. A step is considered expired if the parent run is expired.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run step failed.
-
Optional<LastError> lastErrorThe last error associated with this run step. Will be
nullif there are no errors.-
Code codeOne of
server_errororrate_limit_exceeded.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded")
-
-
String messageA human-readable description of the error.
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.run.step"constantThe object type, which is always
thread.run.step.THREAD_RUN_STEP("thread.run.step")
-
String runIdThe ID of the run that this run step is a part of.
-
Status statusThe status of the run step, which can be either
in_progress,cancelled,failed,completed, orexpired.-
IN_PROGRESS("in_progress") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
EXPIRED("expired")
-
-
StepDetails stepDetailsThe details of the run step.
-
class MessageCreationStepDetails:Details of the message creation by the run step.
-
MessageCreation messageCreation-
String messageIdThe ID of the message that was created by this run step.
-
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
-
class ToolCallsStepDetails:Details of the tool call.
-
List<ToolCall> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCall:Details of the Code Interpreter tool call the run step was involved in.
-
String idThe ID of the tool call.
-
CodeInterpreter codeInterpreterThe Code Interpreter tool call definition.
-
String inputThe input to the Code Interpreter tool call.
-
List<Output> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class LogsOutput:Text output from the Code Interpreter tool call as part of a run step.
-
String logsThe text output from the Code Interpreter tool call.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
-
class ImageOutput:-
Image image-
String fileIdThe file ID of the image.
-
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
-
-
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
-
class FileSearchToolCall:-
String idThe ID of the tool call object.
-
FileSearch fileSearchFor now, this is always going to be an empty object.
-
Optional<RankingOptions> rankingOptionsThe ranking options for the file search.
-
Ranker rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
-
Optional<List<Result>> resultsThe results of the file search.
-
String fileIdThe ID of the file that result was found in.
-
String fileNameThe name of the file that result was found in.
-
double scoreThe score of the result. All values must be a floating point number between 0 and 1.
-
Optional<List<Content>> contentThe content of the result that was found. The content is only included if requested via the include query parameter.
-
Optional<String> textThe text content of the file.
-
Optional<Type> typeThe type of the content.
TEXT("text")
-
-
-
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
-
class FunctionToolCall:-
String idThe ID of the tool call object.
-
Function functionThe definition of the function that was called.
-
String argumentsThe arguments passed to the function.
-
String nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
-
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
-
-
String threadIdThe ID of the thread that was run.
-
Type typeThe type of run step, which can be either
message_creationortool_calls.-
MESSAGE_CREATION("message_creation") -
TOOL_CALLS("tool_calls")
-
-
Optional<Usage> usageUsage statistics related to the run step. This value will be
nullwhile the run step's status isin_progress.-
long completionTokensNumber of completion tokens used over the course of the run step.
-
long promptTokensNumber of prompt tokens used over the course of the run step.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.runs.steps.RunStep;
import com.openai.models.beta.threads.runs.steps.StepRetrieveParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
StepRetrieveParams params = StepRetrieveParams.builder()
.threadId("thread_id")
.runId("run_id")
.stepId("step_id")
.build();
RunStep runStep = client.beta().threads().runs().steps().retrieve(params);
}
}
Response
{
"id": "id",
"assistant_id": "assistant_id",
"cancelled_at": 0,
"completed_at": 0,
"created_at": 0,
"expired_at": 0,
"failed_at": 0,
"last_error": {
"code": "server_error",
"message": "message"
},
"metadata": {
"foo": "string"
},
"object": "thread.run.step",
"run_id": "run_id",
"status": "in_progress",
"step_details": {
"message_creation": {
"message_id": "message_id"
},
"type": "message_creation"
},
"thread_id": "thread_id",
"type": "message_creation",
"usage": {
"completion_tokens": 0,
"prompt_tokens": 0,
"total_tokens": 0
}
}
Domain Types
Code Interpreter Logs
-
class CodeInterpreterLogs:Text output from the Code Interpreter tool call as part of a run step.
-
long indexThe index of the output in the outputs array.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
Optional<String> logsThe text output from the Code Interpreter tool call.
-
Code Interpreter Output Image
-
class CodeInterpreterOutputImage:-
long indexThe index of the output in the outputs array.
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
Optional<Image> image-
Optional<String> fileIdThe file ID of the image.
-
-
Code Interpreter Tool Call
-
class CodeInterpreterToolCall:Details of the Code Interpreter tool call the run step was involved in.
-
String idThe ID of the tool call.
-
CodeInterpreter codeInterpreterThe Code Interpreter tool call definition.
-
String inputThe input to the Code Interpreter tool call.
-
List<Output> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class LogsOutput:Text output from the Code Interpreter tool call as part of a run step.
-
String logsThe text output from the Code Interpreter tool call.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
-
class ImageOutput:-
Image image-
String fileIdThe file ID of the image.
-
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
-
-
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
Code Interpreter Tool Call Delta
-
class CodeInterpreterToolCallDelta:Details of the Code Interpreter tool call the run step was involved in.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
Optional<String> idThe ID of the tool call.
-
Optional<CodeInterpreter> codeInterpreterThe Code Interpreter tool call definition.
-
Optional<String> inputThe input to the Code Interpreter tool call.
-
Optional<List<Output>> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class CodeInterpreterLogs:Text output from the Code Interpreter tool call as part of a run step.
-
long indexThe index of the output in the outputs array.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
Optional<String> logsThe text output from the Code Interpreter tool call.
-
-
class CodeInterpreterOutputImage:-
long indexThe index of the output in the outputs array.
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
Optional<Image> image-
Optional<String> fileIdThe file ID of the image.
-
-
-
-
-
File Search Tool Call
-
class FileSearchToolCall:-
String idThe ID of the tool call object.
-
FileSearch fileSearchFor now, this is always going to be an empty object.
-
Optional<RankingOptions> rankingOptionsThe ranking options for the file search.
-
Ranker rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
-
Optional<List<Result>> resultsThe results of the file search.
-
String fileIdThe ID of the file that result was found in.
-
String fileNameThe name of the file that result was found in.
-
double scoreThe score of the result. All values must be a floating point number between 0 and 1.
-
Optional<List<Content>> contentThe content of the result that was found. The content is only included if requested via the include query parameter.
-
Optional<String> textThe text content of the file.
-
Optional<Type> typeThe type of the content.
TEXT("text")
-
-
-
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
File Search Tool Call Delta
-
class FileSearchToolCallDelta:-
JsonValue fileSearchFor now, this is always going to be an empty object.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
Optional<String> idThe ID of the tool call object.
-
Function Tool Call
-
class FunctionToolCall:-
String idThe ID of the tool call object.
-
Function functionThe definition of the function that was called.
-
String argumentsThe arguments passed to the function.
-
String nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
Function Tool Call Delta
-
class FunctionToolCallDelta:-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
Optional<String> idThe ID of the tool call object.
-
Optional<Function> functionThe definition of the function that was called.
-
Optional<String> argumentsThe arguments passed to the function.
-
Optional<String> nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
Message Creation Step Details
-
class MessageCreationStepDetails:Details of the message creation by the run step.
-
MessageCreation messageCreation-
String messageIdThe ID of the message that was created by this run step.
-
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
Run Step
-
class RunStep:Represents a step in execution of a run.
-
String idThe identifier of the run step, which can be referenced in API endpoints.
-
String assistantIdThe ID of the assistant associated with the run step.
-
Optional<Long> cancelledAtThe Unix timestamp (in seconds) for when the run step was cancelled.
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the run step completed.
-
long createdAtThe Unix timestamp (in seconds) for when the run step was created.
-
Optional<Long> expiredAtThe Unix timestamp (in seconds) for when the run step expired. A step is considered expired if the parent run is expired.
-
Optional<Long> failedAtThe Unix timestamp (in seconds) for when the run step failed.
-
Optional<LastError> lastErrorThe last error associated with this run step. Will be
nullif there are no errors.-
Code codeOne of
server_errororrate_limit_exceeded.-
SERVER_ERROR("server_error") -
RATE_LIMIT_EXCEEDED("rate_limit_exceeded")
-
-
String messageA human-readable description of the error.
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.run.step"constantThe object type, which is always
thread.run.step.THREAD_RUN_STEP("thread.run.step")
-
String runIdThe ID of the run that this run step is a part of.
-
Status statusThe status of the run step, which can be either
in_progress,cancelled,failed,completed, orexpired.-
IN_PROGRESS("in_progress") -
CANCELLED("cancelled") -
FAILED("failed") -
COMPLETED("completed") -
EXPIRED("expired")
-
-
StepDetails stepDetailsThe details of the run step.
-
class MessageCreationStepDetails:Details of the message creation by the run step.
-
MessageCreation messageCreation-
String messageIdThe ID of the message that was created by this run step.
-
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
-
class ToolCallsStepDetails:Details of the tool call.
-
List<ToolCall> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCall:Details of the Code Interpreter tool call the run step was involved in.
-
String idThe ID of the tool call.
-
CodeInterpreter codeInterpreterThe Code Interpreter tool call definition.
-
String inputThe input to the Code Interpreter tool call.
-
List<Output> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class LogsOutput:Text output from the Code Interpreter tool call as part of a run step.
-
String logsThe text output from the Code Interpreter tool call.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
-
class ImageOutput:-
Image image-
String fileIdThe file ID of the image.
-
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
-
-
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
-
class FileSearchToolCall:-
String idThe ID of the tool call object.
-
FileSearch fileSearchFor now, this is always going to be an empty object.
-
Optional<RankingOptions> rankingOptionsThe ranking options for the file search.
-
Ranker rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
-
Optional<List<Result>> resultsThe results of the file search.
-
String fileIdThe ID of the file that result was found in.
-
String fileNameThe name of the file that result was found in.
-
double scoreThe score of the result. All values must be a floating point number between 0 and 1.
-
Optional<List<Content>> contentThe content of the result that was found. The content is only included if requested via the include query parameter.
-
Optional<String> textThe text content of the file.
-
Optional<Type> typeThe type of the content.
TEXT("text")
-
-
-
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
-
class FunctionToolCall:-
String idThe ID of the tool call object.
-
Function functionThe definition of the function that was called.
-
String argumentsThe arguments passed to the function.
-
String nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
-
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
-
-
String threadIdThe ID of the thread that was run.
-
Type typeThe type of run step, which can be either
message_creationortool_calls.-
MESSAGE_CREATION("message_creation") -
TOOL_CALLS("tool_calls")
-
-
Optional<Usage> usageUsage statistics related to the run step. This value will be
nullwhile the run step's status isin_progress.-
long completionTokensNumber of completion tokens used over the course of the run step.
-
long promptTokensNumber of prompt tokens used over the course of the run step.
-
long totalTokensTotal number of tokens used (prompt + completion).
-
-
Run Step Delta
-
class RunStepDelta:The delta containing the fields that have changed on the run step.
-
Optional<StepDetails> stepDetailsThe details of the run step.
-
class RunStepDeltaMessageDelta:Details of the message creation by the run step.
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
Optional<MessageCreation> messageCreation-
Optional<String> messageIdThe ID of the message that was created by this run step.
-
-
-
class ToolCallDeltaObject:Details of the tool call.
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
Optional<List<ToolCallDelta>> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCallDelta:Details of the Code Interpreter tool call the run step was involved in.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
Optional<String> idThe ID of the tool call.
-
Optional<CodeInterpreter> codeInterpreterThe Code Interpreter tool call definition.
-
Optional<String> inputThe input to the Code Interpreter tool call.
-
Optional<List<Output>> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class CodeInterpreterLogs:Text output from the Code Interpreter tool call as part of a run step.
-
long indexThe index of the output in the outputs array.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
Optional<String> logsThe text output from the Code Interpreter tool call.
-
-
class CodeInterpreterOutputImage:-
long indexThe index of the output in the outputs array.
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
Optional<Image> image-
Optional<String> fileIdThe file ID of the image.
-
-
-
-
-
-
class FileSearchToolCallDelta:-
JsonValue fileSearchFor now, this is always going to be an empty object.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
Optional<String> idThe ID of the tool call object.
-
-
class FunctionToolCallDelta:-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
Optional<String> idThe ID of the tool call object.
-
Optional<Function> functionThe definition of the function that was called.
-
Optional<String> argumentsThe arguments passed to the function.
-
Optional<String> nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
-
-
-
-
Run Step Delta Event
-
class RunStepDeltaEvent:Represents a run step delta i.e. any changed fields on a run step during streaming.
-
String idThe identifier of the run step, which can be referenced in API endpoints.
-
RunStepDelta deltaThe delta containing the fields that have changed on the run step.
-
Optional<StepDetails> stepDetailsThe details of the run step.
-
class RunStepDeltaMessageDelta:Details of the message creation by the run step.
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
Optional<MessageCreation> messageCreation-
Optional<String> messageIdThe ID of the message that was created by this run step.
-
-
-
class ToolCallDeltaObject:Details of the tool call.
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
Optional<List<ToolCallDelta>> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCallDelta:Details of the Code Interpreter tool call the run step was involved in.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
Optional<String> idThe ID of the tool call.
-
Optional<CodeInterpreter> codeInterpreterThe Code Interpreter tool call definition.
-
Optional<String> inputThe input to the Code Interpreter tool call.
-
Optional<List<Output>> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class CodeInterpreterLogs:Text output from the Code Interpreter tool call as part of a run step.
-
long indexThe index of the output in the outputs array.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
Optional<String> logsThe text output from the Code Interpreter tool call.
-
-
class CodeInterpreterOutputImage:-
long indexThe index of the output in the outputs array.
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
Optional<Image> image-
Optional<String> fileIdThe file ID of the image.
-
-
-
-
-
-
class FileSearchToolCallDelta:-
JsonValue fileSearchFor now, this is always going to be an empty object.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
Optional<String> idThe ID of the tool call object.
-
-
class FunctionToolCallDelta:-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
Optional<String> idThe ID of the tool call object.
-
Optional<Function> functionThe definition of the function that was called.
-
Optional<String> argumentsThe arguments passed to the function.
-
Optional<String> nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
-
-
-
-
-
JsonValue; object_ "thread.run.step.delta"constantThe object type, which is always
thread.run.step.delta.THREAD_RUN_STEP_DELTA("thread.run.step.delta")
-
Run Step Delta Message Delta
-
class RunStepDeltaMessageDelta:Details of the message creation by the run step.
-
JsonValue; type "message_creation"constantAlways
message_creation.MESSAGE_CREATION("message_creation")
-
Optional<MessageCreation> messageCreation-
Optional<String> messageIdThe ID of the message that was created by this run step.
-
-
Run Step Include
-
enum RunStepInclude:STEP_DETAILS_TOOL_CALLS_FILE_SEARCH_RESULTS_CONTENT("step_details.tool_calls[*].file_search.results[*].content")
Tool Call
-
class ToolCall: A class that can be one of several variants.unionDetails of the Code Interpreter tool call the run step was involved in.
-
class CodeInterpreterToolCall:Details of the Code Interpreter tool call the run step was involved in.
-
String idThe ID of the tool call.
-
CodeInterpreter codeInterpreterThe Code Interpreter tool call definition.
-
String inputThe input to the Code Interpreter tool call.
-
List<Output> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class LogsOutput:Text output from the Code Interpreter tool call as part of a run step.
-
String logsThe text output from the Code Interpreter tool call.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
-
class ImageOutput:-
Image image-
String fileIdThe file ID of the image.
-
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
-
-
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
-
class FileSearchToolCall:-
String idThe ID of the tool call object.
-
FileSearch fileSearchFor now, this is always going to be an empty object.
-
Optional<RankingOptions> rankingOptionsThe ranking options for the file search.
-
Ranker rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
-
Optional<List<Result>> resultsThe results of the file search.
-
String fileIdThe ID of the file that result was found in.
-
String fileNameThe name of the file that result was found in.
-
double scoreThe score of the result. All values must be a floating point number between 0 and 1.
-
Optional<List<Content>> contentThe content of the result that was found. The content is only included if requested via the include query parameter.
-
Optional<String> textThe text content of the file.
-
Optional<Type> typeThe type of the content.
TEXT("text")
-
-
-
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
-
class FunctionToolCall:-
String idThe ID of the tool call object.
-
Function functionThe definition of the function that was called.
-
String argumentsThe arguments passed to the function.
-
String nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
-
Tool Call Delta
-
class ToolCallDelta: A class that can be one of several variants.unionDetails of the Code Interpreter tool call the run step was involved in.
-
class CodeInterpreterToolCallDelta:Details of the Code Interpreter tool call the run step was involved in.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
Optional<String> idThe ID of the tool call.
-
Optional<CodeInterpreter> codeInterpreterThe Code Interpreter tool call definition.
-
Optional<String> inputThe input to the Code Interpreter tool call.
-
Optional<List<Output>> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class CodeInterpreterLogs:Text output from the Code Interpreter tool call as part of a run step.
-
long indexThe index of the output in the outputs array.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
Optional<String> logsThe text output from the Code Interpreter tool call.
-
-
class CodeInterpreterOutputImage:-
long indexThe index of the output in the outputs array.
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
Optional<Image> image-
Optional<String> fileIdThe file ID of the image.
-
-
-
-
-
-
class FileSearchToolCallDelta:-
JsonValue fileSearchFor now, this is always going to be an empty object.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
Optional<String> idThe ID of the tool call object.
-
-
class FunctionToolCallDelta:-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
Optional<String> idThe ID of the tool call object.
-
Optional<Function> functionThe definition of the function that was called.
-
Optional<String> argumentsThe arguments passed to the function.
-
Optional<String> nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
-
Tool Call Delta Object
-
class ToolCallDeltaObject:Details of the tool call.
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
Optional<List<ToolCallDelta>> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCallDelta:Details of the Code Interpreter tool call the run step was involved in.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
Optional<String> idThe ID of the tool call.
-
Optional<CodeInterpreter> codeInterpreterThe Code Interpreter tool call definition.
-
Optional<String> inputThe input to the Code Interpreter tool call.
-
Optional<List<Output>> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class CodeInterpreterLogs:Text output from the Code Interpreter tool call as part of a run step.
-
long indexThe index of the output in the outputs array.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
Optional<String> logsThe text output from the Code Interpreter tool call.
-
-
class CodeInterpreterOutputImage:-
long indexThe index of the output in the outputs array.
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
Optional<Image> image-
Optional<String> fileIdThe file ID of the image.
-
-
-
-
-
-
class FileSearchToolCallDelta:-
JsonValue fileSearchFor now, this is always going to be an empty object.
-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
Optional<String> idThe ID of the tool call object.
-
-
class FunctionToolCallDelta:-
long indexThe index of the tool call in the tool calls array.
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
Optional<String> idThe ID of the tool call object.
-
Optional<Function> functionThe definition of the function that was called.
-
Optional<String> argumentsThe arguments passed to the function.
-
Optional<String> nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
-
-
Tool Calls Step Details
-
class ToolCallsStepDetails:Details of the tool call.
-
List<ToolCall> toolCallsAn array of tool calls the run step was involved in. These can be associated with one of three types of tools:
code_interpreter,file_search, orfunction.-
class CodeInterpreterToolCall:Details of the Code Interpreter tool call the run step was involved in.
-
String idThe ID of the tool call.
-
CodeInterpreter codeInterpreterThe Code Interpreter tool call definition.
-
String inputThe input to the Code Interpreter tool call.
-
List<Output> outputsThe outputs from the Code Interpreter tool call. Code Interpreter can output one or more items, including text (
logs) or images (image). Each of these are represented by a different object type.-
class LogsOutput:Text output from the Code Interpreter tool call as part of a run step.
-
String logsThe text output from the Code Interpreter tool call.
-
JsonValue; type "logs"constantAlways
logs.LOGS("logs")
-
-
class ImageOutput:-
Image image-
String fileIdThe file ID of the image.
-
-
JsonValue; type "image"constantAlways
image.IMAGE("image")
-
-
-
-
JsonValue; type "code_interpreter"constantThe type of tool call. This is always going to be
code_interpreterfor this type of tool call.CODE_INTERPRETER("code_interpreter")
-
-
class FileSearchToolCall:-
String idThe ID of the tool call object.
-
FileSearch fileSearchFor now, this is always going to be an empty object.
-
Optional<RankingOptions> rankingOptionsThe ranking options for the file search.
-
Ranker rankerThe ranker to use for the file search. If not specified will use the
autoranker.-
AUTO("auto") -
DEFAULT_2024_08_21("default_2024_08_21")
-
-
double scoreThresholdThe score threshold for the file search. All values must be a floating point number between 0 and 1.
-
-
Optional<List<Result>> resultsThe results of the file search.
-
String fileIdThe ID of the file that result was found in.
-
String fileNameThe name of the file that result was found in.
-
double scoreThe score of the result. All values must be a floating point number between 0 and 1.
-
Optional<List<Content>> contentThe content of the result that was found. The content is only included if requested via the include query parameter.
-
Optional<String> textThe text content of the file.
-
Optional<Type> typeThe type of the content.
TEXT("text")
-
-
-
-
JsonValue; type "file_search"constantThe type of tool call. This is always going to be
file_searchfor this type of tool call.FILE_SEARCH("file_search")
-
-
class FunctionToolCall:-
String idThe ID of the tool call object.
-
Function functionThe definition of the function that was called.
-
String argumentsThe arguments passed to the function.
-
String nameThe name of the function.
-
Optional<String> outputThe output of the function. This will be
nullif the outputs have not been submitted yet.
-
-
JsonValue; type "function"constantThe type of tool call. This is always going to be
functionfor this type of tool call.FUNCTION("function")
-
-
-
JsonValue; type "tool_calls"constantAlways
tool_calls.TOOL_CALLS("tool_calls")
-
Messages
List messages
MessageListPage beta().threads().messages().list(MessageListParamsparams = MessageListParams.none(), RequestOptionsrequestOptions = RequestOptions.none())
get /threads/{thread_id}/messages
Returns a list of messages for a given thread.
Parameters
-
MessageListParams params-
Optional<String> threadId -
Optional<String> afterA cursor for use in pagination.
afteris an object ID that defines your place in the list. For instance, if you make a list request and receive 100 objects, ending with obj_foo, your subsequent call can include after=obj_foo in order to fetch the next page of the list. -
Optional<String> beforeA cursor for use in pagination.
beforeis an object ID that defines your place in the list. For instance, if you make a list request and receive 100 objects, starting with obj_foo, your subsequent call can include before=obj_foo in order to fetch the previous page of the list. -
Optional<Long> limitA limit on the number of objects to be returned. Limit can range between 1 and 100, and the default is 20.
-
Optional<Order> orderSort order by the
created_attimestamp of the objects.ascfor ascending order anddescfor descending order.-
ASC("asc") -
DESC("desc")
-
-
Optional<String> runIdFilter messages by the run ID that generated them.
-
Returns
-
class Message:Represents a message within a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
Optional<String> assistantIdIf applicable, the ID of the assistant that authored this message.
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they were added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the message was completed.
-
List<MessageContent> contentThe content of the message in array of text and/or images.
-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlock:The text content that is part of a message.
-
Text text-
List<Annotation> annotations-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
-
String valueThe data that makes up the text.
-
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
class RefusalContentBlock:The refusal content generated by the assistant.
-
String refusal -
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
-
-
long createdAtThe Unix timestamp (in seconds) for when the message was created.
-
Optional<Long> incompleteAtThe Unix timestamp (in seconds) for when the message was marked as incomplete.
-
Optional<IncompleteDetails> incompleteDetailsOn an incomplete message, details about why the message is incomplete.
-
Reason reasonThe reason the message is incomplete.
-
CONTENT_FILTER("content_filter") -
MAX_TOKENS("max_tokens") -
RUN_CANCELLED("run_cancelled") -
RUN_EXPIRED("run_expired") -
RUN_FAILED("run_failed")
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.message"constantThe object type, which is always
thread.message.THREAD_MESSAGE("thread.message")
-
Role roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
Optional<String> runIdThe ID of the run associated with the creation of this message. Value is
nullwhen messages are created manually using the create message or create thread endpoints. -
Status statusThe status of the message, which can be either
in_progress,incomplete, orcompleted.-
IN_PROGRESS("in_progress") -
INCOMPLETE("incomplete") -
COMPLETED("completed")
-
-
String threadIdThe thread ID that this message belongs to.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.messages.MessageListPage;
import com.openai.models.beta.threads.messages.MessageListParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
MessageListPage page = client.beta().threads().messages().list("thread_id");
}
}
Response
{
"data": [
{
"id": "id",
"assistant_id": "assistant_id",
"attachments": [
{
"file_id": "file_id",
"tools": [
{
"type": "code_interpreter"
}
]
}
],
"completed_at": 0,
"content": [
{
"image_file": {
"file_id": "file_id",
"detail": "auto"
},
"type": "image_file"
}
],
"created_at": 0,
"incomplete_at": 0,
"incomplete_details": {
"reason": "content_filter"
},
"metadata": {
"foo": "string"
},
"object": "thread.message",
"role": "user",
"run_id": "run_id",
"status": "in_progress",
"thread_id": "thread_id"
}
],
"first_id": "msg_abc123",
"has_more": false,
"last_id": "msg_abc123",
"object": "list"
}
Create message
Message beta().threads().messages().create(MessageCreateParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
post /threads/{thread_id}/messages
Create a message.
Parameters
-
MessageCreateParams params-
Optional<String> threadId -
Content contentThe text contents of the message.
-
String -
List<MessageContentPartParam>-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlockParam:The text content that is part of a message.
-
String textText content to be sent to the model
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
-
-
Role roleThe role of the entity that is creating the message. Allowed values include:
-
user: Indicates the message is sent by an actual user and should be used in most cases to represent user-generated messages. -
assistant: Indicates the message is generated by the assistant. Use this value to insert messages from the assistant into the conversation. -
USER("user") -
ASSISTANT("assistant")
-
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they should be added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
Returns
-
class Message:Represents a message within a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
Optional<String> assistantIdIf applicable, the ID of the assistant that authored this message.
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they were added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the message was completed.
-
List<MessageContent> contentThe content of the message in array of text and/or images.
-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlock:The text content that is part of a message.
-
Text text-
List<Annotation> annotations-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
-
String valueThe data that makes up the text.
-
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
class RefusalContentBlock:The refusal content generated by the assistant.
-
String refusal -
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
-
-
long createdAtThe Unix timestamp (in seconds) for when the message was created.
-
Optional<Long> incompleteAtThe Unix timestamp (in seconds) for when the message was marked as incomplete.
-
Optional<IncompleteDetails> incompleteDetailsOn an incomplete message, details about why the message is incomplete.
-
Reason reasonThe reason the message is incomplete.
-
CONTENT_FILTER("content_filter") -
MAX_TOKENS("max_tokens") -
RUN_CANCELLED("run_cancelled") -
RUN_EXPIRED("run_expired") -
RUN_FAILED("run_failed")
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.message"constantThe object type, which is always
thread.message.THREAD_MESSAGE("thread.message")
-
Role roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
Optional<String> runIdThe ID of the run associated with the creation of this message. Value is
nullwhen messages are created manually using the create message or create thread endpoints. -
Status statusThe status of the message, which can be either
in_progress,incomplete, orcompleted.-
IN_PROGRESS("in_progress") -
INCOMPLETE("incomplete") -
COMPLETED("completed")
-
-
String threadIdThe thread ID that this message belongs to.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.messages.Message;
import com.openai.models.beta.threads.messages.MessageCreateParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
MessageCreateParams params = MessageCreateParams.builder()
.threadId("thread_id")
.content("string")
.role(MessageCreateParams.Role.USER)
.build();
Message message = client.beta().threads().messages().create(params);
}
}
Response
{
"id": "id",
"assistant_id": "assistant_id",
"attachments": [
{
"file_id": "file_id",
"tools": [
{
"type": "code_interpreter"
}
]
}
],
"completed_at": 0,
"content": [
{
"image_file": {
"file_id": "file_id",
"detail": "auto"
},
"type": "image_file"
}
],
"created_at": 0,
"incomplete_at": 0,
"incomplete_details": {
"reason": "content_filter"
},
"metadata": {
"foo": "string"
},
"object": "thread.message",
"role": "user",
"run_id": "run_id",
"status": "in_progress",
"thread_id": "thread_id"
}
Modify message
Message beta().threads().messages().update(MessageUpdateParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
post /threads/{thread_id}/messages/{message_id}
Modifies a message.
Parameters
-
MessageUpdateParams params-
String threadId -
Optional<String> messageId -
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
Returns
-
class Message:Represents a message within a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
Optional<String> assistantIdIf applicable, the ID of the assistant that authored this message.
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they were added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the message was completed.
-
List<MessageContent> contentThe content of the message in array of text and/or images.
-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlock:The text content that is part of a message.
-
Text text-
List<Annotation> annotations-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
-
String valueThe data that makes up the text.
-
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
class RefusalContentBlock:The refusal content generated by the assistant.
-
String refusal -
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
-
-
long createdAtThe Unix timestamp (in seconds) for when the message was created.
-
Optional<Long> incompleteAtThe Unix timestamp (in seconds) for when the message was marked as incomplete.
-
Optional<IncompleteDetails> incompleteDetailsOn an incomplete message, details about why the message is incomplete.
-
Reason reasonThe reason the message is incomplete.
-
CONTENT_FILTER("content_filter") -
MAX_TOKENS("max_tokens") -
RUN_CANCELLED("run_cancelled") -
RUN_EXPIRED("run_expired") -
RUN_FAILED("run_failed")
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.message"constantThe object type, which is always
thread.message.THREAD_MESSAGE("thread.message")
-
Role roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
Optional<String> runIdThe ID of the run associated with the creation of this message. Value is
nullwhen messages are created manually using the create message or create thread endpoints. -
Status statusThe status of the message, which can be either
in_progress,incomplete, orcompleted.-
IN_PROGRESS("in_progress") -
INCOMPLETE("incomplete") -
COMPLETED("completed")
-
-
String threadIdThe thread ID that this message belongs to.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.messages.Message;
import com.openai.models.beta.threads.messages.MessageUpdateParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
MessageUpdateParams params = MessageUpdateParams.builder()
.threadId("thread_id")
.messageId("message_id")
.build();
Message message = client.beta().threads().messages().update(params);
}
}
Response
{
"id": "id",
"assistant_id": "assistant_id",
"attachments": [
{
"file_id": "file_id",
"tools": [
{
"type": "code_interpreter"
}
]
}
],
"completed_at": 0,
"content": [
{
"image_file": {
"file_id": "file_id",
"detail": "auto"
},
"type": "image_file"
}
],
"created_at": 0,
"incomplete_at": 0,
"incomplete_details": {
"reason": "content_filter"
},
"metadata": {
"foo": "string"
},
"object": "thread.message",
"role": "user",
"run_id": "run_id",
"status": "in_progress",
"thread_id": "thread_id"
}
Retrieve message
Message beta().threads().messages().retrieve(MessageRetrieveParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
get /threads/{thread_id}/messages/{message_id}
Retrieve a message.
Parameters
-
MessageRetrieveParams params-
String threadId -
Optional<String> messageId
-
Returns
-
class Message:Represents a message within a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
Optional<String> assistantIdIf applicable, the ID of the assistant that authored this message.
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they were added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the message was completed.
-
List<MessageContent> contentThe content of the message in array of text and/or images.
-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlock:The text content that is part of a message.
-
Text text-
List<Annotation> annotations-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
-
String valueThe data that makes up the text.
-
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
class RefusalContentBlock:The refusal content generated by the assistant.
-
String refusal -
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
-
-
long createdAtThe Unix timestamp (in seconds) for when the message was created.
-
Optional<Long> incompleteAtThe Unix timestamp (in seconds) for when the message was marked as incomplete.
-
Optional<IncompleteDetails> incompleteDetailsOn an incomplete message, details about why the message is incomplete.
-
Reason reasonThe reason the message is incomplete.
-
CONTENT_FILTER("content_filter") -
MAX_TOKENS("max_tokens") -
RUN_CANCELLED("run_cancelled") -
RUN_EXPIRED("run_expired") -
RUN_FAILED("run_failed")
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.message"constantThe object type, which is always
thread.message.THREAD_MESSAGE("thread.message")
-
Role roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
Optional<String> runIdThe ID of the run associated with the creation of this message. Value is
nullwhen messages are created manually using the create message or create thread endpoints. -
Status statusThe status of the message, which can be either
in_progress,incomplete, orcompleted.-
IN_PROGRESS("in_progress") -
INCOMPLETE("incomplete") -
COMPLETED("completed")
-
-
String threadIdThe thread ID that this message belongs to.
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.messages.Message;
import com.openai.models.beta.threads.messages.MessageRetrieveParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
MessageRetrieveParams params = MessageRetrieveParams.builder()
.threadId("thread_id")
.messageId("message_id")
.build();
Message message = client.beta().threads().messages().retrieve(params);
}
}
Response
{
"id": "id",
"assistant_id": "assistant_id",
"attachments": [
{
"file_id": "file_id",
"tools": [
{
"type": "code_interpreter"
}
]
}
],
"completed_at": 0,
"content": [
{
"image_file": {
"file_id": "file_id",
"detail": "auto"
},
"type": "image_file"
}
],
"created_at": 0,
"incomplete_at": 0,
"incomplete_details": {
"reason": "content_filter"
},
"metadata": {
"foo": "string"
},
"object": "thread.message",
"role": "user",
"run_id": "run_id",
"status": "in_progress",
"thread_id": "thread_id"
}
Delete message
MessageDeleted beta().threads().messages().delete(MessageDeleteParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
delete /threads/{thread_id}/messages/{message_id}
Deletes a message.
Parameters
-
MessageDeleteParams params-
String threadId -
Optional<String> messageId
-
Returns
-
class MessageDeleted:-
String id -
boolean deleted -
JsonValue; object_ "thread.message.deleted"constantTHREAD_MESSAGE_DELETED("thread.message.deleted")
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.beta.threads.messages.MessageDeleteParams;
import com.openai.models.beta.threads.messages.MessageDeleted;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
MessageDeleteParams params = MessageDeleteParams.builder()
.threadId("thread_id")
.messageId("message_id")
.build();
MessageDeleted messageDeleted = client.beta().threads().messages().delete(params);
}
}
Response
{
"id": "id",
"deleted": true,
"object": "thread.message.deleted"
}
Domain Types
Annotation
-
class Annotation: A class that can be one of several variants.unionA citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
Annotation Delta
-
class AnnotationDelta: A class that can be one of several variants.unionA citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
class FileCitationDeltaAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
Optional<Long> endIndex -
Optional<FileCitation> fileCitation-
Optional<String> fileIdThe ID of the specific File the citation is from.
-
Optional<String> quoteThe specific quote in the file.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
class FilePathDeltaAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
Optional<Long> endIndex -
Optional<FilePath> filePath-
Optional<String> fileIdThe ID of the file that was generated.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
File Citation Annotation
-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
File Citation Delta Annotation
-
class FileCitationDeltaAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
Optional<Long> endIndex -
Optional<FileCitation> fileCitation-
Optional<String> fileIdThe ID of the specific File the citation is from.
-
Optional<String> quoteThe specific quote in the file.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
File Path Annotation
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
File Path Delta Annotation
-
class FilePathDeltaAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
Optional<Long> endIndex -
Optional<FilePath> filePath-
Optional<String> fileIdThe ID of the file that was generated.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
Image File
-
class ImageFile:-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Image File Content Block
-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
Image File Delta
-
class ImageFileDelta:-
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content.
-
Image File Delta Block
-
class ImageFileDeltaBlock:References an image File in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
Optional<ImageFileDelta> imageFile-
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content.
-
-
Image URL
-
class ImageUrl:-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Image URL Content Block
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
Image URL Delta
-
class ImageUrlDelta:-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> urlThe URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Image URL Delta Block
-
class ImageUrlDeltaBlock:References an image URL in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_url"constantAlways
image_url.IMAGE_URL("image_url")
-
Optional<ImageUrlDelta> imageUrl-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> urlThe URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
-
Message
-
class Message:Represents a message within a thread.
-
String idThe identifier, which can be referenced in API endpoints.
-
Optional<String> assistantIdIf applicable, the ID of the assistant that authored this message.
-
Optional<List<Attachment>> attachmentsA list of files attached to the message, and the tools they were added to.
-
Optional<String> fileIdThe ID of the file to attach to the message.
-
Optional<List<Tool>> toolsThe tools to add this file to.
-
class CodeInterpreterTool:-
JsonValue; type "code_interpreter"constantThe type of tool being defined:
code_interpreterCODE_INTERPRETER("code_interpreter")
-
-
JsonValue;-
JsonValue; type "file_search"constantThe type of tool being defined:
file_searchFILE_SEARCH("file_search")
-
-
-
-
Optional<Long> completedAtThe Unix timestamp (in seconds) for when the message was completed.
-
List<MessageContent> contentThe content of the message in array of text and/or images.
-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlock:The text content that is part of a message.
-
Text text-
List<Annotation> annotations-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
-
String valueThe data that makes up the text.
-
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
class RefusalContentBlock:The refusal content generated by the assistant.
-
String refusal -
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
-
-
long createdAtThe Unix timestamp (in seconds) for when the message was created.
-
Optional<Long> incompleteAtThe Unix timestamp (in seconds) for when the message was marked as incomplete.
-
Optional<IncompleteDetails> incompleteDetailsOn an incomplete message, details about why the message is incomplete.
-
Reason reasonThe reason the message is incomplete.
-
CONTENT_FILTER("content_filter") -
MAX_TOKENS("max_tokens") -
RUN_CANCELLED("run_cancelled") -
RUN_EXPIRED("run_expired") -
RUN_FAILED("run_failed")
-
-
-
Optional<Metadata> metadataSet of 16 key-value pairs that can be attached to an object. This can be useful for storing additional information about the object in a structured format, and querying for objects via API or the dashboard.
Keys are strings with a maximum length of 64 characters. Values are strings with a maximum length of 512 characters.
-
JsonValue; object_ "thread.message"constantThe object type, which is always
thread.message.THREAD_MESSAGE("thread.message")
-
Role roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
Optional<String> runIdThe ID of the run associated with the creation of this message. Value is
nullwhen messages are created manually using the create message or create thread endpoints. -
Status statusThe status of the message, which can be either
in_progress,incomplete, orcompleted.-
IN_PROGRESS("in_progress") -
INCOMPLETE("incomplete") -
COMPLETED("completed")
-
-
String threadIdThe thread ID that this message belongs to.
-
Message Content
-
class MessageContent: A class that can be one of several variants.unionReferences an image File in the content of a message.
-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlock:The text content that is part of a message.
-
Text text-
List<Annotation> annotations-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
-
String valueThe data that makes up the text.
-
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
class RefusalContentBlock:The refusal content generated by the assistant.
-
String refusal -
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
-
Message Content Delta
-
class MessageContentDelta: A class that can be one of several variants.unionReferences an image File in the content of a message.
-
class ImageFileDeltaBlock:References an image File in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
Optional<ImageFileDelta> imageFile-
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content.
-
-
-
class TextDeltaBlock:The text content that is part of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
Optional<TextDelta> text-
Optional<List<AnnotationDelta>> annotations-
class FileCitationDeltaAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
Optional<Long> endIndex -
Optional<FileCitation> fileCitation-
Optional<String> fileIdThe ID of the specific File the citation is from.
-
Optional<String> quoteThe specific quote in the file.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
class FilePathDeltaAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
Optional<Long> endIndex -
Optional<FilePath> filePath-
Optional<String> fileIdThe ID of the file that was generated.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
-
Optional<String> valueThe data that makes up the text.
-
-
-
class RefusalDeltaBlock:The refusal content that is part of a message.
-
long indexThe index of the refusal part in the message.
-
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
Optional<String> refusal
-
-
class ImageUrlDeltaBlock:References an image URL in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_url"constantAlways
image_url.IMAGE_URL("image_url")
-
Optional<ImageUrlDelta> imageUrl-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> urlThe URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
-
-
Message Content Part Param
-
class MessageContentPartParam: A class that can be one of several variants.unionReferences an image File in the content of a message.
-
class ImageFileContentBlock:References an image File in the content of a message.
-
ImageFile imageFile-
String fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content. -
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
-
class ImageUrlContentBlock:References an image URL in the content of a message.
-
ImageUrl imageUrl-
String urlThe external URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh. Default value isauto-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
-
JsonValue; type "image_url"constantThe type of the content part.
IMAGE_URL("image_url")
-
-
class TextContentBlockParam:The text content that is part of a message.
-
String textText content to be sent to the model
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
-
Message Deleted
-
class MessageDeleted:-
String id -
boolean deleted -
JsonValue; object_ "thread.message.deleted"constantTHREAD_MESSAGE_DELETED("thread.message.deleted")
-
Message Delta
-
class MessageDelta:The delta containing the fields that have changed on the Message.
-
Optional<List<MessageContentDelta>> contentThe content of the message in array of text and/or images.
-
class ImageFileDeltaBlock:References an image File in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
Optional<ImageFileDelta> imageFile-
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content.
-
-
-
class TextDeltaBlock:The text content that is part of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
Optional<TextDelta> text-
Optional<List<AnnotationDelta>> annotations-
class FileCitationDeltaAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
Optional<Long> endIndex -
Optional<FileCitation> fileCitation-
Optional<String> fileIdThe ID of the specific File the citation is from.
-
Optional<String> quoteThe specific quote in the file.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
class FilePathDeltaAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
Optional<Long> endIndex -
Optional<FilePath> filePath-
Optional<String> fileIdThe ID of the file that was generated.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
-
Optional<String> valueThe data that makes up the text.
-
-
-
class RefusalDeltaBlock:The refusal content that is part of a message.
-
long indexThe index of the refusal part in the message.
-
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
Optional<String> refusal
-
-
class ImageUrlDeltaBlock:References an image URL in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_url"constantAlways
image_url.IMAGE_URL("image_url")
-
Optional<ImageUrlDelta> imageUrl-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> urlThe URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
-
-
-
Optional<Role> roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
Message Delta Event
-
class MessageDeltaEvent:Represents a message delta i.e. any changed fields on a message during streaming.
-
String idThe identifier of the message, which can be referenced in API endpoints.
-
MessageDelta deltaThe delta containing the fields that have changed on the Message.
-
Optional<List<MessageContentDelta>> contentThe content of the message in array of text and/or images.
-
class ImageFileDeltaBlock:References an image File in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_file"constantAlways
image_file.IMAGE_FILE("image_file")
-
Optional<ImageFileDelta> imageFile-
Optional<Detail> detailSpecifies the detail level of the image if specified by the user.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> fileIdThe File ID of the image in the message content. Set
purpose="vision"when uploading the File if you need to later display the file content.
-
-
-
class TextDeltaBlock:The text content that is part of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
Optional<TextDelta> text-
Optional<List<AnnotationDelta>> annotations-
class FileCitationDeltaAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
Optional<Long> endIndex -
Optional<FileCitation> fileCitation-
Optional<String> fileIdThe ID of the specific File the citation is from.
-
Optional<String> quoteThe specific quote in the file.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
class FilePathDeltaAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
Optional<Long> endIndex -
Optional<FilePath> filePath-
Optional<String> fileIdThe ID of the file that was generated.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
-
Optional<String> valueThe data that makes up the text.
-
-
-
class RefusalDeltaBlock:The refusal content that is part of a message.
-
long indexThe index of the refusal part in the message.
-
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
Optional<String> refusal
-
-
class ImageUrlDeltaBlock:References an image URL in the content of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "image_url"constantAlways
image_url.IMAGE_URL("image_url")
-
Optional<ImageUrlDelta> imageUrl-
Optional<Detail> detailSpecifies the detail level of the image.
lowuses fewer tokens, you can opt in to high resolution usinghigh.-
AUTO("auto") -
LOW("low") -
HIGH("high")
-
-
Optional<String> urlThe URL of the image, must be a supported image types: jpeg, jpg, png, gif, webp.
-
-
-
-
Optional<Role> roleThe entity that produced the message. One of
userorassistant.-
USER("user") -
ASSISTANT("assistant")
-
-
-
JsonValue; object_ "thread.message.delta"constantThe object type, which is always
thread.message.delta.THREAD_MESSAGE_DELTA("thread.message.delta")
-
Refusal Content Block
-
class RefusalContentBlock:The refusal content generated by the assistant.
-
String refusal -
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
Refusal Delta Block
-
class RefusalDeltaBlock:The refusal content that is part of a message.
-
long indexThe index of the refusal part in the message.
-
JsonValue; type "refusal"constantAlways
refusal.REFUSAL("refusal")
-
Optional<String> refusal
-
Text
-
class Text:-
List<Annotation> annotations-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
-
String valueThe data that makes up the text.
-
Text Content Block
-
class TextContentBlock:The text content that is part of a message.
-
Text text-
List<Annotation> annotations-
class FileCitationAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long endIndex -
FileCitation fileCitation-
String fileIdThe ID of the specific File the citation is from.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
-
class FilePathAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long endIndex -
FilePath filePath-
String fileIdThe ID of the file that was generated.
-
-
long startIndex -
String textThe text in the message content that needs to be replaced.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
-
-
String valueThe data that makes up the text.
-
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
Text Content Block Param
-
class TextContentBlockParam:The text content that is part of a message.
-
String textText content to be sent to the model
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
Text Delta
-
class TextDelta:-
Optional<List<AnnotationDelta>> annotations-
class FileCitationDeltaAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
Optional<Long> endIndex -
Optional<FileCitation> fileCitation-
Optional<String> fileIdThe ID of the specific File the citation is from.
-
Optional<String> quoteThe specific quote in the file.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
class FilePathDeltaAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
Optional<Long> endIndex -
Optional<FilePath> filePath-
Optional<String> fileIdThe ID of the file that was generated.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
-
Optional<String> valueThe data that makes up the text.
-
Text Delta Block
-
class TextDeltaBlock:The text content that is part of a message.
-
long indexThe index of the content part in the message.
-
JsonValue; type "text"constantAlways
text.TEXT("text")
-
Optional<TextDelta> text-
Optional<List<AnnotationDelta>> annotations-
class FileCitationDeltaAnnotation:A citation within the message that points to a specific quote from a specific File associated with the assistant or the message. Generated when the assistant uses the "file_search" tool to search files.
-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_citation"constantAlways
file_citation.FILE_CITATION("file_citation")
-
Optional<Long> endIndex -
Optional<FileCitation> fileCitation-
Optional<String> fileIdThe ID of the specific File the citation is from.
-
Optional<String> quoteThe specific quote in the file.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
class FilePathDeltaAnnotation:A URL for the file that's generated when the assistant used the
code_interpretertool to generate a file.-
long indexThe index of the annotation in the text content part.
-
JsonValue; type "file_path"constantAlways
file_path.FILE_PATH("file_path")
-
Optional<Long> endIndex -
Optional<FilePath> filePath-
Optional<String> fileIdThe ID of the file that was generated.
-
-
Optional<Long> startIndex -
Optional<String> textThe text in the message content that needs to be replaced.
-
-
-
Optional<String> valueThe data that makes up the text.
-
-