Compact a response
CompactedResponse responses().compact(ResponseCompactParamsparams, RequestOptionsrequestOptions = RequestOptions.none())
post /responses/compact
Compact a conversation. Returns a compacted response object.
Learn when and how to compact long-running conversations in the conversation state guide. For ZDR-compatible compaction details, see Compaction (advanced).
Parameters
-
ResponseCompactParams params-
Optional<Model> modelModel ID used to generate the response, like
gpt-5oro3. OpenAI offers a wide range of models with different capabilities, performance characteristics, and price points. Refer to the model guide to browse and compare available models.-
GPT_5_4("gpt-5.4") -
GPT_5_4_MINI("gpt-5.4-mini") -
GPT_5_4_NANO("gpt-5.4-nano") -
GPT_5_4_MINI_2026_03_17("gpt-5.4-mini-2026-03-17") -
GPT_5_4_NANO_2026_03_17("gpt-5.4-nano-2026-03-17") -
GPT_5_3_CHAT_LATEST("gpt-5.3-chat-latest") -
GPT_5_2("gpt-5.2") -
GPT_5_2_2025_12_11("gpt-5.2-2025-12-11") -
GPT_5_2_CHAT_LATEST("gpt-5.2-chat-latest") -
GPT_5_2_PRO("gpt-5.2-pro") -
GPT_5_2_PRO_2025_12_11("gpt-5.2-pro-2025-12-11") -
GPT_5_1("gpt-5.1") -
GPT_5_1_2025_11_13("gpt-5.1-2025-11-13") -
GPT_5_1_CODEX("gpt-5.1-codex") -
GPT_5_1_MINI("gpt-5.1-mini") -
GPT_5_1_CHAT_LATEST("gpt-5.1-chat-latest") -
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_5_CHAT_LATEST("gpt-5-chat-latest") -
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") -
O4_MINI("o4-mini") -
O4_MINI_2025_04_16("o4-mini-2025-04-16") -
O3("o3") -
O3_2025_04_16("o3-2025-04-16") -
O3_MINI("o3-mini") -
O3_MINI_2025_01_31("o3-mini-2025-01-31") -
O1("o1") -
O1_2024_12_17("o1-2024-12-17") -
O1_PREVIEW("o1-preview") -
O1_PREVIEW_2024_09_12("o1-preview-2024-09-12") -
O1_MINI("o1-mini") -
O1_MINI_2024_09_12("o1-mini-2024-09-12") -
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_AUDIO_PREVIEW("gpt-4o-audio-preview") -
GPT_4O_AUDIO_PREVIEW_2024_10_01("gpt-4o-audio-preview-2024-10-01") -
GPT_4O_AUDIO_PREVIEW_2024_12_17("gpt-4o-audio-preview-2024-12-17") -
GPT_4O_AUDIO_PREVIEW_2025_06_03("gpt-4o-audio-preview-2025-06-03") -
GPT_4O_MINI_AUDIO_PREVIEW("gpt-4o-mini-audio-preview") -
GPT_4O_MINI_AUDIO_PREVIEW_2024_12_17("gpt-4o-mini-audio-preview-2024-12-17") -
GPT_4O_SEARCH_PREVIEW("gpt-4o-search-preview") -
GPT_4O_MINI_SEARCH_PREVIEW("gpt-4o-mini-search-preview") -
GPT_4O_SEARCH_PREVIEW_2025_03_11("gpt-4o-search-preview-2025-03-11") -
GPT_4O_MINI_SEARCH_PREVIEW_2025_03_11("gpt-4o-mini-search-preview-2025-03-11") -
CHATGPT_4O_LATEST("chatgpt-4o-latest") -
CODEX_MINI_LATEST("codex-mini-latest") -
GPT_4O_MINI("gpt-4o-mini") -
GPT_4O_MINI_2024_07_18("gpt-4o-mini-2024-07-18") -
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_0301("gpt-3.5-turbo-0301") -
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") -
O1_PRO("o1-pro") -
O1_PRO_2025_03_19("o1-pro-2025-03-19") -
O3_PRO("o3-pro") -
O3_PRO_2025_06_10("o3-pro-2025-06-10") -
O3_DEEP_RESEARCH("o3-deep-research") -
O3_DEEP_RESEARCH_2025_06_26("o3-deep-research-2025-06-26") -
O4_MINI_DEEP_RESEARCH("o4-mini-deep-research") -
O4_MINI_DEEP_RESEARCH_2025_06_26("o4-mini-deep-research-2025-06-26") -
COMPUTER_USE_PREVIEW("computer-use-preview") -
COMPUTER_USE_PREVIEW_2025_03_11("computer-use-preview-2025-03-11") -
GPT_5_CODEX("gpt-5-codex") -
GPT_5_PRO("gpt-5-pro") -
GPT_5_PRO_2025_10_06("gpt-5-pro-2025-10-06") -
GPT_5_1_CODEX_MAX("gpt-5.1-codex-max")
-
-
Optional<Input> inputText, image, or file inputs to the model, used to generate a response
-
String -
List<ResponseInputItem>-
class EasyInputMessage:A message input to the model with a role indicating instruction following hierarchy. Instructions given with the
developerorsystemrole take precedence over instructions given with theuserrole. Messages with theassistantrole are presumed to have been generated by the model in previous interactions.-
Content contentText, image, or audio input to the model, used to generate a response. Can also contain previous assistant responses.
-
String -
List<ResponseInputContent>-
class ResponseInputText:A text input to the model.
-
String textThe text input to the model.
-
JsonValue; type "input_text"constantThe type of the input item. Always
input_text.INPUT_TEXT("input_text")
-
-
class ResponseInputImage:An image input to the model. Learn about image inputs.
-
Detail detailThe detail level of the image to be sent to the model. One of
high,low,auto, ororiginal. Defaults toauto.-
LOW("low") -
HIGH("high") -
AUTO("auto") -
ORIGINAL("original")
-
-
JsonValue; type "input_image"constantThe type of the input item. Always
input_image.INPUT_IMAGE("input_image")
-
Optional<String> fileIdThe ID of the file to be sent to the model.
-
Optional<String> imageUrlThe URL of the image to be sent to the model. A fully qualified URL or base64 encoded image in a data URL.
-
-
class ResponseInputFile:A file input to the model.
-
JsonValue; type "input_file"constantThe type of the input item. Always
input_file.INPUT_FILE("input_file")
-
Optional<Detail> detailThe detail level of the file to be sent to the model. Use
lowfor the default rendering behavior, orhighto render the file at higher quality. Defaults tolow.-
LOW("low") -
HIGH("high")
-
-
Optional<String> fileDataThe content of the file to be sent to the model.
-
Optional<String> fileIdThe ID of the file to be sent to the model.
-
Optional<String> fileUrlThe URL of the file to be sent to the model.
-
Optional<String> filenameThe name of the file to be sent to the model.
-
-
-
-
Role roleThe role of the message input. One of
user,assistant,system, ordeveloper.-
USER("user") -
ASSISTANT("assistant") -
SYSTEM("system") -
DEVELOPER("developer")
-
-
Optional<Phase> phaseLabels an
assistantmessage as intermediate commentary (commentary) or the final answer (final_answer). For models likegpt-5.3-codexand beyond, when sending follow-up requests, preserve and resend phase on all assistant messages — dropping it can degrade performance. Not used for user messages.-
COMMENTARY("commentary") -
FINAL_ANSWER("final_answer")
-
-
Optional<Type> typeThe type of the message input. Always
message.MESSAGE("message")
-
-
Message-
List<ResponseInputContent> contentA list of one or many input items to the model, containing different content types.
-
class ResponseInputText:A text input to the model.
-
class ResponseInputImage:An image input to the model. Learn about image inputs.
-
class ResponseInputFile:A file input to the model.
-
-
Role roleThe role of the message input. One of
user,system, ordeveloper.-
USER("user") -
SYSTEM("system") -
DEVELOPER("developer")
-
-
Optional<Status> statusThe status of item. One of
in_progress,completed, orincomplete. Populated when items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
Optional<Type> typeThe type of the message input. Always set to
message.MESSAGE("message")
-
-
class ResponseOutputMessage:An output message from the model.
-
String idThe unique ID of the output message.
-
List<Content> contentThe content of the output message.
-
class ResponseOutputText:A text output from the model.
-
List<Annotation> annotationsThe annotations of the text output.
-
class FileCitation:A citation to a file.
-
String fileIdThe ID of the file.
-
String filenameThe filename of the file cited.
-
long indexThe index of the file in the list of files.
-
JsonValue; type "file_citation"constantThe type of the file citation. Always
file_citation.FILE_CITATION("file_citation")
-
-
class UrlCitation:A citation for a web resource used to generate a model response.
-
long endIndexThe index of the last character of the URL citation in the message.
-
long startIndexThe index of the first character of the URL citation in the message.
-
String titleThe title of the web resource.
-
JsonValue; type "url_citation"constantThe type of the URL citation. Always
url_citation.URL_CITATION("url_citation")
-
String urlThe URL of the web resource.
-
-
class ContainerFileCitation:A citation for a container file used to generate a model response.
-
String containerIdThe ID of the container file.
-
long endIndexThe index of the last character of the container file citation in the message.
-
String fileIdThe ID of the file.
-
String filenameThe filename of the container file cited.
-
long startIndexThe index of the first character of the container file citation in the message.
-
JsonValue; type "container_file_citation"constantThe type of the container file citation. Always
container_file_citation.CONTAINER_FILE_CITATION("container_file_citation")
-
-
class FilePath:A path to a file.
-
String fileIdThe ID of the file.
-
long indexThe index of the file in the list of files.
-
JsonValue; type "file_path"constantThe type of the file path. Always
file_path.FILE_PATH("file_path")
-
-
-
String textThe text output from the model.
-
JsonValue; type "output_text"constantThe type of the output text. Always
output_text.OUTPUT_TEXT("output_text")
-
Optional<List<Logprob>> logprobs-
String token -
List<long> bytes -
double logprob -
List<TopLogprob> topLogprobs-
String token -
List<long> bytes -
double logprob
-
-
-
-
class ResponseOutputRefusal:A refusal from the model.
-
String refusalThe refusal explanation from the model.
-
JsonValue; type "refusal"constantThe type of the refusal. Always
refusal.REFUSAL("refusal")
-
-
-
JsonValue; role "assistant"constantThe role of the output message. Always
assistant.ASSISTANT("assistant")
-
Status statusThe status of the message input. One of
in_progress,completed, orincomplete. Populated when input items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
JsonValue; type "message"constantThe type of the output message. Always
message.MESSAGE("message")
-
Optional<Phase> phaseLabels an
assistantmessage as intermediate commentary (commentary) or the final answer (final_answer). For models likegpt-5.3-codexand beyond, when sending follow-up requests, preserve and resend phase on all assistant messages — dropping it can degrade performance. Not used for user messages.-
COMMENTARY("commentary") -
FINAL_ANSWER("final_answer")
-
-
-
class ResponseFileSearchToolCall:The results of a file search tool call. See the file search guide for more information.
-
String idThe unique ID of the file search tool call.
-
List<String> queriesThe queries used to search for files.
-
Status statusThe status of the file search tool call. One of
in_progress,searching,incompleteorfailed,-
IN_PROGRESS("in_progress") -
SEARCHING("searching") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
FAILED("failed")
-
-
JsonValue; type "file_search_call"constantThe type of the file search tool call. Always
file_search_call.FILE_SEARCH_CALL("file_search_call")
-
Optional<List<Result>> resultsThe results of the file search tool call.
-
Optional<Attributes> attributesSet 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, booleans, or numbers.
-
String -
double -
boolean
-
-
Optional<String> fileIdThe unique ID of the file.
-
Optional<String> filenameThe name of the file.
-
Optional<Double> scoreThe relevance score of the file - a value between 0 and 1.
-
Optional<String> textThe text that was retrieved from the file.
-
-
-
class ResponseComputerToolCall:A tool call to a computer use tool. See the computer use guide for more information.
-
String idThe unique ID of the computer call.
-
String callIdAn identifier used when responding to the tool call with output.
-
List<PendingSafetyCheck> pendingSafetyChecksThe pending safety checks for the computer call.
-
String idThe ID of the pending safety check.
-
Optional<String> codeThe type of the pending safety check.
-
Optional<String> messageDetails about the pending safety check.
-
-
Status statusThe status of the item. One of
in_progress,completed, orincomplete. Populated when items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
Type typeThe type of the computer call. Always
computer_call.COMPUTER_CALL("computer_call")
-
Optional<Action> actionA click action.
-
class Click:A click action.
-
Button buttonIndicates which mouse button was pressed during the click. One of
left,right,wheel,back, orforward.-
LEFT("left") -
RIGHT("right") -
WHEEL("wheel") -
BACK("back") -
FORWARD("forward")
-
-
JsonValue; type "click"constantSpecifies the event type. For a click action, this property is always
click.CLICK("click")
-
long xThe x-coordinate where the click occurred.
-
long yThe y-coordinate where the click occurred.
-
Optional<List<String>> keysThe keys being held while clicking.
-
-
class DoubleClick:A double click action.
-
Optional<List<String>> keysThe keys being held while double-clicking.
-
JsonValue; type "double_click"constantSpecifies the event type. For a double click action, this property is always set to
double_click.DOUBLE_CLICK("double_click")
-
long xThe x-coordinate where the double click occurred.
-
long yThe y-coordinate where the double click occurred.
-
-
class Drag:A drag action.
-
List<Path> pathAn array of coordinates representing the path of the drag action. Coordinates will appear as an array of objects, eg
[ { x: 100, y: 200 }, { x: 200, y: 300 } ]-
long xThe x-coordinate.
-
long yThe y-coordinate.
-
-
JsonValue; type "drag"constantSpecifies the event type. For a drag action, this property is always set to
drag.DRAG("drag")
-
Optional<List<String>> keysThe keys being held while dragging the mouse.
-
-
class Keypress:A collection of keypresses the model would like to perform.
-
List<String> keysThe combination of keys the model is requesting to be pressed. This is an array of strings, each representing a key.
-
JsonValue; type "keypress"constantSpecifies the event type. For a keypress action, this property is always set to
keypress.KEYPRESS("keypress")
-
-
class Move:A mouse move action.
-
JsonValue; type "move"constantSpecifies the event type. For a move action, this property is always set to
move.MOVE("move")
-
long xThe x-coordinate to move to.
-
long yThe y-coordinate to move to.
-
Optional<List<String>> keysThe keys being held while moving the mouse.
-
-
JsonValue;-
JsonValue; type "screenshot"constantSpecifies the event type. For a screenshot action, this property is always set to
screenshot.SCREENSHOT("screenshot")
-
-
class Scroll:A scroll action.
-
long scrollXThe horizontal scroll distance.
-
long scrollYThe vertical scroll distance.
-
JsonValue; type "scroll"constantSpecifies the event type. For a scroll action, this property is always set to
scroll.SCROLL("scroll")
-
long xThe x-coordinate where the scroll occurred.
-
long yThe y-coordinate where the scroll occurred.
-
Optional<List<String>> keysThe keys being held while scrolling.
-
-
class Type:An action to type in text.
-
String textThe text to type.
-
JsonValue; type "type"constantSpecifies the event type. For a type action, this property is always set to
type.TYPE("type")
-
-
JsonValue;-
JsonValue; type "wait"constantSpecifies the event type. For a wait action, this property is always set to
wait.WAIT("wait")
-
-
-
Optional<List<ComputerAction>> actionsFlattened batched actions for
computer_use. Each action includes antypediscriminator and action-specific fields.-
Click-
Button buttonIndicates which mouse button was pressed during the click. One of
left,right,wheel,back, orforward.-
LEFT("left") -
RIGHT("right") -
WHEEL("wheel") -
BACK("back") -
FORWARD("forward")
-
-
JsonValue; type "click"constantSpecifies the event type. For a click action, this property is always
click.CLICK("click")
-
long xThe x-coordinate where the click occurred.
-
long yThe y-coordinate where the click occurred.
-
Optional<List<String>> keysThe keys being held while clicking.
-
-
DoubleClick-
Optional<List<String>> keysThe keys being held while double-clicking.
-
JsonValue; type "double_click"constantSpecifies the event type. For a double click action, this property is always set to
double_click.DOUBLE_CLICK("double_click")
-
long xThe x-coordinate where the double click occurred.
-
long yThe y-coordinate where the double click occurred.
-
-
Drag-
List<Path> pathAn array of coordinates representing the path of the drag action. Coordinates will appear as an array of objects, eg
[ { x: 100, y: 200 }, { x: 200, y: 300 } ]-
long xThe x-coordinate.
-
long yThe y-coordinate.
-
-
JsonValue; type "drag"constantSpecifies the event type. For a drag action, this property is always set to
drag.DRAG("drag")
-
Optional<List<String>> keysThe keys being held while dragging the mouse.
-
-
Keypress-
List<String> keysThe combination of keys the model is requesting to be pressed. This is an array of strings, each representing a key.
-
JsonValue; type "keypress"constantSpecifies the event type. For a keypress action, this property is always set to
keypress.KEYPRESS("keypress")
-
-
Move-
JsonValue; type "move"constantSpecifies the event type. For a move action, this property is always set to
move.MOVE("move")
-
long xThe x-coordinate to move to.
-
long yThe y-coordinate to move to.
-
Optional<List<String>> keysThe keys being held while moving the mouse.
-
-
JsonValue;-
JsonValue; type "screenshot"constantSpecifies the event type. For a screenshot action, this property is always set to
screenshot.SCREENSHOT("screenshot")
-
-
Scroll-
long scrollXThe horizontal scroll distance.
-
long scrollYThe vertical scroll distance.
-
JsonValue; type "scroll"constantSpecifies the event type. For a scroll action, this property is always set to
scroll.SCROLL("scroll")
-
long xThe x-coordinate where the scroll occurred.
-
long yThe y-coordinate where the scroll occurred.
-
Optional<List<String>> keysThe keys being held while scrolling.
-
-
Type-
String textThe text to type.
-
JsonValue; type "type"constantSpecifies the event type. For a type action, this property is always set to
type.TYPE("type")
-
-
JsonValue;-
JsonValue; type "wait"constantSpecifies the event type. For a wait action, this property is always set to
wait.WAIT("wait")
-
-
-
-
ComputerCallOutput-
String callIdThe ID of the computer tool call that produced the output.
-
ResponseComputerToolCallOutputScreenshot outputA computer screenshot image used with the computer use tool.
-
JsonValue; type "computer_screenshot"constantSpecifies the event type. For a computer screenshot, this property is always set to
computer_screenshot.COMPUTER_SCREENSHOT("computer_screenshot")
-
Optional<String> fileIdThe identifier of an uploaded file that contains the screenshot.
-
Optional<String> imageUrlThe URL of the screenshot image.
-
-
JsonValue; type "computer_call_output"constantThe type of the computer tool call output. Always
computer_call_output.COMPUTER_CALL_OUTPUT("computer_call_output")
-
Optional<String> idThe ID of the computer tool call output.
-
Optional<List<AcknowledgedSafetyCheck>> acknowledgedSafetyChecksThe safety checks reported by the API that have been acknowledged by the developer.
-
String idThe ID of the pending safety check.
-
Optional<String> codeThe type of the pending safety check.
-
Optional<String> messageDetails about the pending safety check.
-
-
Optional<Status> statusThe status of the message input. One of
in_progress,completed, orincomplete. Populated when input items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
class ResponseFunctionWebSearch:The results of a web search tool call. See the web search guide for more information.
-
String idThe unique ID of the web search tool call.
-
Action actionAn object describing the specific action taken in this web search call. Includes details on how the model used the web (search, open_page, find_in_page).
-
class Search:Action type "search" - Performs a web search query.
-
JsonValue; type "search"constantThe action type.
SEARCH("search")
-
Optional<List<String>> queriesThe search queries.
-
Optional<String> queryThe search query.
-
Optional<List<Source>> sourcesThe sources used in the search.
-
JsonValue; type "url"constantThe type of source. Always
url.URL("url")
-
String urlThe URL of the source.
-
-
-
class OpenPage:Action type "open_page" - Opens a specific URL from search results.
-
JsonValue; type "open_page"constantThe action type.
OPEN_PAGE("open_page")
-
Optional<String> urlThe URL opened by the model.
-
-
class FindInPage:Action type "find_in_page": Searches for a pattern within a loaded page.
-
String patternThe pattern or text to search for within the page.
-
JsonValue; type "find_in_page"constantThe action type.
FIND_IN_PAGE("find_in_page")
-
String urlThe URL of the page searched for the pattern.
-
-
-
Status statusThe status of the web search tool call.
-
IN_PROGRESS("in_progress") -
SEARCHING("searching") -
COMPLETED("completed") -
FAILED("failed")
-
-
JsonValue; type "web_search_call"constantThe type of the web search tool call. Always
web_search_call.WEB_SEARCH_CALL("web_search_call")
-
-
class ResponseFunctionToolCall:A tool call to run a function. See the function calling guide for more information.
-
String argumentsA JSON string of the arguments to pass to the function.
-
String callIdThe unique ID of the function tool call generated by the model.
-
String nameThe name of the function to run.
-
JsonValue; type "function_call"constantThe type of the function tool call. Always
function_call.FUNCTION_CALL("function_call")
-
Optional<String> idThe unique ID of the function tool call.
-
Optional<String> namespaceThe namespace of the function to run.
-
Optional<Status> statusThe status of the item. One of
in_progress,completed, orincomplete. Populated when items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
FunctionCallOutput-
String callIdThe unique ID of the function tool call generated by the model.
-
Output outputText, image, or file output of the function tool call.
-
String -
List<ResponseFunctionCallOutputItem>-
class ResponseInputTextContent:A text input to the model.
-
String textThe text input to the model.
-
JsonValue; type "input_text"constantThe type of the input item. Always
input_text.INPUT_TEXT("input_text")
-
-
class ResponseInputImageContent:An image input to the model. Learn about image inputs
-
JsonValue; type "input_image"constantThe type of the input item. Always
input_image.INPUT_IMAGE("input_image")
-
Optional<Detail> detailThe detail level of the image to be sent to the model. One of
high,low,auto, ororiginal. Defaults toauto.-
LOW("low") -
HIGH("high") -
AUTO("auto") -
ORIGINAL("original")
-
-
Optional<String> fileIdThe ID of the file to be sent to the model.
-
Optional<String> imageUrlThe URL of the image to be sent to the model. A fully qualified URL or base64 encoded image in a data URL.
-
-
class ResponseInputFileContent:A file input to the model.
-
JsonValue; type "input_file"constantThe type of the input item. Always
input_file.INPUT_FILE("input_file")
-
Optional<Detail> detailThe detail level of the file to be sent to the model. Use
lowfor the default rendering behavior, orhighto render the file at higher quality. Defaults tolow.-
LOW("low") -
HIGH("high")
-
-
Optional<String> fileDataThe base64-encoded data of the file to be sent to the model.
-
Optional<String> fileIdThe ID of the file to be sent to the model.
-
Optional<String> fileUrlThe URL of the file to be sent to the model.
-
Optional<String> filenameThe name of the file to be sent to the model.
-
-
-
-
JsonValue; type "function_call_output"constantThe type of the function tool call output. Always
function_call_output.FUNCTION_CALL_OUTPUT("function_call_output")
-
Optional<String> idThe unique ID of the function tool call output. Populated when this item is returned via API.
-
Optional<Status> statusThe status of the item. One of
in_progress,completed, orincomplete. Populated when items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
ToolSearchCall-
JsonValue argumentsThe arguments supplied to the tool search call.
-
JsonValue; type "tool_search_call"constantThe item type. Always
tool_search_call.TOOL_SEARCH_CALL("tool_search_call")
-
Optional<String> idThe unique ID of this tool search call.
-
Optional<String> callIdThe unique ID of the tool search call generated by the model.
-
Optional<Execution> executionWhether tool search was executed by the server or by the client.
-
SERVER("server") -
CLIENT("client")
-
-
Optional<Status> statusThe status of the tool search call.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
class ResponseToolSearchOutputItemParam:-
List<Tool> toolsThe loaded tool definitions returned by the tool search output.
-
class FunctionTool:Defines a function in your own code the model can choose to call. Learn more about function calling.
-
String nameThe name of the function to call.
-
Optional<Parameters> parametersA JSON schema object describing the parameters of the function.
-
Optional<Boolean> strictWhether to enforce strict parameter validation. Default
true. -
JsonValue; type "function"constantThe type of the function tool. Always
function.FUNCTION("function")
-
Optional<Boolean> deferLoadingWhether this function is deferred and loaded via tool search.
-
Optional<String> descriptionA description of the function. Used by the model to determine whether or not to call the function.
-
-
class FileSearchTool:A tool that searches for relevant content from uploaded files. Learn more about the file search tool.
-
JsonValue; type "file_search"constantThe type of the file search tool. Always
file_search.FILE_SEARCH("file_search")
-
List<String> vectorStoreIdsThe IDs of the vector stores to search.
-
Optional<Filters> filtersA filter to apply.
-
class ComparisonFilter:A filter used to compare a specified attribute key to a given value using a defined comparison operation.
-
String keyThe key to compare against the value.
-
Type typeSpecifies the comparison operator:
eq,ne,gt,gte,lt,lte,in,nin.-
eq: equals -
ne: not equal -
gt: greater than -
gte: greater than or equal -
lt: less than -
lte: less than or equal -
in: in -
nin: not in -
EQ("eq") -
NE("ne") -
GT("gt") -
GTE("gte") -
LT("lt") -
LTE("lte") -
IN("in") -
NIN("nin")
-
-
Value valueThe value to compare against the attribute key; supports string, number, or boolean types.
-
String -
double -
boolean -
List<ComparisonFilterValueItem>-
String -
double
-
-
-
-
class CompoundFilter:Combine multiple filters using
andoror.-
List<Filter> filtersArray of filters to combine. Items can be
ComparisonFilterorCompoundFilter.-
class ComparisonFilter:A filter used to compare a specified attribute key to a given value using a defined comparison operation.
-
JsonValue
-
-
Type typeType of operation:
andoror.-
AND("and") -
OR("or")
-
-
-
-
Optional<Long> maxNumResultsThe maximum number of results to return. This number should be between 1 and 50 inclusive.
-
Optional<RankingOptions> rankingOptionsRanking options for search.
-
Optional<HybridSearch> hybridSearchWeights that control how reciprocal rank fusion balances semantic embedding matches versus sparse keyword matches when hybrid search is enabled.
-
double embeddingWeightThe weight of the embedding in the reciprocal ranking fusion.
-
double textWeightThe weight of the text in the reciprocal ranking fusion.
-
-
Optional<Ranker> rankerThe ranker to use for the file search.
-
AUTO("auto") -
DEFAULT_2024_11_15("default-2024-11-15")
-
-
Optional<Double> scoreThresholdThe score threshold for the file search, a number between 0 and 1. Numbers closer to 1 will attempt to return only the most relevant results, but may return fewer results.
-
-
-
class ComputerTool:A tool that controls a virtual computer. Learn more about the computer tool.
-
JsonValue; type "computer"constantThe type of the computer tool. Always
computer.COMPUTER("computer")
-
-
class ComputerUsePreviewTool:A tool that controls a virtual computer. Learn more about the computer tool.
-
long displayHeightThe height of the computer display.
-
long displayWidthThe width of the computer display.
-
Environment environmentThe type of computer environment to control.
-
WINDOWS("windows") -
MAC("mac") -
LINUX("linux") -
UBUNTU("ubuntu") -
BROWSER("browser")
-
-
JsonValue; type "computer_use_preview"constantThe type of the computer use tool. Always
computer_use_preview.COMPUTER_USE_PREVIEW("computer_use_preview")
-
-
class WebSearchTool:Search the Internet for sources related to the prompt. Learn more about the web search tool.
-
Type typeThe type of the web search tool. One of
web_searchorweb_search_2025_08_26.-
WEB_SEARCH("web_search") -
WEB_SEARCH_2025_08_26("web_search_2025_08_26")
-
-
Optional<Filters> filtersFilters for the search.
-
Optional<List<String>> allowedDomainsAllowed domains for the search. If not provided, all domains are allowed. Subdomains of the provided domains are allowed as well.
Example:
["pubmed.ncbi.nlm.nih.gov"]
-
-
Optional<SearchContextSize> searchContextSizeHigh level guidance for the amount of context window space to use for the search. One of
low,medium, orhigh.mediumis the default.-
LOW("low") -
MEDIUM("medium") -
HIGH("high")
-
-
Optional<UserLocation> userLocationThe approximate location of the user.
-
Optional<String> cityFree text input for the city of the user, e.g.
San Francisco. -
Optional<String> countryThe two-letter ISO country code of the user, e.g.
US. -
Optional<String> regionFree text input for the region of the user, e.g.
California. -
Optional<String> timezoneThe IANA timezone of the user, e.g.
America/Los_Angeles. -
Optional<Type> typeThe type of location approximation. Always
approximate.APPROXIMATE("approximate")
-
-
-
Mcp-
String serverLabelA label for this MCP server, used to identify it in tool calls.
-
JsonValue; type "mcp"constantThe type of the MCP tool. Always
mcp.MCP("mcp")
-
Optional<AllowedTools> allowedToolsList of allowed tool names or a filter object.
-
List<String> -
class McpToolFilter:A filter object to specify which tools are allowed.
-
Optional<Boolean> readOnlyIndicates whether or not a tool modifies data or is read-only. If an MCP server is annotated with
readOnlyHint, it will match this filter. -
Optional<List<String>> toolNamesList of allowed tool names.
-
-
-
Optional<String> authorizationAn OAuth access token that can be used with a remote MCP server, either with a custom MCP server URL or a service connector. Your application must handle the OAuth authorization flow and provide the token here.
-
Optional<ConnectorId> connectorIdIdentifier for service connectors, like those available in ChatGPT. One of
server_urlorconnector_idmust be provided. Learn more about service connectors here.Currently supported
connector_idvalues are:-
Dropbox:
connector_dropbox -
Gmail:
connector_gmail -
Google Calendar:
connector_googlecalendar -
Google Drive:
connector_googledrive -
Microsoft Teams:
connector_microsoftteams -
Outlook Calendar:
connector_outlookcalendar -
Outlook Email:
connector_outlookemail -
SharePoint:
connector_sharepoint -
CONNECTOR_DROPBOX("connector_dropbox") -
CONNECTOR_GMAIL("connector_gmail") -
CONNECTOR_GOOGLECALENDAR("connector_googlecalendar") -
CONNECTOR_GOOGLEDRIVE("connector_googledrive") -
CONNECTOR_MICROSOFTTEAMS("connector_microsoftteams") -
CONNECTOR_OUTLOOKCALENDAR("connector_outlookcalendar") -
CONNECTOR_OUTLOOKEMAIL("connector_outlookemail") -
CONNECTOR_SHAREPOINT("connector_sharepoint")
-
-
Optional<Boolean> deferLoadingWhether this MCP tool is deferred and discovered via tool search.
-
Optional<Headers> headersOptional HTTP headers to send to the MCP server. Use for authentication or other purposes.
-
Optional<RequireApproval> requireApprovalSpecify which of the MCP server's tools require approval.
-
class McpToolApprovalFilter:Specify which of the MCP server's tools require approval. Can be
always,never, or a filter object associated with tools that require approval.-
Optional<Always> alwaysA filter object to specify which tools are allowed.
-
Optional<Boolean> readOnlyIndicates whether or not a tool modifies data or is read-only. If an MCP server is annotated with
readOnlyHint, it will match this filter. -
Optional<List<String>> toolNamesList of allowed tool names.
-
-
Optional<Never> neverA filter object to specify which tools are allowed.
-
Optional<Boolean> readOnlyIndicates whether or not a tool modifies data or is read-only. If an MCP server is annotated with
readOnlyHint, it will match this filter. -
Optional<List<String>> toolNamesList of allowed tool names.
-
-
-
enum McpToolApprovalSetting:Specify a single approval policy for all tools. One of
alwaysornever. When set toalways, all tools will require approval. When set tonever, all tools will not require approval.-
ALWAYS("always") -
NEVER("never")
-
-
-
Optional<String> serverDescriptionOptional description of the MCP server, used to provide more context.
-
Optional<String> serverUrlThe URL for the MCP server. One of
server_urlorconnector_idmust be provided.
-
-
CodeInterpreter-
Container containerThe code interpreter container. Can be a container ID or an object that specifies uploaded file IDs to make available to your code, along with an optional
memory_limitsetting.-
String -
class CodeInterpreterToolAuto:Configuration for a code interpreter container. Optionally specify the IDs of the files to run the code on.
-
JsonValue; type "auto"constantAlways
auto.AUTO("auto")
-
Optional<List<String>> fileIdsAn optional list of uploaded files to make available to your code.
-
Optional<MemoryLimit> memoryLimitThe memory limit for the code interpreter container.
-
_1G("1g") -
_4G("4g") -
_16G("16g") -
_64G("64g")
-
-
Optional<NetworkPolicy> networkPolicyNetwork access policy for the container.
-
class ContainerNetworkPolicyDisabled:-
JsonValue; type "disabled"constantDisable outbound network access. Always
disabled.DISABLED("disabled")
-
-
class ContainerNetworkPolicyAllowlist:-
List<String> allowedDomainsA list of allowed domains when type is
allowlist. -
JsonValue; type "allowlist"constantAllow outbound network access only to specified domains. Always
allowlist.ALLOWLIST("allowlist")
-
Optional<List<ContainerNetworkPolicyDomainSecret>> domainSecretsOptional domain-scoped secrets for allowlisted domains.
-
String domainThe domain associated with the secret.
-
String nameThe name of the secret to inject for the domain.
-
String valueThe secret value to inject for the domain.
-
-
-
-
-
-
JsonValue; type "code_interpreter"constantThe type of the code interpreter tool. Always
code_interpreter.CODE_INTERPRETER("code_interpreter")
-
-
ImageGeneration-
JsonValue; type "image_generation"constantThe type of the image generation tool. Always
image_generation.IMAGE_GENERATION("image_generation")
-
Optional<Action> actionWhether to generate a new image or edit an existing image. Default:
auto.-
GENERATE("generate") -
EDIT("edit") -
AUTO("auto")
-
-
Optional<Background> backgroundAllows to set transparency for the background of the generated image(s). This parameter is only supported for GPT image models that support transparent backgrounds. Must be one of
transparent,opaque, orauto(default value). Whenautois used, the model will automatically determine the best background for the image.gpt-image-2andgpt-image-2-2026-04-21do not support transparent backgrounds. Requests withbackgroundset totransparentwill return an error for these models; useopaqueorautoinstead.If
transparent, the output format needs to support transparency, so it should be set to eitherpng(default value) orwebp.-
TRANSPARENT("transparent") -
OPAQUE("opaque") -
AUTO("auto")
-
-
Optional<InputFidelity> inputFidelityControl how much effort the model will exert to match the style and features, especially facial features, of input images. This parameter is only supported for
gpt-image-1andgpt-image-1.5and later models, unsupported forgpt-image-1-mini. Supportshighandlow. Defaults tolow.-
HIGH("high") -
LOW("low")
-
-
Optional<InputImageMask> inputImageMaskOptional mask for inpainting. Contains
image_url(string, optional) andfile_id(string, optional).-
Optional<String> fileIdFile ID for the mask image.
-
Optional<String> imageUrlBase64-encoded mask image.
-
-
Optional<Model> modelThe image generation model to use. Default:
gpt-image-1.-
GPT_IMAGE_1("gpt-image-1") -
GPT_IMAGE_1_MINI("gpt-image-1-mini") -
GPT_IMAGE_2("gpt-image-2") -
GPT_IMAGE_2_2026_04_21("gpt-image-2-2026-04-21") -
GPT_IMAGE_1_5("gpt-image-1.5") -
CHATGPT_IMAGE_LATEST("chatgpt-image-latest")
-
-
Optional<Moderation> moderationModeration level for the generated image. Default:
auto.-
AUTO("auto") -
LOW("low")
-
-
Optional<Long> outputCompressionCompression level for the output image. Default: 100.
-
Optional<OutputFormat> outputFormatThe output format of the generated image. One of
png,webp, orjpeg. Default:png.-
PNG("png") -
WEBP("webp") -
JPEG("jpeg")
-
-
Optional<Long> partialImagesNumber of partial images to generate in streaming mode, from 0 (default value) to 3.
-
Optional<Quality> qualityThe quality of the generated image. One of
low,medium,high, orauto. Default:auto.-
LOW("low") -
MEDIUM("medium") -
HIGH("high") -
AUTO("auto")
-
-
Optional<Size> sizeThe size of the generated images. For
gpt-image-2andgpt-image-2-2026-04-21, arbitrary resolutions are supported asWIDTHxHEIGHTstrings, for example1536x864. Width and height must both be divisible by 16 and the requested aspect ratio must be between 1:3 and 3:1. Resolutions above2560x1440are experimental, and the maximum supported resolution is3840x2160. The requested size must also satisfy the model's current pixel and edge limits. The standard sizes1024x1024,1536x1024, and1024x1536are supported by the GPT image models;autois supported for models that allow automatic sizing. Fordall-e-2, use one of256x256,512x512, or1024x1024. Fordall-e-3, use one of1024x1024,1792x1024, or1024x1792.-
_1024X1024("1024x1024") -
_1024X1536("1024x1536") -
_1536X1024("1536x1024") -
AUTO("auto")
-
-
-
JsonValue;-
JsonValue; type "local_shell"constantThe type of the local shell tool. Always
local_shell.LOCAL_SHELL("local_shell")
-
-
class FunctionShellTool:A tool that allows the model to execute shell commands.
-
JsonValue; type "shell"constantThe type of the shell tool. Always
shell.SHELL("shell")
-
Optional<Environment> environment-
class ContainerAuto:-
JsonValue; type "container_auto"constantAutomatically creates a container for this request
CONTAINER_AUTO("container_auto")
-
Optional<List<String>> fileIdsAn optional list of uploaded files to make available to your code.
-
Optional<MemoryLimit> memoryLimitThe memory limit for the container.
-
_1G("1g") -
_4G("4g") -
_16G("16g") -
_64G("64g")
-
-
Optional<NetworkPolicy> networkPolicyNetwork access policy for the container.
-
class ContainerNetworkPolicyDisabled: -
class ContainerNetworkPolicyAllowlist:
-
-
Optional<List<Skill>> skillsAn optional list of skills referenced by id or inline data.
-
class SkillReference:-
String skillIdThe ID of the referenced skill.
-
JsonValue; type "skill_reference"constantReferences a skill created with the /v1/skills endpoint.
SKILL_REFERENCE("skill_reference")
-
Optional<String> versionOptional skill version. Use a positive integer or 'latest'. Omit for default.
-
-
class InlineSkill:-
String descriptionThe description of the skill.
-
String nameThe name of the skill.
-
InlineSkillSource sourceInline skill payload
-
String dataBase64-encoded skill zip bundle.
-
JsonValue; mediaType "application/zip"constantThe media type of the inline skill payload. Must be
application/zip.APPLICATION_ZIP("application/zip")
-
JsonValue; type "base64"constantThe type of the inline skill source. Must be
base64.BASE64("base64")
-
-
JsonValue; type "inline"constantDefines an inline skill for this request.
INLINE("inline")
-
-
-
-
class LocalEnvironment:-
JsonValue; type "local"constantUse a local computer environment.
LOCAL("local")
-
Optional<List<LocalSkill>> skillsAn optional list of skills.
-
String descriptionThe description of the skill.
-
String nameThe name of the skill.
-
String pathThe path to the directory containing the skill.
-
-
-
class ContainerReference:-
String containerIdThe ID of the referenced container.
-
JsonValue; type "container_reference"constantReferences a container created with the /v1/containers endpoint
CONTAINER_REFERENCE("container_reference")
-
-
-
-
class CustomTool:A custom tool that processes input using a specified format. Learn more about custom tools
-
String nameThe name of the custom tool, used to identify it in tool calls.
-
JsonValue; type "custom"constantThe type of the custom tool. Always
custom.CUSTOM("custom")
-
Optional<Boolean> deferLoadingWhether this tool should be deferred and discovered via tool search.
-
Optional<String> descriptionOptional description of the custom tool, used to provide more context.
-
Optional<CustomToolInputFormat> formatThe input format for the custom tool. Default is unconstrained text.
-
JsonValue;-
JsonValue; type "text"constantUnconstrained text format. Always
text.TEXT("text")
-
-
Grammar-
String definitionThe grammar definition.
-
Syntax syntaxThe syntax of the grammar definition. One of
larkorregex.-
LARK("lark") -
REGEX("regex")
-
-
JsonValue; type "grammar"constantGrammar format. Always
grammar.GRAMMAR("grammar")
-
-
-
-
class NamespaceTool:Groups function/custom tools under a shared namespace.
-
String descriptionA description of the namespace shown to the model.
-
String nameThe namespace name used in tool calls (for example,
crm). -
List<Tool> toolsThe function/custom tools available inside this namespace.
-
class Function:-
String name -
JsonValue; type "function"constantFUNCTION("function")
-
Optional<Boolean> deferLoadingWhether this function should be deferred and discovered via tool search.
-
Optional<String> description -
Optional<JsonValue> parameters -
Optional<Boolean> strict
-
-
class CustomTool:A custom tool that processes input using a specified format. Learn more about custom tools
-
-
JsonValue; type "namespace"constantThe type of the tool. Always
namespace.NAMESPACE("namespace")
-
-
class ToolSearchTool:Hosted or BYOT tool search configuration for deferred tools.
-
JsonValue; type "tool_search"constantThe type of the tool. Always
tool_search.TOOL_SEARCH("tool_search")
-
Optional<String> descriptionDescription shown to the model for a client-executed tool search tool.
-
Optional<Execution> executionWhether tool search is executed by the server or by the client.
-
SERVER("server") -
CLIENT("client")
-
-
Optional<JsonValue> parametersParameter schema for a client-executed tool search tool.
-
-
class WebSearchPreviewTool:This tool searches the web for relevant results to use in a response. Learn more about the web search tool.
-
Type typeThe type of the web search tool. One of
web_search_previeworweb_search_preview_2025_03_11.-
WEB_SEARCH_PREVIEW("web_search_preview") -
WEB_SEARCH_PREVIEW_2025_03_11("web_search_preview_2025_03_11")
-
-
Optional<List<SearchContentType>> searchContentTypes-
TEXT("text") -
IMAGE("image")
-
-
Optional<SearchContextSize> searchContextSizeHigh level guidance for the amount of context window space to use for the search. One of
low,medium, orhigh.mediumis the default.-
LOW("low") -
MEDIUM("medium") -
HIGH("high")
-
-
Optional<UserLocation> userLocationThe user's location.
-
JsonValue; type "approximate"constantThe type of location approximation. Always
approximate.APPROXIMATE("approximate")
-
Optional<String> cityFree text input for the city of the user, e.g.
San Francisco. -
Optional<String> countryThe two-letter ISO country code of the user, e.g.
US. -
Optional<String> regionFree text input for the region of the user, e.g.
California. -
Optional<String> timezoneThe IANA timezone of the user, e.g.
America/Los_Angeles.
-
-
-
class ApplyPatchTool:Allows the assistant to create, delete, or update files using unified diffs.
-
JsonValue; type "apply_patch"constantThe type of the tool. Always
apply_patch.APPLY_PATCH("apply_patch")
-
-
-
JsonValue; type "tool_search_output"constantThe item type. Always
tool_search_output.TOOL_SEARCH_OUTPUT("tool_search_output")
-
Optional<String> idThe unique ID of this tool search output.
-
Optional<String> callIdThe unique ID of the tool search call generated by the model.
-
Optional<Execution> executionWhether tool search was executed by the server or by the client.
-
SERVER("server") -
CLIENT("client")
-
-
Optional<Status> statusThe status of the tool search output.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
AdditionalTools-
JsonValue; role "developer"constantThe role that provided the additional tools. Only
developeris supported.DEVELOPER("developer")
-
List<Tool> toolsA list of additional tools made available at this item.
-
class FunctionTool:Defines a function in your own code the model can choose to call. Learn more about function calling.
-
class FileSearchTool:A tool that searches for relevant content from uploaded files. Learn more about the file search tool.
-
class ComputerTool:A tool that controls a virtual computer. Learn more about the computer tool.
-
class ComputerUsePreviewTool:A tool that controls a virtual computer. Learn more about the computer tool.
-
class WebSearchTool:Search the Internet for sources related to the prompt. Learn more about the web search tool.
-
Mcp -
CodeInterpreter -
ImageGeneration -
JsonValue; -
class FunctionShellTool:A tool that allows the model to execute shell commands.
-
class CustomTool:A custom tool that processes input using a specified format. Learn more about custom tools
-
class NamespaceTool:Groups function/custom tools under a shared namespace.
-
class ToolSearchTool:Hosted or BYOT tool search configuration for deferred tools.
-
class WebSearchPreviewTool:This tool searches the web for relevant results to use in a response. Learn more about the web search tool.
-
class ApplyPatchTool:Allows the assistant to create, delete, or update files using unified diffs.
-
-
JsonValue; type "additional_tools"constantThe item type. Always
additional_tools.ADDITIONAL_TOOLS("additional_tools")
-
Optional<String> idThe unique ID of this additional tools item.
-
-
class ResponseReasoningItem:A description of the chain of thought used by a reasoning model while generating a response. Be sure to include these items in your
inputto the Responses API for subsequent turns of a conversation if you are manually managing context.-
String idThe unique identifier of the reasoning content.
-
List<Summary> summaryReasoning summary content.
-
String textA summary of the reasoning output from the model so far.
-
JsonValue; type "summary_text"constantThe type of the object. Always
summary_text.SUMMARY_TEXT("summary_text")
-
-
JsonValue; type "reasoning"constantThe type of the object. Always
reasoning.REASONING("reasoning")
-
Optional<List<Content>> contentReasoning text content.
-
String textThe reasoning text from the model.
-
JsonValue; type "reasoning_text"constantThe type of the reasoning text. Always
reasoning_text.REASONING_TEXT("reasoning_text")
-
-
Optional<String> encryptedContentThe encrypted content of the reasoning item - populated when a response is generated with
reasoning.encrypted_contentin theincludeparameter. -
Optional<Status> statusThe status of the item. One of
in_progress,completed, orincomplete. Populated when items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
class ResponseCompactionItemParam:A compaction item generated by the
v1/responses/compactAPI.-
String encryptedContentThe encrypted content of the compaction summary.
-
JsonValue; type "compaction"constantThe type of the item. Always
compaction.COMPACTION("compaction")
-
Optional<String> idThe ID of the compaction item.
-
-
ImageGenerationCall-
String idThe unique ID of the image generation call.
-
Optional<String> resultThe generated image encoded in base64.
-
Status statusThe status of the image generation call.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
GENERATING("generating") -
FAILED("failed")
-
-
JsonValue; type "image_generation_call"constantThe type of the image generation call. Always
image_generation_call.IMAGE_GENERATION_CALL("image_generation_call")
-
-
class ResponseCodeInterpreterToolCall:A tool call to run code.
-
String idThe unique ID of the code interpreter tool call.
-
Optional<String> codeThe code to run, or null if not available.
-
String containerIdThe ID of the container used to run the code.
-
Optional<List<Output>> outputsThe outputs generated by the code interpreter, such as logs or images. Can be null if no outputs are available.
-
class Logs:The logs output from the code interpreter.
-
String logsThe logs output from the code interpreter.
-
JsonValue; type "logs"constantThe type of the output. Always
logs.LOGS("logs")
-
-
class Image:The image output from the code interpreter.
-
JsonValue; type "image"constantThe type of the output. Always
image.IMAGE("image")
-
String urlThe URL of the image output from the code interpreter.
-
-
-
Status statusThe status of the code interpreter tool call. Valid values are
in_progress,completed,incomplete,interpreting, andfailed.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
INTERPRETING("interpreting") -
FAILED("failed")
-
-
JsonValue; type "code_interpreter_call"constantThe type of the code interpreter tool call. Always
code_interpreter_call.CODE_INTERPRETER_CALL("code_interpreter_call")
-
-
LocalShellCall-
String idThe unique ID of the local shell call.
-
Action actionExecute a shell command on the server.
-
List<String> commandThe command to run.
-
Env envEnvironment variables to set for the command.
-
JsonValue; type "exec"constantThe type of the local shell action. Always
exec.EXEC("exec")
-
Optional<Long> timeoutMsOptional timeout in milliseconds for the command.
-
Optional<String> userOptional user to run the command as.
-
Optional<String> workingDirectoryOptional working directory to run the command in.
-
-
String callIdThe unique ID of the local shell tool call generated by the model.
-
Status statusThe status of the local shell call.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
JsonValue; type "local_shell_call"constantThe type of the local shell call. Always
local_shell_call.LOCAL_SHELL_CALL("local_shell_call")
-
-
LocalShellCallOutput-
String idThe unique ID of the local shell tool call generated by the model.
-
String outputA JSON string of the output of the local shell tool call.
-
JsonValue; type "local_shell_call_output"constantThe type of the local shell tool call output. Always
local_shell_call_output.LOCAL_SHELL_CALL_OUTPUT("local_shell_call_output")
-
Optional<Status> statusThe status of the item. One of
in_progress,completed, orincomplete.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
ShellCall-
Action actionThe shell commands and limits that describe how to run the tool call.
-
List<String> commandsOrdered shell commands for the execution environment to run.
-
Optional<Long> maxOutputLengthMaximum number of UTF-8 characters to capture from combined stdout and stderr output.
-
Optional<Long> timeoutMsMaximum wall-clock time in milliseconds to allow the shell commands to run.
-
-
String callIdThe unique ID of the shell tool call generated by the model.
-
JsonValue; type "shell_call"constantThe type of the item. Always
shell_call.SHELL_CALL("shell_call")
-
Optional<String> idThe unique ID of the shell tool call. Populated when this item is returned via API.
-
Optional<Environment> environmentThe environment to execute the shell commands in.
-
class LocalEnvironment: -
class ContainerReference:
-
-
Optional<Status> statusThe status of the shell call. One of
in_progress,completed, orincomplete.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
ShellCallOutput-
String callIdThe unique ID of the shell tool call generated by the model.
-
List<ResponseFunctionShellCallOutputContent> outputCaptured chunks of stdout and stderr output, along with their associated outcomes.
-
Outcome outcomeThe exit or timeout outcome associated with this shell call.
-
JsonValue;-
JsonValue; type "timeout"constantThe outcome type. Always
timeout.TIMEOUT("timeout")
-
-
class Exit:Indicates that the shell commands finished and returned an exit code.
-
long exitCodeThe exit code returned by the shell process.
-
JsonValue; type "exit"constantThe outcome type. Always
exit.EXIT("exit")
-
-
-
String stderrCaptured stderr output for the shell call.
-
String stdoutCaptured stdout output for the shell call.
-
-
JsonValue; type "shell_call_output"constantThe type of the item. Always
shell_call_output.SHELL_CALL_OUTPUT("shell_call_output")
-
Optional<String> idThe unique ID of the shell tool call output. Populated when this item is returned via API.
-
Optional<Long> maxOutputLengthThe maximum number of UTF-8 characters captured for this shell call's combined output.
-
Optional<Status> statusThe status of the shell call output.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
ApplyPatchCall-
String callIdThe unique ID of the apply patch tool call generated by the model.
-
Operation operationThe specific create, delete, or update instruction for the apply_patch tool call.
-
class CreateFile:Instruction for creating a new file via the apply_patch tool.
-
String diffUnified diff content to apply when creating the file.
-
String pathPath of the file to create relative to the workspace root.
-
JsonValue; type "create_file"constantThe operation type. Always
create_file.CREATE_FILE("create_file")
-
-
class DeleteFile:Instruction for deleting an existing file via the apply_patch tool.
-
String pathPath of the file to delete relative to the workspace root.
-
JsonValue; type "delete_file"constantThe operation type. Always
delete_file.DELETE_FILE("delete_file")
-
-
class UpdateFile:Instruction for updating an existing file via the apply_patch tool.
-
String diffUnified diff content to apply to the existing file.
-
String pathPath of the file to update relative to the workspace root.
-
JsonValue; type "update_file"constantThe operation type. Always
update_file.UPDATE_FILE("update_file")
-
-
-
Status statusThe status of the apply patch tool call. One of
in_progressorcompleted.-
IN_PROGRESS("in_progress") -
COMPLETED("completed")
-
-
JsonValue; type "apply_patch_call"constantThe type of the item. Always
apply_patch_call.APPLY_PATCH_CALL("apply_patch_call")
-
Optional<String> idThe unique ID of the apply patch tool call. Populated when this item is returned via API.
-
-
ApplyPatchCallOutput-
String callIdThe unique ID of the apply patch tool call generated by the model.
-
Status statusThe status of the apply patch tool call output. One of
completedorfailed.-
COMPLETED("completed") -
FAILED("failed")
-
-
JsonValue; type "apply_patch_call_output"constantThe type of the item. Always
apply_patch_call_output.APPLY_PATCH_CALL_OUTPUT("apply_patch_call_output")
-
Optional<String> idThe unique ID of the apply patch tool call output. Populated when this item is returned via API.
-
Optional<String> outputOptional human-readable log text from the apply patch tool (e.g., patch results or errors).
-
-
McpListTools-
String idThe unique ID of the list.
-
String serverLabelThe label of the MCP server.
-
List<Tool> toolsThe tools available on the server.
-
JsonValue inputSchemaThe JSON schema describing the tool's input.
-
String nameThe name of the tool.
-
Optional<JsonValue> annotationsAdditional annotations about the tool.
-
Optional<String> descriptionThe description of the tool.
-
-
JsonValue; type "mcp_list_tools"constantThe type of the item. Always
mcp_list_tools.MCP_LIST_TOOLS("mcp_list_tools")
-
Optional<String> errorError message if the server could not list tools.
-
-
McpApprovalRequest-
String idThe unique ID of the approval request.
-
String argumentsA JSON string of arguments for the tool.
-
String nameThe name of the tool to run.
-
String serverLabelThe label of the MCP server making the request.
-
JsonValue; type "mcp_approval_request"constantThe type of the item. Always
mcp_approval_request.MCP_APPROVAL_REQUEST("mcp_approval_request")
-
-
McpApprovalResponse-
String approvalRequestIdThe ID of the approval request being answered.
-
boolean approveWhether the request was approved.
-
JsonValue; type "mcp_approval_response"constantThe type of the item. Always
mcp_approval_response.MCP_APPROVAL_RESPONSE("mcp_approval_response")
-
Optional<String> idThe unique ID of the approval response
-
Optional<String> reasonOptional reason for the decision.
-
-
McpCall-
String idThe unique ID of the tool call.
-
String argumentsA JSON string of the arguments passed to the tool.
-
String nameThe name of the tool that was run.
-
String serverLabelThe label of the MCP server running the tool.
-
JsonValue; type "mcp_call"constantThe type of the item. Always
mcp_call.MCP_CALL("mcp_call")
-
Optional<String> approvalRequestIdUnique identifier for the MCP tool call approval request. Include this value in a subsequent
mcp_approval_responseinput to approve or reject the corresponding tool call. -
Optional<String> errorThe error from the tool call, if any.
-
Optional<String> outputThe output from the tool call.
-
Optional<Status> statusThe status of the tool call. One of
in_progress,completed,incomplete,calling, orfailed.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
CALLING("calling") -
FAILED("failed")
-
-
-
class ResponseCustomToolCallOutput:The output of a custom tool call from your code, being sent back to the model.
-
String callIdThe call ID, used to map this custom tool call output to a custom tool call.
-
Output outputThe output from the custom tool call generated by your code. Can be a string or an list of output content.
-
String -
List<FunctionAndCustomToolCallOutput>-
class ResponseInputText:A text input to the model.
-
class ResponseInputImage:An image input to the model. Learn about image inputs.
-
class ResponseInputFile:A file input to the model.
-
-
-
JsonValue; type "custom_tool_call_output"constantThe type of the custom tool call output. Always
custom_tool_call_output.CUSTOM_TOOL_CALL_OUTPUT("custom_tool_call_output")
-
Optional<String> idThe unique ID of the custom tool call output in the OpenAI platform.
-
-
class ResponseCustomToolCall:A call to a custom tool created by the model.
-
String callIdAn identifier used to map this custom tool call to a tool call output.
-
String inputThe input for the custom tool call generated by the model.
-
String nameThe name of the custom tool being called.
-
JsonValue; type "custom_tool_call"constantThe type of the custom tool call. Always
custom_tool_call.CUSTOM_TOOL_CALL("custom_tool_call")
-
Optional<String> idThe unique ID of the custom tool call in the OpenAI platform.
-
Optional<String> namespaceThe namespace of the custom tool being called.
-
-
JsonValue;-
JsonValue; type "compaction_trigger"constantThe type of the item. Always
compaction_trigger.COMPACTION_TRIGGER("compaction_trigger")
-
-
ItemReference-
String idThe ID of the item to reference.
-
Optional<Type> typeThe type of item to reference. Always
item_reference.ITEM_REFERENCE("item_reference")
-
-
-
-
Optional<String> instructionsA system (or developer) message inserted into the model's context. When used along with
previous_response_id, the instructions from a previous response will not be carried over to the next response. This makes it simple to swap out system (or developer) messages in new responses. -
Optional<String> previousResponseIdThe unique ID of the previous response to the model. Use this to create multi-turn conversations. Learn more about conversation state. Cannot be used in conjunction with
conversation. -
Optional<String> promptCacheKeyA key to use when reading from or writing to the prompt cache.
-
Optional<PromptCacheRetention> promptCacheRetentionHow long to retain a prompt cache entry created by this request.
-
IN_MEMORY("in_memory") -
_24H("24h")
-
-
Optional<ServiceTier> serviceTierThe service tier to use for this request.
-
AUTO("auto") -
DEFAULT("default") -
FLEX("flex") -
PRIORITY("priority")
-
-
Returns
-
class CompactedResponse:-
String idThe unique identifier for the compacted response.
-
long createdAtUnix timestamp (in seconds) when the compacted conversation was created.
-
JsonValue; object_ "response.compaction"constantThe object type. Always
response.compaction.RESPONSE_COMPACTION("response.compaction")
-
List<ResponseOutputItem> outputThe compacted list of output items. This is a list of all user messages, followed by a single compaction item.
-
class ResponseOutputMessage:An output message from the model.
-
String idThe unique ID of the output message.
-
List<Content> contentThe content of the output message.
-
class ResponseOutputText:A text output from the model.
-
List<Annotation> annotationsThe annotations of the text output.
-
class FileCitation:A citation to a file.
-
String fileIdThe ID of the file.
-
String filenameThe filename of the file cited.
-
long indexThe index of the file in the list of files.
-
JsonValue; type "file_citation"constantThe type of the file citation. Always
file_citation.FILE_CITATION("file_citation")
-
-
class UrlCitation:A citation for a web resource used to generate a model response.
-
long endIndexThe index of the last character of the URL citation in the message.
-
long startIndexThe index of the first character of the URL citation in the message.
-
String titleThe title of the web resource.
-
JsonValue; type "url_citation"constantThe type of the URL citation. Always
url_citation.URL_CITATION("url_citation")
-
String urlThe URL of the web resource.
-
-
class ContainerFileCitation:A citation for a container file used to generate a model response.
-
String containerIdThe ID of the container file.
-
long endIndexThe index of the last character of the container file citation in the message.
-
String fileIdThe ID of the file.
-
String filenameThe filename of the container file cited.
-
long startIndexThe index of the first character of the container file citation in the message.
-
JsonValue; type "container_file_citation"constantThe type of the container file citation. Always
container_file_citation.CONTAINER_FILE_CITATION("container_file_citation")
-
-
class FilePath:A path to a file.
-
String fileIdThe ID of the file.
-
long indexThe index of the file in the list of files.
-
JsonValue; type "file_path"constantThe type of the file path. Always
file_path.FILE_PATH("file_path")
-
-
-
String textThe text output from the model.
-
JsonValue; type "output_text"constantThe type of the output text. Always
output_text.OUTPUT_TEXT("output_text")
-
Optional<List<Logprob>> logprobs-
String token -
List<long> bytes -
double logprob -
List<TopLogprob> topLogprobs-
String token -
List<long> bytes -
double logprob
-
-
-
-
class ResponseOutputRefusal:A refusal from the model.
-
String refusalThe refusal explanation from the model.
-
JsonValue; type "refusal"constantThe type of the refusal. Always
refusal.REFUSAL("refusal")
-
-
-
JsonValue; role "assistant"constantThe role of the output message. Always
assistant.ASSISTANT("assistant")
-
Status statusThe status of the message input. One of
in_progress,completed, orincomplete. Populated when input items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
JsonValue; type "message"constantThe type of the output message. Always
message.MESSAGE("message")
-
Optional<Phase> phaseLabels an
assistantmessage as intermediate commentary (commentary) or the final answer (final_answer). For models likegpt-5.3-codexand beyond, when sending follow-up requests, preserve and resend phase on all assistant messages — dropping it can degrade performance. Not used for user messages.-
COMMENTARY("commentary") -
FINAL_ANSWER("final_answer")
-
-
-
class ResponseFileSearchToolCall:The results of a file search tool call. See the file search guide for more information.
-
String idThe unique ID of the file search tool call.
-
List<String> queriesThe queries used to search for files.
-
Status statusThe status of the file search tool call. One of
in_progress,searching,incompleteorfailed,-
IN_PROGRESS("in_progress") -
SEARCHING("searching") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
FAILED("failed")
-
-
JsonValue; type "file_search_call"constantThe type of the file search tool call. Always
file_search_call.FILE_SEARCH_CALL("file_search_call")
-
Optional<List<Result>> resultsThe results of the file search tool call.
-
Optional<Attributes> attributesSet 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, booleans, or numbers.
-
String -
double -
boolean
-
-
Optional<String> fileIdThe unique ID of the file.
-
Optional<String> filenameThe name of the file.
-
Optional<Double> scoreThe relevance score of the file - a value between 0 and 1.
-
Optional<String> textThe text that was retrieved from the file.
-
-
-
class ResponseFunctionToolCall:A tool call to run a function. See the function calling guide for more information.
-
String argumentsA JSON string of the arguments to pass to the function.
-
String callIdThe unique ID of the function tool call generated by the model.
-
String nameThe name of the function to run.
-
JsonValue; type "function_call"constantThe type of the function tool call. Always
function_call.FUNCTION_CALL("function_call")
-
Optional<String> idThe unique ID of the function tool call.
-
Optional<String> namespaceThe namespace of the function to run.
-
Optional<Status> statusThe status of the item. One of
in_progress,completed, orincomplete. Populated when items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
class ResponseFunctionToolCallOutputItem:-
String idThe unique ID of the function call tool output.
-
String callIdThe unique ID of the function tool call generated by the model.
-
Output outputThe output from the function call generated by your code. Can be a string or an list of output content.
-
String -
List<FunctionAndCustomToolCallOutput>-
class ResponseInputText:A text input to the model.
-
String textThe text input to the model.
-
JsonValue; type "input_text"constantThe type of the input item. Always
input_text.INPUT_TEXT("input_text")
-
-
class ResponseInputImage:An image input to the model. Learn about image inputs.
-
Detail detailThe detail level of the image to be sent to the model. One of
high,low,auto, ororiginal. Defaults toauto.-
LOW("low") -
HIGH("high") -
AUTO("auto") -
ORIGINAL("original")
-
-
JsonValue; type "input_image"constantThe type of the input item. Always
input_image.INPUT_IMAGE("input_image")
-
Optional<String> fileIdThe ID of the file to be sent to the model.
-
Optional<String> imageUrlThe URL of the image to be sent to the model. A fully qualified URL or base64 encoded image in a data URL.
-
-
class ResponseInputFile:A file input to the model.
-
JsonValue; type "input_file"constantThe type of the input item. Always
input_file.INPUT_FILE("input_file")
-
Optional<Detail> detailThe detail level of the file to be sent to the model. Use
lowfor the default rendering behavior, orhighto render the file at higher quality. Defaults tolow.-
LOW("low") -
HIGH("high")
-
-
Optional<String> fileDataThe content of the file to be sent to the model.
-
Optional<String> fileIdThe ID of the file to be sent to the model.
-
Optional<String> fileUrlThe URL of the file to be sent to the model.
-
Optional<String> filenameThe name of the file to be sent to the model.
-
-
-
-
Status statusThe status of the item. One of
in_progress,completed, orincomplete. Populated when items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
JsonValue; type "function_call_output"constantThe type of the function tool call output. Always
function_call_output.FUNCTION_CALL_OUTPUT("function_call_output")
-
Optional<String> createdByThe identifier of the actor that created the item.
-
-
class ResponseFunctionWebSearch:The results of a web search tool call. See the web search guide for more information.
-
String idThe unique ID of the web search tool call.
-
Action actionAn object describing the specific action taken in this web search call. Includes details on how the model used the web (search, open_page, find_in_page).
-
class Search:Action type "search" - Performs a web search query.
-
JsonValue; type "search"constantThe action type.
SEARCH("search")
-
Optional<List<String>> queriesThe search queries.
-
Optional<String> queryThe search query.
-
Optional<List<Source>> sourcesThe sources used in the search.
-
JsonValue; type "url"constantThe type of source. Always
url.URL("url")
-
String urlThe URL of the source.
-
-
-
class OpenPage:Action type "open_page" - Opens a specific URL from search results.
-
JsonValue; type "open_page"constantThe action type.
OPEN_PAGE("open_page")
-
Optional<String> urlThe URL opened by the model.
-
-
class FindInPage:Action type "find_in_page": Searches for a pattern within a loaded page.
-
String patternThe pattern or text to search for within the page.
-
JsonValue; type "find_in_page"constantThe action type.
FIND_IN_PAGE("find_in_page")
-
String urlThe URL of the page searched for the pattern.
-
-
-
Status statusThe status of the web search tool call.
-
IN_PROGRESS("in_progress") -
SEARCHING("searching") -
COMPLETED("completed") -
FAILED("failed")
-
-
JsonValue; type "web_search_call"constantThe type of the web search tool call. Always
web_search_call.WEB_SEARCH_CALL("web_search_call")
-
-
class ResponseComputerToolCall:A tool call to a computer use tool. See the computer use guide for more information.
-
String idThe unique ID of the computer call.
-
String callIdAn identifier used when responding to the tool call with output.
-
List<PendingSafetyCheck> pendingSafetyChecksThe pending safety checks for the computer call.
-
String idThe ID of the pending safety check.
-
Optional<String> codeThe type of the pending safety check.
-
Optional<String> messageDetails about the pending safety check.
-
-
Status statusThe status of the item. One of
in_progress,completed, orincomplete. Populated when items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
Type typeThe type of the computer call. Always
computer_call.COMPUTER_CALL("computer_call")
-
Optional<Action> actionA click action.
-
class Click:A click action.
-
Button buttonIndicates which mouse button was pressed during the click. One of
left,right,wheel,back, orforward.-
LEFT("left") -
RIGHT("right") -
WHEEL("wheel") -
BACK("back") -
FORWARD("forward")
-
-
JsonValue; type "click"constantSpecifies the event type. For a click action, this property is always
click.CLICK("click")
-
long xThe x-coordinate where the click occurred.
-
long yThe y-coordinate where the click occurred.
-
Optional<List<String>> keysThe keys being held while clicking.
-
-
class DoubleClick:A double click action.
-
Optional<List<String>> keysThe keys being held while double-clicking.
-
JsonValue; type "double_click"constantSpecifies the event type. For a double click action, this property is always set to
double_click.DOUBLE_CLICK("double_click")
-
long xThe x-coordinate where the double click occurred.
-
long yThe y-coordinate where the double click occurred.
-
-
class Drag:A drag action.
-
List<Path> pathAn array of coordinates representing the path of the drag action. Coordinates will appear as an array of objects, eg
[ { x: 100, y: 200 }, { x: 200, y: 300 } ]-
long xThe x-coordinate.
-
long yThe y-coordinate.
-
-
JsonValue; type "drag"constantSpecifies the event type. For a drag action, this property is always set to
drag.DRAG("drag")
-
Optional<List<String>> keysThe keys being held while dragging the mouse.
-
-
class Keypress:A collection of keypresses the model would like to perform.
-
List<String> keysThe combination of keys the model is requesting to be pressed. This is an array of strings, each representing a key.
-
JsonValue; type "keypress"constantSpecifies the event type. For a keypress action, this property is always set to
keypress.KEYPRESS("keypress")
-
-
class Move:A mouse move action.
-
JsonValue; type "move"constantSpecifies the event type. For a move action, this property is always set to
move.MOVE("move")
-
long xThe x-coordinate to move to.
-
long yThe y-coordinate to move to.
-
Optional<List<String>> keysThe keys being held while moving the mouse.
-
-
JsonValue;-
JsonValue; type "screenshot"constantSpecifies the event type. For a screenshot action, this property is always set to
screenshot.SCREENSHOT("screenshot")
-
-
class Scroll:A scroll action.
-
long scrollXThe horizontal scroll distance.
-
long scrollYThe vertical scroll distance.
-
JsonValue; type "scroll"constantSpecifies the event type. For a scroll action, this property is always set to
scroll.SCROLL("scroll")
-
long xThe x-coordinate where the scroll occurred.
-
long yThe y-coordinate where the scroll occurred.
-
Optional<List<String>> keysThe keys being held while scrolling.
-
-
class Type:An action to type in text.
-
String textThe text to type.
-
JsonValue; type "type"constantSpecifies the event type. For a type action, this property is always set to
type.TYPE("type")
-
-
JsonValue;-
JsonValue; type "wait"constantSpecifies the event type. For a wait action, this property is always set to
wait.WAIT("wait")
-
-
-
Optional<List<ComputerAction>> actionsFlattened batched actions for
computer_use. Each action includes antypediscriminator and action-specific fields.-
Click-
Button buttonIndicates which mouse button was pressed during the click. One of
left,right,wheel,back, orforward.-
LEFT("left") -
RIGHT("right") -
WHEEL("wheel") -
BACK("back") -
FORWARD("forward")
-
-
JsonValue; type "click"constantSpecifies the event type. For a click action, this property is always
click.CLICK("click")
-
long xThe x-coordinate where the click occurred.
-
long yThe y-coordinate where the click occurred.
-
Optional<List<String>> keysThe keys being held while clicking.
-
-
DoubleClick-
Optional<List<String>> keysThe keys being held while double-clicking.
-
JsonValue; type "double_click"constantSpecifies the event type. For a double click action, this property is always set to
double_click.DOUBLE_CLICK("double_click")
-
long xThe x-coordinate where the double click occurred.
-
long yThe y-coordinate where the double click occurred.
-
-
Drag-
List<Path> pathAn array of coordinates representing the path of the drag action. Coordinates will appear as an array of objects, eg
[ { x: 100, y: 200 }, { x: 200, y: 300 } ]-
long xThe x-coordinate.
-
long yThe y-coordinate.
-
-
JsonValue; type "drag"constantSpecifies the event type. For a drag action, this property is always set to
drag.DRAG("drag")
-
Optional<List<String>> keysThe keys being held while dragging the mouse.
-
-
Keypress-
List<String> keysThe combination of keys the model is requesting to be pressed. This is an array of strings, each representing a key.
-
JsonValue; type "keypress"constantSpecifies the event type. For a keypress action, this property is always set to
keypress.KEYPRESS("keypress")
-
-
Move-
JsonValue; type "move"constantSpecifies the event type. For a move action, this property is always set to
move.MOVE("move")
-
long xThe x-coordinate to move to.
-
long yThe y-coordinate to move to.
-
Optional<List<String>> keysThe keys being held while moving the mouse.
-
-
JsonValue;-
JsonValue; type "screenshot"constantSpecifies the event type. For a screenshot action, this property is always set to
screenshot.SCREENSHOT("screenshot")
-
-
Scroll-
long scrollXThe horizontal scroll distance.
-
long scrollYThe vertical scroll distance.
-
JsonValue; type "scroll"constantSpecifies the event type. For a scroll action, this property is always set to
scroll.SCROLL("scroll")
-
long xThe x-coordinate where the scroll occurred.
-
long yThe y-coordinate where the scroll occurred.
-
Optional<List<String>> keysThe keys being held while scrolling.
-
-
Type-
String textThe text to type.
-
JsonValue; type "type"constantSpecifies the event type. For a type action, this property is always set to
type.TYPE("type")
-
-
JsonValue;-
JsonValue; type "wait"constantSpecifies the event type. For a wait action, this property is always set to
wait.WAIT("wait")
-
-
-
-
class ResponseComputerToolCallOutputItem:-
String idThe unique ID of the computer call tool output.
-
String callIdThe ID of the computer tool call that produced the output.
-
ResponseComputerToolCallOutputScreenshot outputA computer screenshot image used with the computer use tool.
-
JsonValue; type "computer_screenshot"constantSpecifies the event type. For a computer screenshot, this property is always set to
computer_screenshot.COMPUTER_SCREENSHOT("computer_screenshot")
-
Optional<String> fileIdThe identifier of an uploaded file that contains the screenshot.
-
Optional<String> imageUrlThe URL of the screenshot image.
-
-
Status statusThe status of the message input. One of
in_progress,completed, orincomplete. Populated when input items are returned via API.-
COMPLETED("completed") -
INCOMPLETE("incomplete") -
FAILED("failed") -
IN_PROGRESS("in_progress")
-
-
JsonValue; type "computer_call_output"constantThe type of the computer tool call output. Always
computer_call_output.COMPUTER_CALL_OUTPUT("computer_call_output")
-
Optional<List<AcknowledgedSafetyCheck>> acknowledgedSafetyChecksThe safety checks reported by the API that have been acknowledged by the developer.
-
String idThe ID of the pending safety check.
-
Optional<String> codeThe type of the pending safety check.
-
Optional<String> messageDetails about the pending safety check.
-
-
Optional<String> createdByThe identifier of the actor that created the item.
-
-
class ResponseReasoningItem:A description of the chain of thought used by a reasoning model while generating a response. Be sure to include these items in your
inputto the Responses API for subsequent turns of a conversation if you are manually managing context.-
String idThe unique identifier of the reasoning content.
-
List<Summary> summaryReasoning summary content.
-
String textA summary of the reasoning output from the model so far.
-
JsonValue; type "summary_text"constantThe type of the object. Always
summary_text.SUMMARY_TEXT("summary_text")
-
-
JsonValue; type "reasoning"constantThe type of the object. Always
reasoning.REASONING("reasoning")
-
Optional<List<Content>> contentReasoning text content.
-
String textThe reasoning text from the model.
-
JsonValue; type "reasoning_text"constantThe type of the reasoning text. Always
reasoning_text.REASONING_TEXT("reasoning_text")
-
-
Optional<String> encryptedContentThe encrypted content of the reasoning item - populated when a response is generated with
reasoning.encrypted_contentin theincludeparameter. -
Optional<Status> statusThe status of the item. One of
in_progress,completed, orincomplete. Populated when items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
class ResponseToolSearchCall:-
String idThe unique ID of the tool search call item.
-
JsonValue argumentsArguments used for the tool search call.
-
Optional<String> callIdThe unique ID of the tool search call generated by the model.
-
Execution executionWhether tool search was executed by the server or by the client.
-
SERVER("server") -
CLIENT("client")
-
-
Status statusThe status of the tool search call item that was recorded.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
JsonValue; type "tool_search_call"constantThe type of the item. Always
tool_search_call.TOOL_SEARCH_CALL("tool_search_call")
-
Optional<String> createdByThe identifier of the actor that created the item.
-
-
class ResponseToolSearchOutputItem:-
String idThe unique ID of the tool search output item.
-
Optional<String> callIdThe unique ID of the tool search call generated by the model.
-
Execution executionWhether tool search was executed by the server or by the client.
-
SERVER("server") -
CLIENT("client")
-
-
Status statusThe status of the tool search output item that was recorded.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
List<Tool> toolsThe loaded tool definitions returned by tool search.
-
class FunctionTool:Defines a function in your own code the model can choose to call. Learn more about function calling.
-
String nameThe name of the function to call.
-
Optional<Parameters> parametersA JSON schema object describing the parameters of the function.
-
Optional<Boolean> strictWhether to enforce strict parameter validation. Default
true. -
JsonValue; type "function"constantThe type of the function tool. Always
function.FUNCTION("function")
-
Optional<Boolean> deferLoadingWhether this function is deferred and loaded via tool search.
-
Optional<String> descriptionA description of the function. Used by the model to determine whether or not to call the function.
-
-
class FileSearchTool:A tool that searches for relevant content from uploaded files. Learn more about the file search tool.
-
JsonValue; type "file_search"constantThe type of the file search tool. Always
file_search.FILE_SEARCH("file_search")
-
List<String> vectorStoreIdsThe IDs of the vector stores to search.
-
Optional<Filters> filtersA filter to apply.
-
class ComparisonFilter:A filter used to compare a specified attribute key to a given value using a defined comparison operation.
-
String keyThe key to compare against the value.
-
Type typeSpecifies the comparison operator:
eq,ne,gt,gte,lt,lte,in,nin.-
eq: equals -
ne: not equal -
gt: greater than -
gte: greater than or equal -
lt: less than -
lte: less than or equal -
in: in -
nin: not in -
EQ("eq") -
NE("ne") -
GT("gt") -
GTE("gte") -
LT("lt") -
LTE("lte") -
IN("in") -
NIN("nin")
-
-
Value valueThe value to compare against the attribute key; supports string, number, or boolean types.
-
String -
double -
boolean -
List<ComparisonFilterValueItem>-
String -
double
-
-
-
-
class CompoundFilter:Combine multiple filters using
andoror.-
List<Filter> filtersArray of filters to combine. Items can be
ComparisonFilterorCompoundFilter.-
class ComparisonFilter:A filter used to compare a specified attribute key to a given value using a defined comparison operation.
-
JsonValue
-
-
Type typeType of operation:
andoror.-
AND("and") -
OR("or")
-
-
-
-
Optional<Long> maxNumResultsThe maximum number of results to return. This number should be between 1 and 50 inclusive.
-
Optional<RankingOptions> rankingOptionsRanking options for search.
-
Optional<HybridSearch> hybridSearchWeights that control how reciprocal rank fusion balances semantic embedding matches versus sparse keyword matches when hybrid search is enabled.
-
double embeddingWeightThe weight of the embedding in the reciprocal ranking fusion.
-
double textWeightThe weight of the text in the reciprocal ranking fusion.
-
-
Optional<Ranker> rankerThe ranker to use for the file search.
-
AUTO("auto") -
DEFAULT_2024_11_15("default-2024-11-15")
-
-
Optional<Double> scoreThresholdThe score threshold for the file search, a number between 0 and 1. Numbers closer to 1 will attempt to return only the most relevant results, but may return fewer results.
-
-
-
class ComputerTool:A tool that controls a virtual computer. Learn more about the computer tool.
-
JsonValue; type "computer"constantThe type of the computer tool. Always
computer.COMPUTER("computer")
-
-
class ComputerUsePreviewTool:A tool that controls a virtual computer. Learn more about the computer tool.
-
long displayHeightThe height of the computer display.
-
long displayWidthThe width of the computer display.
-
Environment environmentThe type of computer environment to control.
-
WINDOWS("windows") -
MAC("mac") -
LINUX("linux") -
UBUNTU("ubuntu") -
BROWSER("browser")
-
-
JsonValue; type "computer_use_preview"constantThe type of the computer use tool. Always
computer_use_preview.COMPUTER_USE_PREVIEW("computer_use_preview")
-
-
class WebSearchTool:Search the Internet for sources related to the prompt. Learn more about the web search tool.
-
Type typeThe type of the web search tool. One of
web_searchorweb_search_2025_08_26.-
WEB_SEARCH("web_search") -
WEB_SEARCH_2025_08_26("web_search_2025_08_26")
-
-
Optional<Filters> filtersFilters for the search.
-
Optional<List<String>> allowedDomainsAllowed domains for the search. If not provided, all domains are allowed. Subdomains of the provided domains are allowed as well.
Example:
["pubmed.ncbi.nlm.nih.gov"]
-
-
Optional<SearchContextSize> searchContextSizeHigh level guidance for the amount of context window space to use for the search. One of
low,medium, orhigh.mediumis the default.-
LOW("low") -
MEDIUM("medium") -
HIGH("high")
-
-
Optional<UserLocation> userLocationThe approximate location of the user.
-
Optional<String> cityFree text input for the city of the user, e.g.
San Francisco. -
Optional<String> countryThe two-letter ISO country code of the user, e.g.
US. -
Optional<String> regionFree text input for the region of the user, e.g.
California. -
Optional<String> timezoneThe IANA timezone of the user, e.g.
America/Los_Angeles. -
Optional<Type> typeThe type of location approximation. Always
approximate.APPROXIMATE("approximate")
-
-
-
Mcp-
String serverLabelA label for this MCP server, used to identify it in tool calls.
-
JsonValue; type "mcp"constantThe type of the MCP tool. Always
mcp.MCP("mcp")
-
Optional<AllowedTools> allowedToolsList of allowed tool names or a filter object.
-
List<String> -
class McpToolFilter:A filter object to specify which tools are allowed.
-
Optional<Boolean> readOnlyIndicates whether or not a tool modifies data or is read-only. If an MCP server is annotated with
readOnlyHint, it will match this filter. -
Optional<List<String>> toolNamesList of allowed tool names.
-
-
-
Optional<String> authorizationAn OAuth access token that can be used with a remote MCP server, either with a custom MCP server URL or a service connector. Your application must handle the OAuth authorization flow and provide the token here.
-
Optional<ConnectorId> connectorIdIdentifier for service connectors, like those available in ChatGPT. One of
server_urlorconnector_idmust be provided. Learn more about service connectors here.Currently supported
connector_idvalues are:-
Dropbox:
connector_dropbox -
Gmail:
connector_gmail -
Google Calendar:
connector_googlecalendar -
Google Drive:
connector_googledrive -
Microsoft Teams:
connector_microsoftteams -
Outlook Calendar:
connector_outlookcalendar -
Outlook Email:
connector_outlookemail -
SharePoint:
connector_sharepoint -
CONNECTOR_DROPBOX("connector_dropbox") -
CONNECTOR_GMAIL("connector_gmail") -
CONNECTOR_GOOGLECALENDAR("connector_googlecalendar") -
CONNECTOR_GOOGLEDRIVE("connector_googledrive") -
CONNECTOR_MICROSOFTTEAMS("connector_microsoftteams") -
CONNECTOR_OUTLOOKCALENDAR("connector_outlookcalendar") -
CONNECTOR_OUTLOOKEMAIL("connector_outlookemail") -
CONNECTOR_SHAREPOINT("connector_sharepoint")
-
-
Optional<Boolean> deferLoadingWhether this MCP tool is deferred and discovered via tool search.
-
Optional<Headers> headersOptional HTTP headers to send to the MCP server. Use for authentication or other purposes.
-
Optional<RequireApproval> requireApprovalSpecify which of the MCP server's tools require approval.
-
class McpToolApprovalFilter:Specify which of the MCP server's tools require approval. Can be
always,never, or a filter object associated with tools that require approval.-
Optional<Always> alwaysA filter object to specify which tools are allowed.
-
Optional<Boolean> readOnlyIndicates whether or not a tool modifies data or is read-only. If an MCP server is annotated with
readOnlyHint, it will match this filter. -
Optional<List<String>> toolNamesList of allowed tool names.
-
-
Optional<Never> neverA filter object to specify which tools are allowed.
-
Optional<Boolean> readOnlyIndicates whether or not a tool modifies data or is read-only. If an MCP server is annotated with
readOnlyHint, it will match this filter. -
Optional<List<String>> toolNamesList of allowed tool names.
-
-
-
enum McpToolApprovalSetting:Specify a single approval policy for all tools. One of
alwaysornever. When set toalways, all tools will require approval. When set tonever, all tools will not require approval.-
ALWAYS("always") -
NEVER("never")
-
-
-
Optional<String> serverDescriptionOptional description of the MCP server, used to provide more context.
-
Optional<String> serverUrlThe URL for the MCP server. One of
server_urlorconnector_idmust be provided.
-
-
CodeInterpreter-
Container containerThe code interpreter container. Can be a container ID or an object that specifies uploaded file IDs to make available to your code, along with an optional
memory_limitsetting.-
String -
class CodeInterpreterToolAuto:Configuration for a code interpreter container. Optionally specify the IDs of the files to run the code on.
-
JsonValue; type "auto"constantAlways
auto.AUTO("auto")
-
Optional<List<String>> fileIdsAn optional list of uploaded files to make available to your code.
-
Optional<MemoryLimit> memoryLimitThe memory limit for the code interpreter container.
-
_1G("1g") -
_4G("4g") -
_16G("16g") -
_64G("64g")
-
-
Optional<NetworkPolicy> networkPolicyNetwork access policy for the container.
-
class ContainerNetworkPolicyDisabled:-
JsonValue; type "disabled"constantDisable outbound network access. Always
disabled.DISABLED("disabled")
-
-
class ContainerNetworkPolicyAllowlist:-
List<String> allowedDomainsA list of allowed domains when type is
allowlist. -
JsonValue; type "allowlist"constantAllow outbound network access only to specified domains. Always
allowlist.ALLOWLIST("allowlist")
-
Optional<List<ContainerNetworkPolicyDomainSecret>> domainSecretsOptional domain-scoped secrets for allowlisted domains.
-
String domainThe domain associated with the secret.
-
String nameThe name of the secret to inject for the domain.
-
String valueThe secret value to inject for the domain.
-
-
-
-
-
-
JsonValue; type "code_interpreter"constantThe type of the code interpreter tool. Always
code_interpreter.CODE_INTERPRETER("code_interpreter")
-
-
ImageGeneration-
JsonValue; type "image_generation"constantThe type of the image generation tool. Always
image_generation.IMAGE_GENERATION("image_generation")
-
Optional<Action> actionWhether to generate a new image or edit an existing image. Default:
auto.-
GENERATE("generate") -
EDIT("edit") -
AUTO("auto")
-
-
Optional<Background> backgroundAllows to set transparency for the background of the generated image(s). This parameter is only supported for GPT image models that support transparent backgrounds. Must be one of
transparent,opaque, orauto(default value). Whenautois used, the model will automatically determine the best background for the image.gpt-image-2andgpt-image-2-2026-04-21do not support transparent backgrounds. Requests withbackgroundset totransparentwill return an error for these models; useopaqueorautoinstead.If
transparent, the output format needs to support transparency, so it should be set to eitherpng(default value) orwebp.-
TRANSPARENT("transparent") -
OPAQUE("opaque") -
AUTO("auto")
-
-
Optional<InputFidelity> inputFidelityControl how much effort the model will exert to match the style and features, especially facial features, of input images. This parameter is only supported for
gpt-image-1andgpt-image-1.5and later models, unsupported forgpt-image-1-mini. Supportshighandlow. Defaults tolow.-
HIGH("high") -
LOW("low")
-
-
Optional<InputImageMask> inputImageMaskOptional mask for inpainting. Contains
image_url(string, optional) andfile_id(string, optional).-
Optional<String> fileIdFile ID for the mask image.
-
Optional<String> imageUrlBase64-encoded mask image.
-
-
Optional<Model> modelThe image generation model to use. Default:
gpt-image-1.-
GPT_IMAGE_1("gpt-image-1") -
GPT_IMAGE_1_MINI("gpt-image-1-mini") -
GPT_IMAGE_2("gpt-image-2") -
GPT_IMAGE_2_2026_04_21("gpt-image-2-2026-04-21") -
GPT_IMAGE_1_5("gpt-image-1.5") -
CHATGPT_IMAGE_LATEST("chatgpt-image-latest")
-
-
Optional<Moderation> moderationModeration level for the generated image. Default:
auto.-
AUTO("auto") -
LOW("low")
-
-
Optional<Long> outputCompressionCompression level for the output image. Default: 100.
-
Optional<OutputFormat> outputFormatThe output format of the generated image. One of
png,webp, orjpeg. Default:png.-
PNG("png") -
WEBP("webp") -
JPEG("jpeg")
-
-
Optional<Long> partialImagesNumber of partial images to generate in streaming mode, from 0 (default value) to 3.
-
Optional<Quality> qualityThe quality of the generated image. One of
low,medium,high, orauto. Default:auto.-
LOW("low") -
MEDIUM("medium") -
HIGH("high") -
AUTO("auto")
-
-
Optional<Size> sizeThe size of the generated images. For
gpt-image-2andgpt-image-2-2026-04-21, arbitrary resolutions are supported asWIDTHxHEIGHTstrings, for example1536x864. Width and height must both be divisible by 16 and the requested aspect ratio must be between 1:3 and 3:1. Resolutions above2560x1440are experimental, and the maximum supported resolution is3840x2160. The requested size must also satisfy the model's current pixel and edge limits. The standard sizes1024x1024,1536x1024, and1024x1536are supported by the GPT image models;autois supported for models that allow automatic sizing. Fordall-e-2, use one of256x256,512x512, or1024x1024. Fordall-e-3, use one of1024x1024,1792x1024, or1024x1792.-
_1024X1024("1024x1024") -
_1024X1536("1024x1536") -
_1536X1024("1536x1024") -
AUTO("auto")
-
-
-
JsonValue;-
JsonValue; type "local_shell"constantThe type of the local shell tool. Always
local_shell.LOCAL_SHELL("local_shell")
-
-
class FunctionShellTool:A tool that allows the model to execute shell commands.
-
JsonValue; type "shell"constantThe type of the shell tool. Always
shell.SHELL("shell")
-
Optional<Environment> environment-
class ContainerAuto:-
JsonValue; type "container_auto"constantAutomatically creates a container for this request
CONTAINER_AUTO("container_auto")
-
Optional<List<String>> fileIdsAn optional list of uploaded files to make available to your code.
-
Optional<MemoryLimit> memoryLimitThe memory limit for the container.
-
_1G("1g") -
_4G("4g") -
_16G("16g") -
_64G("64g")
-
-
Optional<NetworkPolicy> networkPolicyNetwork access policy for the container.
-
class ContainerNetworkPolicyDisabled: -
class ContainerNetworkPolicyAllowlist:
-
-
Optional<List<Skill>> skillsAn optional list of skills referenced by id or inline data.
-
class SkillReference:-
String skillIdThe ID of the referenced skill.
-
JsonValue; type "skill_reference"constantReferences a skill created with the /v1/skills endpoint.
SKILL_REFERENCE("skill_reference")
-
Optional<String> versionOptional skill version. Use a positive integer or 'latest'. Omit for default.
-
-
class InlineSkill:-
String descriptionThe description of the skill.
-
String nameThe name of the skill.
-
InlineSkillSource sourceInline skill payload
-
String dataBase64-encoded skill zip bundle.
-
JsonValue; mediaType "application/zip"constantThe media type of the inline skill payload. Must be
application/zip.APPLICATION_ZIP("application/zip")
-
JsonValue; type "base64"constantThe type of the inline skill source. Must be
base64.BASE64("base64")
-
-
JsonValue; type "inline"constantDefines an inline skill for this request.
INLINE("inline")
-
-
-
-
class LocalEnvironment:-
JsonValue; type "local"constantUse a local computer environment.
LOCAL("local")
-
Optional<List<LocalSkill>> skillsAn optional list of skills.
-
String descriptionThe description of the skill.
-
String nameThe name of the skill.
-
String pathThe path to the directory containing the skill.
-
-
-
class ContainerReference:-
String containerIdThe ID of the referenced container.
-
JsonValue; type "container_reference"constantReferences a container created with the /v1/containers endpoint
CONTAINER_REFERENCE("container_reference")
-
-
-
-
class CustomTool:A custom tool that processes input using a specified format. Learn more about custom tools
-
String nameThe name of the custom tool, used to identify it in tool calls.
-
JsonValue; type "custom"constantThe type of the custom tool. Always
custom.CUSTOM("custom")
-
Optional<Boolean> deferLoadingWhether this tool should be deferred and discovered via tool search.
-
Optional<String> descriptionOptional description of the custom tool, used to provide more context.
-
Optional<CustomToolInputFormat> formatThe input format for the custom tool. Default is unconstrained text.
-
JsonValue;-
JsonValue; type "text"constantUnconstrained text format. Always
text.TEXT("text")
-
-
Grammar-
String definitionThe grammar definition.
-
Syntax syntaxThe syntax of the grammar definition. One of
larkorregex.-
LARK("lark") -
REGEX("regex")
-
-
JsonValue; type "grammar"constantGrammar format. Always
grammar.GRAMMAR("grammar")
-
-
-
-
class NamespaceTool:Groups function/custom tools under a shared namespace.
-
String descriptionA description of the namespace shown to the model.
-
String nameThe namespace name used in tool calls (for example,
crm). -
List<Tool> toolsThe function/custom tools available inside this namespace.
-
class Function:-
String name -
JsonValue; type "function"constantFUNCTION("function")
-
Optional<Boolean> deferLoadingWhether this function should be deferred and discovered via tool search.
-
Optional<String> description -
Optional<JsonValue> parameters -
Optional<Boolean> strict
-
-
class CustomTool:A custom tool that processes input using a specified format. Learn more about custom tools
-
-
JsonValue; type "namespace"constantThe type of the tool. Always
namespace.NAMESPACE("namespace")
-
-
class ToolSearchTool:Hosted or BYOT tool search configuration for deferred tools.
-
JsonValue; type "tool_search"constantThe type of the tool. Always
tool_search.TOOL_SEARCH("tool_search")
-
Optional<String> descriptionDescription shown to the model for a client-executed tool search tool.
-
Optional<Execution> executionWhether tool search is executed by the server or by the client.
-
SERVER("server") -
CLIENT("client")
-
-
Optional<JsonValue> parametersParameter schema for a client-executed tool search tool.
-
-
class WebSearchPreviewTool:This tool searches the web for relevant results to use in a response. Learn more about the web search tool.
-
Type typeThe type of the web search tool. One of
web_search_previeworweb_search_preview_2025_03_11.-
WEB_SEARCH_PREVIEW("web_search_preview") -
WEB_SEARCH_PREVIEW_2025_03_11("web_search_preview_2025_03_11")
-
-
Optional<List<SearchContentType>> searchContentTypes-
TEXT("text") -
IMAGE("image")
-
-
Optional<SearchContextSize> searchContextSizeHigh level guidance for the amount of context window space to use for the search. One of
low,medium, orhigh.mediumis the default.-
LOW("low") -
MEDIUM("medium") -
HIGH("high")
-
-
Optional<UserLocation> userLocationThe user's location.
-
JsonValue; type "approximate"constantThe type of location approximation. Always
approximate.APPROXIMATE("approximate")
-
Optional<String> cityFree text input for the city of the user, e.g.
San Francisco. -
Optional<String> countryThe two-letter ISO country code of the user, e.g.
US. -
Optional<String> regionFree text input for the region of the user, e.g.
California. -
Optional<String> timezoneThe IANA timezone of the user, e.g.
America/Los_Angeles.
-
-
-
class ApplyPatchTool:Allows the assistant to create, delete, or update files using unified diffs.
-
JsonValue; type "apply_patch"constantThe type of the tool. Always
apply_patch.APPLY_PATCH("apply_patch")
-
-
-
JsonValue; type "tool_search_output"constantThe type of the item. Always
tool_search_output.TOOL_SEARCH_OUTPUT("tool_search_output")
-
Optional<String> createdByThe identifier of the actor that created the item.
-
-
AdditionalTools-
String idThe unique ID of the additional tools item.
-
Role roleThe role that provided the additional tools.
-
UNKNOWN("unknown") -
USER("user") -
ASSISTANT("assistant") -
SYSTEM("system") -
CRITIC("critic") -
DISCRIMINATOR("discriminator") -
DEVELOPER("developer") -
TOOL("tool")
-
-
List<Tool> toolsThe additional tool definitions made available at this item.
-
class FunctionTool:Defines a function in your own code the model can choose to call. Learn more about function calling.
-
class FileSearchTool:A tool that searches for relevant content from uploaded files. Learn more about the file search tool.
-
class ComputerTool:A tool that controls a virtual computer. Learn more about the computer tool.
-
class ComputerUsePreviewTool:A tool that controls a virtual computer. Learn more about the computer tool.
-
class WebSearchTool:Search the Internet for sources related to the prompt. Learn more about the web search tool.
-
Mcp -
CodeInterpreter -
ImageGeneration -
JsonValue; -
class FunctionShellTool:A tool that allows the model to execute shell commands.
-
class CustomTool:A custom tool that processes input using a specified format. Learn more about custom tools
-
class NamespaceTool:Groups function/custom tools under a shared namespace.
-
class ToolSearchTool:Hosted or BYOT tool search configuration for deferred tools.
-
class WebSearchPreviewTool:This tool searches the web for relevant results to use in a response. Learn more about the web search tool.
-
class ApplyPatchTool:Allows the assistant to create, delete, or update files using unified diffs.
-
-
JsonValue; type "additional_tools"constantThe type of the item. Always
additional_tools.ADDITIONAL_TOOLS("additional_tools")
-
-
class ResponseCompactionItem:A compaction item generated by the
v1/responses/compactAPI.-
String idThe unique ID of the compaction item.
-
String encryptedContentThe encrypted content that was produced by compaction.
-
JsonValue; type "compaction"constantThe type of the item. Always
compaction.COMPACTION("compaction")
-
Optional<String> createdByThe identifier of the actor that created the item.
-
-
ImageGenerationCall-
String idThe unique ID of the image generation call.
-
Optional<String> resultThe generated image encoded in base64.
-
Status statusThe status of the image generation call.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
GENERATING("generating") -
FAILED("failed")
-
-
JsonValue; type "image_generation_call"constantThe type of the image generation call. Always
image_generation_call.IMAGE_GENERATION_CALL("image_generation_call")
-
-
class ResponseCodeInterpreterToolCall:A tool call to run code.
-
String idThe unique ID of the code interpreter tool call.
-
Optional<String> codeThe code to run, or null if not available.
-
String containerIdThe ID of the container used to run the code.
-
Optional<List<Output>> outputsThe outputs generated by the code interpreter, such as logs or images. Can be null if no outputs are available.
-
class Logs:The logs output from the code interpreter.
-
String logsThe logs output from the code interpreter.
-
JsonValue; type "logs"constantThe type of the output. Always
logs.LOGS("logs")
-
-
class Image:The image output from the code interpreter.
-
JsonValue; type "image"constantThe type of the output. Always
image.IMAGE("image")
-
String urlThe URL of the image output from the code interpreter.
-
-
-
Status statusThe status of the code interpreter tool call. Valid values are
in_progress,completed,incomplete,interpreting, andfailed.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
INTERPRETING("interpreting") -
FAILED("failed")
-
-
JsonValue; type "code_interpreter_call"constantThe type of the code interpreter tool call. Always
code_interpreter_call.CODE_INTERPRETER_CALL("code_interpreter_call")
-
-
LocalShellCall-
String idThe unique ID of the local shell call.
-
Action actionExecute a shell command on the server.
-
List<String> commandThe command to run.
-
Env envEnvironment variables to set for the command.
-
JsonValue; type "exec"constantThe type of the local shell action. Always
exec.EXEC("exec")
-
Optional<Long> timeoutMsOptional timeout in milliseconds for the command.
-
Optional<String> userOptional user to run the command as.
-
Optional<String> workingDirectoryOptional working directory to run the command in.
-
-
String callIdThe unique ID of the local shell tool call generated by the model.
-
Status statusThe status of the local shell call.
-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
JsonValue; type "local_shell_call"constantThe type of the local shell call. Always
local_shell_call.LOCAL_SHELL_CALL("local_shell_call")
-
-
LocalShellCallOutput-
String idThe unique ID of the local shell tool call generated by the model.
-
String outputA JSON string of the output of the local shell tool call.
-
JsonValue; type "local_shell_call_output"constantThe type of the local shell tool call output. Always
local_shell_call_output.LOCAL_SHELL_CALL_OUTPUT("local_shell_call_output")
-
Optional<Status> statusThe status of the item. One of
in_progress,completed, orincomplete.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
-
class ResponseFunctionShellToolCall:A tool call that executes one or more shell commands in a managed environment.
-
String idThe unique ID of the shell tool call. Populated when this item is returned via API.
-
Action actionThe shell commands and limits that describe how to run the tool call.
-
List<String> commands -
Optional<Long> maxOutputLengthOptional maximum number of characters to return from each command.
-
Optional<Long> timeoutMsOptional timeout in milliseconds for the commands.
-
-
String callIdThe unique ID of the shell tool call generated by the model.
-
Optional<Environment> environmentRepresents the use of a local environment to perform shell actions.
-
class ResponseLocalEnvironment:Represents the use of a local environment to perform shell actions.
-
JsonValue; type "local"constantThe environment type. Always
local.LOCAL("local")
-
-
class ResponseContainerReference:Represents a container created with /v1/containers.
-
String containerId -
JsonValue; type "container_reference"constantThe environment type. Always
container_reference.CONTAINER_REFERENCE("container_reference")
-
-
-
Status statusThe status of the shell call. One of
in_progress,completed, orincomplete.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
JsonValue; type "shell_call"constantThe type of the item. Always
shell_call.SHELL_CALL("shell_call")
-
Optional<String> createdByThe ID of the entity that created this tool call.
-
-
class ResponseFunctionShellToolCallOutput:The output of a shell tool call that was emitted.
-
String idThe unique ID of the shell call output. Populated when this item is returned via API.
-
String callIdThe unique ID of the shell tool call generated by the model.
-
Optional<Long> maxOutputLengthThe maximum length of the shell command output. This is generated by the model and should be passed back with the raw output.
-
List<Output> outputAn array of shell call output contents
-
Outcome outcomeRepresents either an exit outcome (with an exit code) or a timeout outcome for a shell call output chunk.
-
JsonValue;-
JsonValue; type "timeout"constantThe outcome type. Always
timeout.TIMEOUT("timeout")
-
-
class Exit:Indicates that the shell commands finished and returned an exit code.
-
long exitCodeExit code from the shell process.
-
JsonValue; type "exit"constantThe outcome type. Always
exit.EXIT("exit")
-
-
-
String stderrThe standard error output that was captured.
-
String stdoutThe standard output that was captured.
-
Optional<String> createdByThe identifier of the actor that created the item.
-
-
Status statusThe status of the shell call output. One of
in_progress,completed, orincomplete.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
JsonValue; type "shell_call_output"constantThe type of the shell call output. Always
shell_call_output.SHELL_CALL_OUTPUT("shell_call_output")
-
Optional<String> createdByThe identifier of the actor that created the item.
-
-
class ResponseApplyPatchToolCall:A tool call that applies file diffs by creating, deleting, or updating files.
-
String idThe unique ID of the apply patch tool call. Populated when this item is returned via API.
-
String callIdThe unique ID of the apply patch tool call generated by the model.
-
Operation operationOne of the create_file, delete_file, or update_file operations applied via apply_patch.
-
class CreateFile:Instruction describing how to create a file via the apply_patch tool.
-
String diffDiff to apply.
-
String pathPath of the file to create.
-
JsonValue; type "create_file"constantCreate a new file with the provided diff.
CREATE_FILE("create_file")
-
-
class DeleteFile:Instruction describing how to delete a file via the apply_patch tool.
-
String pathPath of the file to delete.
-
JsonValue; type "delete_file"constantDelete the specified file.
DELETE_FILE("delete_file")
-
-
class UpdateFile:Instruction describing how to update a file via the apply_patch tool.
-
String diffDiff to apply.
-
String pathPath of the file to update.
-
JsonValue; type "update_file"constantUpdate an existing file with the provided diff.
UPDATE_FILE("update_file")
-
-
-
Status statusThe status of the apply patch tool call. One of
in_progressorcompleted.-
IN_PROGRESS("in_progress") -
COMPLETED("completed")
-
-
JsonValue; type "apply_patch_call"constantThe type of the item. Always
apply_patch_call.APPLY_PATCH_CALL("apply_patch_call")
-
Optional<String> createdByThe ID of the entity that created this tool call.
-
-
class ResponseApplyPatchToolCallOutput:The output emitted by an apply patch tool call.
-
String idThe unique ID of the apply patch tool call output. Populated when this item is returned via API.
-
String callIdThe unique ID of the apply patch tool call generated by the model.
-
Status statusThe status of the apply patch tool call output. One of
completedorfailed.-
COMPLETED("completed") -
FAILED("failed")
-
-
JsonValue; type "apply_patch_call_output"constantThe type of the item. Always
apply_patch_call_output.APPLY_PATCH_CALL_OUTPUT("apply_patch_call_output")
-
Optional<String> createdByThe ID of the entity that created this tool call output.
-
Optional<String> outputOptional textual output returned by the apply patch tool.
-
-
McpCall-
String idThe unique ID of the tool call.
-
String argumentsA JSON string of the arguments passed to the tool.
-
String nameThe name of the tool that was run.
-
String serverLabelThe label of the MCP server running the tool.
-
JsonValue; type "mcp_call"constantThe type of the item. Always
mcp_call.MCP_CALL("mcp_call")
-
Optional<String> approvalRequestIdUnique identifier for the MCP tool call approval request. Include this value in a subsequent
mcp_approval_responseinput to approve or reject the corresponding tool call. -
Optional<String> errorThe error from the tool call, if any.
-
Optional<String> outputThe output from the tool call.
-
Optional<Status> statusThe status of the tool call. One of
in_progress,completed,incomplete,calling, orfailed.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete") -
CALLING("calling") -
FAILED("failed")
-
-
-
McpListTools-
String idThe unique ID of the list.
-
String serverLabelThe label of the MCP server.
-
List<Tool> toolsThe tools available on the server.
-
JsonValue inputSchemaThe JSON schema describing the tool's input.
-
String nameThe name of the tool.
-
Optional<JsonValue> annotationsAdditional annotations about the tool.
-
Optional<String> descriptionThe description of the tool.
-
-
JsonValue; type "mcp_list_tools"constantThe type of the item. Always
mcp_list_tools.MCP_LIST_TOOLS("mcp_list_tools")
-
Optional<String> errorError message if the server could not list tools.
-
-
McpApprovalRequest-
String idThe unique ID of the approval request.
-
String argumentsA JSON string of arguments for the tool.
-
String nameThe name of the tool to run.
-
String serverLabelThe label of the MCP server making the request.
-
JsonValue; type "mcp_approval_request"constantThe type of the item. Always
mcp_approval_request.MCP_APPROVAL_REQUEST("mcp_approval_request")
-
-
McpApprovalResponse-
String idThe unique ID of the approval response
-
String approvalRequestIdThe ID of the approval request being answered.
-
boolean approveWhether the request was approved.
-
JsonValue; type "mcp_approval_response"constantThe type of the item. Always
mcp_approval_response.MCP_APPROVAL_RESPONSE("mcp_approval_response")
-
Optional<String> reasonOptional reason for the decision.
-
-
class ResponseCustomToolCall:A call to a custom tool created by the model.
-
String callIdAn identifier used to map this custom tool call to a tool call output.
-
String inputThe input for the custom tool call generated by the model.
-
String nameThe name of the custom tool being called.
-
JsonValue; type "custom_tool_call"constantThe type of the custom tool call. Always
custom_tool_call.CUSTOM_TOOL_CALL("custom_tool_call")
-
Optional<String> idThe unique ID of the custom tool call in the OpenAI platform.
-
Optional<String> namespaceThe namespace of the custom tool being called.
-
-
class ResponseCustomToolCallOutputItem:The output of a custom tool call from your code, being sent back to the model.
-
String idThe unique ID of the custom tool call output item.
-
Status statusThe status of the item. One of
in_progress,completed, orincomplete. Populated when items are returned via API.-
IN_PROGRESS("in_progress") -
COMPLETED("completed") -
INCOMPLETE("incomplete")
-
-
Optional<String> createdByThe identifier of the actor that created the item.
-
-
-
ResponseUsage usageToken accounting for the compaction pass, including cached, reasoning, and total tokens.
-
long inputTokensThe number of input tokens.
-
InputTokensDetails inputTokensDetailsA detailed breakdown of the input tokens.
-
long cachedTokensThe number of tokens that were retrieved from the cache. More on prompt caching.
-
-
long outputTokensThe number of output tokens.
-
OutputTokensDetails outputTokensDetailsA detailed breakdown of the output tokens.
-
long reasoningTokensThe number of reasoning tokens.
-
-
long totalTokensThe total number of tokens used.
-
-
Example
package com.openai.example;
import com.openai.client.OpenAIClient;
import com.openai.client.okhttp.OpenAIOkHttpClient;
import com.openai.models.responses.CompactedResponse;
import com.openai.models.responses.ResponseCompactParams;
public final class Main {
private Main() {}
public static void main(String[] args) {
OpenAIClient client = OpenAIOkHttpClient.fromEnv();
ResponseCompactParams params = ResponseCompactParams.builder()
.model(ResponseCompactParams.Model.GPT_5_4)
.build();
CompactedResponse compactedResponse = client.responses().compact(params);
}
}
Response
{
"id": "id",
"created_at": 0,
"object": "response.compaction",
"output": [
{
"id": "id",
"content": [
{
"annotations": [
{
"file_id": "file_id",
"filename": "filename",
"index": 0,
"type": "file_citation"
}
],
"text": "text",
"type": "output_text",
"logprobs": [
{
"token": "token",
"bytes": [
0
],
"logprob": 0,
"top_logprobs": [
{
"token": "token",
"bytes": [
0
],
"logprob": 0
}
]
}
]
}
],
"role": "assistant",
"status": "in_progress",
"type": "message",
"phase": "commentary"
}
],
"usage": {
"input_tokens": 0,
"input_tokens_details": {
"cached_tokens": 0
},
"output_tokens": 0,
"output_tokens_details": {
"reasoning_tokens": 0
},
"total_tokens": 0
}
}