@langchain/openai
Version:
OpenAI integrations for LangChain.js
148 lines (146 loc) • 6.06 kB
TypeScript
import { OpenAI as OpenAI$1 } from "openai";
import { DynamicStructuredTool } from "@langchain/core/tools";
import { z } from "zod/v4";
//#region src/tools/applyPatch.d.ts
/**
* Re-export operation types from OpenAI SDK for convenience.
*/
type ApplyPatchCreateFileOperation = OpenAI$1.Responses.ResponseApplyPatchToolCall.CreateFile;
type ApplyPatchUpdateFileOperation = OpenAI$1.Responses.ResponseApplyPatchToolCall.UpdateFile;
type ApplyPatchDeleteFileOperation = OpenAI$1.Responses.ResponseApplyPatchToolCall.DeleteFile;
/**
* Union type of all apply patch operations from OpenAI SDK.
*/
type ApplyPatchOperation = NonNullable<OpenAI$1.Responses.ResponseApplyPatchToolCall["operation"]>;
/**
* Options for the Apply Patch tool.
*/
interface ApplyPatchOptions {
/**
* Execute function that handles patch operations.
* This function receives the operation input and should return a string
* describing the result (success or failure message).
*
* The operation types are:
* - `create_file`: Create a new file at the specified path with the diff content
* - `update_file`: Modify an existing file using V4A diff format
* - `delete_file`: Remove a file at the specified path
*
* @example
* ```typescript
* 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";
* }
* ```
*/
execute: (operation: ApplyPatchOperation) => string | Promise<string>;
}
/**
* OpenAI Apply Patch tool type for the Responses API.
*/
type ApplyPatchTool = OpenAI$1.Responses.ApplyPatchTool;
/**
* Creates an Apply Patch tool that allows models to propose structured diffs
* that your integration applies. This enables iterative, multi-step code
* editing workflows.
*
* **Apply Patch** lets GPT-5.1 create, update, and delete files in your codebase
* using structured diffs. Instead of just suggesting edits, the model emits
* patch operations that your application applies and then reports back on.
*
* **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
* - **Migrations & mechanical edits** – Apply repetitive, structured updates
*
* **How it works**:
* The tool operates in a continuous loop:
* 1. Model sends patch operations (`apply_patch_call` with operation type)
* 2. Your code applies the patch to your working directory or repo
* 3. You return success/failure status and optional output
* 4. Repeat until the task is complete
*
* **Security Warning**: Applying patches can modify files in your codebase.
* Always validate paths, implement backups, and consider sandboxing.
*
* @see {@link https://platform.openai.com/docs/guides/tools-apply-patch | OpenAI Apply Patch Documentation}
*
* @param options - Configuration options for the Apply Patch tool
* @returns An Apply Patch tool that can be passed to `bindTools`
*
* @example
* ```typescript
* 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 handling
* const 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"
* );
* ```
*
* @remarks
* - Only available through the Responses API (not Chat Completions)
* - Designed for use with `gpt-5.1` model
* - Operations include: `create_file`, `update_file`, `delete_file`
* - Patches use V4A diff format for updates
* - Always validate paths to prevent directory traversal attacks
* - Consider backing up files before applying patches
* - Implement "all-or-nothing" semantics if atomicity is required
*/
declare function applyPatch(options: ApplyPatchOptions): DynamicStructuredTool<z.ZodDiscriminatedUnion<[z.ZodObject<{
type: z.ZodLiteral<"create_file">;
path: z.ZodString;
diff: z.ZodString;
}, z.core.$strip>, z.ZodObject<{
type: z.ZodLiteral<"update_file">;
path: z.ZodString;
diff: z.ZodString;
}, z.core.$strip>, z.ZodObject<{
type: z.ZodLiteral<"delete_file">;
path: z.ZodString;
}, z.core.$strip>]>, ApplyPatchOperation, unknown, string>;
//#endregion
export { ApplyPatchCreateFileOperation, ApplyPatchDeleteFileOperation, ApplyPatchOperation, ApplyPatchOptions, ApplyPatchTool, ApplyPatchUpdateFileOperation, applyPatch };
//# sourceMappingURL=applyPatch.d.ts.map