Use this file to discover all available pages before exploring further.
The @langchain/openai package provides LangChain-compatible wrappers for OpenAI’s built-in tools. These tools can be bound to ChatOpenAI using bindTools() or createAgent.
The web search tool allows OpenAI models to search the web for up-to-date information before generating a response. Web search supports three main types:
Non-reasoning web search: Quick lookups where the model passes queries directly to the search tool
Agentic search with reasoning models: The model actively manages the search process, analyzing results and deciding whether to keep searching
Deep research: Extended investigations using models like o3-deep-research or gpt-5 with high reasoning effort
import { ChatOpenAI, tools } from "@langchain/openai";const model = new ChatOpenAI({ model: "gpt-5.4",});// Basic usageconst response = await model.invoke( "What was a positive news story from today?", { tools: [tools.webSearch()], });
Domain filtering - Limit search results to specific domains (up to 100):
The MCP tool allows OpenAI models to connect to remote MCP servers and OpenAI-maintained service connectors, giving models access to external tools and services.There are two ways to use MCP tools:
Remote MCP servers: Connect to any public MCP server via URL
Connectors: Use OpenAI-maintained wrappers for popular services like Google Workspace or Dropbox
Remote MCP server - Connect to any MCP-compatible server:
import { ChatOpenAI, tools } from "@langchain/openai";const model = new ChatOpenAI({ model: "gpt-5.4" });const response = await model.invoke("Roll 2d4+1", { tools: [ tools.mcp({ serverLabel: "dmcp", serverDescription: "A D&D MCP server for dice rolling", serverUrl: "https://dmcp-server.deno.dev/sse", requireApproval: "never", }), ],});
Service connectors - Use OpenAI-maintained connectors for popular services:
Explicit container - Use a pre-created container ID:
const response = await model.invoke("Continue working with the data", { tools: [ tools.codeInterpreter({ container: "cntr_abc123", }), ],});
Note: Containers expire after 20 minutes of inactivity. While called “Code Interpreter”, the model knows it as the “python tool” - for explicit prompting, ask for “the python tool” in your prompts.
The File Search tool allows models to search your files for relevant information using semantic and keyword search. It enables retrieval from a knowledge base of previously uploaded files stored in vector stores.Prerequisites: Before using File Search, you must:
Upload files to the File API with purpose: "assistants"
Filter operators: eq (equals), ne (not equal), gt (greater than), gte (greater than or equal), lt (less than), lte (less than or equal).For more information, see OpenAI’s File Search Documentation.
The Image Generation tool allows models to generate or edit images using text prompts and optional image inputs. It leverages the GPT Image model and automatically optimizes text inputs for improved performance.Use Image Generation for:
Creating images from text: Generate images from detailed text descriptions
Editing existing images: Modify images based on text instructions
Multi-turn image editing: Iteratively refine images across conversation turns
Various output formats: Support for PNG, JPEG, and WebP formats
import { ChatOpenAI, tools } from "@langchain/openai";const model = new ChatOpenAI({ model: "gpt-5.4" });// Basic usage - generate an imageconst response = await model.invoke( "Generate an image of a gray tabby cat hugging an otter with an orange scarf", { tools: [tools.imageGeneration()] });// Access the generated image (base64-encoded)const imageOutput = response.additional_kwargs.tool_outputs?.find( (output) => output.type === "image_generation_call");if (imageOutput?.result) { const fs = await import("fs"); fs.writeFileSync("output.png", Buffer.from(imageOutput.result, "base64"));}
Custom size and quality - Configure output dimensions and quality:
Transparent background - Generate images with transparency:
const response = await model.invoke( "Create a logo with transparent background", { tools: [ tools.imageGeneration({ background: "transparent", // Background type (also: "opaque", "auto") outputFormat: "png", }), ], });
Streaming with partial images - Get visual feedback during generation:
const response = await model.invoke("Draw a detailed fantasy castle", { tools: [ tools.imageGeneration({ partialImages: 2, // Number of partial images (0-3) }), ],});
Force image generation - Ensure the model uses the image generation tool:
const response = await model.invoke("A serene lake at dawn", { tools: [tools.imageGeneration()], tool_choice: { type: "image_generation" },});
Multi-turn editing - Refine images across conversation turns:
// First turn: generate initial imageconst response1 = await model.invoke("Draw a red car", { tools: [tools.imageGeneration()],});// Second turn: edit the imageconst response2 = await model.invoke( [response1, new HumanMessage("Now change the car color to blue")], { tools: [tools.imageGeneration()] });
Prompting tips: Use terms like “draw” or “edit” for best results. For combining images, say “edit the first image by adding this element” instead of “combine” or “merge”.
The Computer Use tool allows models to control computer interfaces by simulating mouse clicks, keyboard input, scrolling, and more. It uses OpenAI’s Computer-Using Agent (CUA) model to understand screenshots and suggest actions.
Beta: Computer use is in beta. Use in sandboxed environments only and do not use for high-stakes or authenticated tasks. Always implement human-in-the-loop for important decisions.
How it works: The tool operates in a continuous loop:
Model sends computer actions (click, type, scroll, etc.)
Your code executes these actions in a controlled environment
You capture a screenshot of the result
Send the screenshot back to the model
Repeat until the task is complete
import { ChatOpenAI, tools } from "@langchain/openai";const model = new ChatOpenAI({ model: "computer-use-preview" });// With execute callback for automatic action handlingconst computer = tools.computerUse({ displayWidth: 1024, displayHeight: 768, environment: "browser", execute: async (action) => { if (action.type === "screenshot") { return captureScreenshot(); } if (action.type === "click") { await page.mouse.click(action.x, action.y, { button: action.button }); return captureScreenshot(); } if (action.type === "type") { await page.keyboard.type(action.text); return captureScreenshot(); } if (action.type === "scroll") { await page.mouse.move(action.x, action.y); await page.evaluate( `window.scrollBy(${action.scroll_x}, ${action.scroll_y})` ); return captureScreenshot(); } // Handle other actions... return captureScreenshot(); },});const llmWithComputer = model.bindTools([computer]);const response = await llmWithComputer.invoke( "Check the latest news on bing.com");
The Local Shell tool allows models to run shell commands locally on a machine you provide. Commands are executed inside your own runtime—the API only returns the instructions.
Security Warning: Running arbitrary shell commands can be dangerous. Always sandbox execution or add strict allow/deny-lists before forwarding commands to the system shell.
Note: This tool is designed to work with Codex CLI and the codex-mini-latest model.
import { ChatOpenAI, tools } from "@langchain/openai";import { exec } from "child_process";import { promisify } from "util";const execAsync = promisify(exec);const model = new ChatOpenAI({ model: "codex-mini-latest" });// With execute callback for automatic command handlingconst shell = tools.localShell({ execute: async (action) => { const { command, env, working_directory, timeout_ms } = action; const result = await execAsync(command.join(" "), { cwd: working_directory ?? process.cwd(), env: { ...process.env, ...env }, timeout: timeout_ms ?? undefined, }); return result.stdout + result.stderr; },});const llmWithShell = model.bindTools([shell]);const response = await llmWithShell.invoke( "List files in the current directory");
Action properties: The model returns actions with these properties:
command - Array of argv tokens to execute
env - Environment variables to set
working_directory - Directory to run the command in
timeout_ms - Suggested timeout (enforce your own limits)
The Shell tool allows models to run shell commands through your integration. Unlike Local Shell, this tool supports executing multiple commands concurrently and is designed for gpt-5.1.
Security Warning: Running arbitrary shell commands can be dangerous. Always sandbox execution or add strict allow/deny-lists before forwarding commands to the system shell.
Use cases:
Automating filesystem or process diagnostics – e.g., “find the largest PDF under ~/Documents”
Extending model capabilities – Using built-in UNIX utilities, Python runtime, and other CLIs
Running multi-step build and test flows – Chaining commands like pip install and pytest
Complex agentic coding workflows – Using with apply_patch for file operations
The Apply Patch tool allows models to propose structured diffs that your integration applies. This enables iterative, multi-step code editing workflows where the model can create, update, and delete files in your codebase.When to use:
Multi-file refactors – Rename symbols, extract helpers, or reorganize modules
Bug fixes – Have the model both diagnose issues and emit precise patches
Tests & docs generation – Create new test files, fixtures, and documentation
Security Warning: Applying patches can modify files in your codebase. Always validate paths, implement backups, and consider sandboxing.
Note: This tool is designed to work with gpt-5.1 model.
import { ChatOpenAI, tools } from "@langchain/openai";import { applyDiff } from "@openai/agents";import * as fs from "fs/promises";const model = new ChatOpenAI({ model: "gpt-5.1" });// With execute callback for automatic patch handlingconst patchTool = tools.applyPatch({ execute: async (operation) => { if (operation.type === "create_file") { const content = applyDiff("", operation.diff, "create"); await fs.writeFile(operation.path, content); return `Created ${operation.path}`; } if (operation.type === "update_file") { const current = await fs.readFile(operation.path, "utf-8"); const newContent = applyDiff(current, operation.diff); await fs.writeFile(operation.path, newContent); return `Updated ${operation.path}`; } if (operation.type === "delete_file") { await fs.unlink(operation.path); return `Deleted ${operation.path}`; } return "Unknown operation type"; },});const llmWithPatch = model.bindTools([patchTool]);const response = await llmWithPatch.invoke( "Rename the fib() function to fibonacci() in lib/fib.py");
Operation types: The model returns operations with these properties:
create_file – Create a new file at path with content from diff
update_file – Modify an existing file at path using V4A diff format in diff
delete_file – Remove a file at path
Best practices:
Path validation: Prevent directory traversal and restrict edits to allowed directories
Backups: Consider backing up files before applying patches
Error handling: Return descriptive error messages so the model can recover
Atomicity: Decide whether you want “all-or-nothing” semantics (rollback if any patch fails)