Español
Documentación
Herramientas Personalizadas

Herramientas Personalizadas

Crea herramientas que el LLM puede llamar en opencode.

Las herramientas personalizadas son funciones que creas y que el LLM puede llamar durante las conversaciones. Funcionan junto con las herramientas integradas de opencode como read, write y bash.

Crear una herramienta

Las herramientas se definen como archivos TypeScript o JavaScript. Sin embargo, la definición de la herramienta puede invocar scripts escritos en cualquier lenguaje — TypeScript o JavaScript solo se usa para la definición de la herramienta en sí.

Ubicación

Pueden definirse:

  • Localmente, colocándolas en el directorio .opencode/tools/ de tu proyecto.
  • O globalmente, colocándolas en ~/.config/opencode/tools/.

Estructura

La forma más fácil de crear herramientas es usando el helper tool() que proporciona seguridad de tipos y validación.

.opencode/tools/database.ts
import { tool } from "@opencode-ai/plugin"
 
export default tool({
  description: "Query the project database",
  args: {
    query: tool.schema.string().describe("SQL query to execute"),
  },
  async execute(args) {
    // Your database logic here
    return `Executed query: ${args.query}`
  },
})

El nombre del archivo se convierte en el nombre de la herramienta. Lo anterior crea una herramienta database.

Múltiples herramientas por archivo

También puedes exportar múltiples herramientas desde un solo archivo. Cada exportación se convierte en una herramienta separada con el nombre <filename>_<exportname>:

.opencode/tools/math.ts
import { tool } from "@opencode-ai/plugin"
 
export const add = tool({
  description: "Add two numbers",
  args: {
    a: tool.schema.number().describe("First number"),
    b: tool.schema.number().describe("Second number"),
  },
  async execute(args) {
    return args.a + args.b
  },
})
 
export const multiply = tool({
  description: "Multiply two numbers",
  args: {
    a: tool.schema.number().describe("First number"),
    b: tool.schema.number().describe("Second number"),
  },
  async execute(args) {
    return args.a * args.b
  },
})

Esto crea dos herramientas: math_add y math_multiply.

Argumentos

Puedes usar tool.schema, que es simplemente Zod (opens in a new tab), para definir tipos de argumentos.

args: {
  query: tool.schema.string().describe("SQL query to execute")
}

También puedes importar Zod (opens in a new tab) directamente y devolver un objeto simple:

import { z } from "zod"
 
export default {
  description: "Tool description",
  args: {
    param: z.string().describe("Parameter description"),
  },
  async execute(args, context) {
    // Tool implementation
    return "result"
  },
}

Contexto

Las herramientas reciben contexto sobre la sesión actual:

.opencode/tools/project.ts
import { tool } from "@opencode-ai/plugin"
 
export default tool({
  description: "Get project information",
  args: {},
  async execute(args, context) {
    // Access context information
    const { agent, sessionID, messageID, directory, worktree } = context
    return `Agent: ${agent}, Session: ${sessionID}, Message: ${messageID}, Directory: ${directory}, Worktree: ${worktree}`
  },
})

Usa context.directory para el directorio de trabajo de la sesión. Usa context.worktree para la raíz del git worktree.

Ejemplos

Escribir una herramienta en Python

Puedes escribir tus herramientas en cualquier lenguaje que desees. Aquí hay un ejemplo que suma dos números usando Python.

Primero, crea la herramienta como un script de Python:

.opencode/tools/add.py
import sys
 
a = int(sys.argv[1])
b = int(sys.argv[2])
print(a + b)

Luego crea la definición de la herramienta que lo invoca:

.opencode/tools/python-add.ts
import { tool } from "@opencode-ai/plugin"
import path from "path"
 
export default tool({
  description: "Add two numbers using Python",
  args: {
    a: tool.schema.number().describe("First number"),
    b: tool.schema.number().describe("Second number"),
  },
  async execute(args, context) {
    const script = path.join(context.worktree, ".opencode/tools/add.py")
    const result = await Bun.$`python3 ${script} ${args.a} ${args.b}`.text()
    return result.trim()
  },
})

Aquí estamos usando la utilidad Bun.$ (opens in a new tab) para ejecutar el script de Python.