Back to Opencode

SDK

packages/web/src/content/docs/nb/sdk.mdx

1.14.3919.8 KB
Original Source

import config from "../../../../config.mjs" export const typesUrl = ${config.github}/blob/dev/packages/sdk/js/src/gen/types.gen.ts

OpenCode JS/TS SDK gir en typesikker klient for samhandling med serveren. Bruk den til å bygge integrasjoner og kontrollere OpenCode programmatisk.

Finn ut mer om hvordan serveren fungerer. For eksempler, sjekk ut prosjektene bygget av fellesskapet.


Installasjon

Installer SDK fra npm:

bash
npm install @opencode-ai/sdk

Opprette klient

Opprett en forekomst av OpenCode:

javascript
import { createOpencode } from "@opencode-ai/sdk"

const { client } = await createOpencode()

Dette starter både en server og en klient

Alternativer

AlternativTypeBeskrivelseStandard
hostnamestringServer vertsnavn127.0.0.1
portnumberServerport4096
signalAbortSignalAbortSignal for avbruddundefined
timeoutnumberTidsavbrudd i ms for serverstart5000
configConfigKonfigurasjonsobjekt{}

Konfigurasjon

Du kan sende et konfigurasjonsobjekt for å tilpasse virkemåten. Forekomsten henter fortsatt din opencode.json, men du kan overstyre eller legge til konfigurasjon inline:

javascript
import { createOpencode } from "@opencode-ai/sdk"

const opencode = await createOpencode({
  hostname: "127.0.0.1",
  port: 4096,
  config: {
    model: "anthropic/claude-3-5-sonnet-20241022",
  },
})

console.log(`Server running at ${opencode.server.url}`)

opencode.server.close()

Kun klient

Hvis du allerede har en kjørende forekomst av OpenCode, kan du opprette en klientforekomst for å koble til den:

javascript
import { createOpencodeClient } from "@opencode-ai/sdk"

const client = createOpencodeClient({
  baseUrl: "http://localhost:4096",
})

Alternativer

AlternativTypeBeskrivelseStandard
baseUrlstringURL av serverenhttp://localhost:4096
fetchfunctionEgendefinert fetch-implementasjonglobalThis.fetch
parseAsstringMetode for responsparsingauto
responseStylestringReturstil: data eller fieldsfields
throwOnErrorbooleanKast feil i stedet for returfalse

Typer

SDK inkluderer TypeScript-definisjoner for alle API-typer. Importer dem direkte:

typescript
import type { Session, Message, Part } from "@opencode-ai/sdk"

Alle typer er generert fra serverens OpenAPI-spesifikasjon og tilgjengelig i <a href={typesUrl}>type-filen</a>.


Feil

SDK kan gi feil som du kan fange opp og håndtere:

typescript
try {
  await client.session.get({ path: { id: "invalid-id" } })
} catch (error) {
  console.error("Failed to get session:", (error as Error).message)
}

Strukturert Utdata

Du kan be om strukturert JSON-utdata fra modellen ved å spesifisere et format med et JSON-skjema. Modellen vil bruke et StructuredOutput-verktøy for å returnere validert JSON som samsvarer med skjemaet ditt.

Grunnleggende bruk

typescript
const result = await client.session.prompt({
  path: { id: sessionId },
  body: {
    parts: [{ type: "text", text: "Research Anthropic and provide company info" }],
    format: {
      type: "json_schema",
      schema: {
        type: "object",
        properties: {
          company: { type: "string", description: "Company name" },
          founded: { type: "number", description: "Year founded" },
          products: {
            type: "array",
            items: { type: "string" },
            description: "Main products",
          },
        },
        required: ["company", "founded"],
      },
    },
  },
})

// Access the structured output
console.log(result.data.info.structured_output)
// { company: "Anthropic", founded: 2021, products: ["Claude", "Claude API"] }

Utdataformattyper

TypeBeskrivelse
textStandard. Standard tekstrespons (ingen strukturert utdata)
json_schemaReturnerer validert JSON som samsvarer med det angitte skjemaet

JSON Skjemaformat

Når du bruker type: 'json_schema', oppgi:

FeltTypeBeskrivelse
type'json_schema'Påkrevd. Spesifiserer JSON-skjemamodus
schemaobjectPåkrevd. JSON Schema-objekt som definerer utdatastrukturen
retryCountnumberValgfritt. Antall valideringsforsøk (standard: 2)

Feilhåndtering

Hvis modellen ikke klarer å produsere gyldig strukturert utdata etter alle forsøk, vil svaret inkludere en StructuredOutputError:

typescript
if (result.data.info.error?.name === "StructuredOutputError") {
  console.error("Failed to produce structured output:", result.data.info.error.message)
  console.error("Attempts:", result.data.info.error.retries)
}

Beste praksis

  1. Gi klare beskrivelser i skjemaegenskapene dine for å hjelpe modellen med å forstå hvilke data som skal trekkes ut
  2. Bruk required for å spesifisere hvilke felt som må være til stede
  3. Hold skjemaer fokuserte - komplekse nøstede skjemaer kan være vanskeligere for modellen å fylle ut riktig
  4. Angi passende retryCount - øk for komplekse skjemaer, reduser for enkle

API-er

SDK-en eksponerer alle server-API-er gjennom en typesikker klient.


Globalt

MetodeBeskrivelseSvar
global.health()Sjekk serverstatus og versjon{ healthy: true, version: string }

Eksempler

javascript
const health = await client.global.health()
console.log(health.data.version)

App

MetodeBeskrivelseSvar
app.log()Skriv en loggoppføringboolean
app.agents()List alle tilgjengelige agenter<a href={typesUrl}><code>Agent[]</code></a>

Eksempler

javascript
// Write a log entry
await client.app.log({
  body: {
    service: "my-app",
    level: "info",
    message: "Operation completed",
  },
})

// List available agents
const agents = await client.app.agents()

Prosjekt

MetodeBeskrivelseSvar
project.list()List alle prosjekter<a href={typesUrl}><code>Project[]</code></a>
project.current()Hent gjeldende prosjekt<a href={typesUrl}><code>Project</code></a>

Eksempler

javascript
// List all projects
const projects = await client.project.list()

// Get current project
const currentProject = await client.project.current()

Sti

MetodeBeskrivelseSvar
path.get()Hent gjeldende bane<a href={typesUrl}><code>Path</code></a>

Eksempler

javascript
// Get current path information
const pathInfo = await client.path.get()

Konfigurasjon

MetodeBeskrivelseSvar
config.get()Hent konfigurasjonsinformasjon<a href={typesUrl}><code>Config</code></a>
config.providers()List leverandører og standardmodeller{ providers: <a href={typesUrl}><code>Provider[]</code></a>, default: { [key: string]: string } }

Eksempler

javascript
const config = await client.config.get()

const { providers, default: defaults } = await client.config.providers()

Sesjoner

MetodeBeskrivelseMerknader
session.list()List økterReturnerer <a href={typesUrl}><code>Session[]</code></a>
session.get({ path })Hent øktReturnerer <a href={typesUrl}><code>Session</code></a>
session.children({ path })List barneøkterReturnerer <a href={typesUrl}><code>Session[]</code></a>
session.create({ body })Opprett øktReturnerer <a href={typesUrl}><code>Session</code></a>
session.delete({ path })Slett øktReturnerer boolean
session.update({ path, body })Oppdater øktegenskaperReturnerer <a href={typesUrl}><code>Session</code></a>
session.init({ path, body })Analyser appen og lag AGENTS.mdReturnerer boolean
session.abort({ path })Avbryt en kjørende øktReturnerer boolean
session.share({ path })Del øktenReturnerer <a href={typesUrl}><code>Session</code></a>
session.unshare({ path })Slutt å dele øktenReturnerer <a href={typesUrl}><code>Session</code></a>
session.summarize({ path, body })Oppsummer øktenReturnerer boolean
session.messages({ path })List meldinger i en øktReturnerer { info: <a href={typesUrl}><code>Message</code></a>, parts: <a href={typesUrl}><code>Part[]</code></a>}[]
session.message({ path })Hent meldingsdetaljerReturnerer { info: <a href={typesUrl}><code>Message</code></a>, parts: <a href={typesUrl}><code>Part[]</code></a>}
session.prompt({ path, body })Send meldingbody.noReply: true returnerer UserMessage (kun kontekst). Standard returnerer <a href={typesUrl}><code>AssistantMessage</code></a> med AI svar. Støtter body.outputFormat for strukturert utdata
session.command({ path, body })Send kommando til øktReturnerer { info: <a href={typesUrl}><code>AssistantMessage</code></a>, parts: <a href={typesUrl}><code>Part[]</code></a>}
session.shell({ path, body })Kjør en shell-kommandoReturnerer <a href={typesUrl}><code>AssistantMessage</code></a>
session.revert({ path, body })Tilbakestill en meldingReturnerer <a href={typesUrl}><code>Session</code></a>
session.unrevert({ path })Gjenopprett reverserte meldingerReturnerer <a href={typesUrl}><code>Session</code></a>
postSessionByIdPermissionsByPermissionId({ path, body })Svar på en tillatelsesforespørselReturnerer boolean

Eksempler

javascript
// Create and manage sessions
const session = await client.session.create({
  body: { title: "My session" },
})

const sessions = await client.session.list()

// Send a prompt message
const result = await client.session.prompt({
  path: { id: session.id },
  body: {
    model: { providerID: "anthropic", modelID: "claude-3-5-sonnet-20241022" },
    parts: [{ type: "text", text: "Hello!" }],
  },
})

// Inject context without triggering AI response (useful for plugins)
await client.session.prompt({
  path: { id: session.id },
  body: {
    noReply: true,
    parts: [{ type: "text", text: "You are a helpful assistant." }],
  },
})

Filer

MetodeBeskrivelseSvar
find.text({ query })Søk etter tekst i filerEn rekke matchobjekter med path, lines, line_number, absolute_offset, submatches
find.files({ query })Finn filer og kataloger etter navnstring[] (baner)
find.symbols({ query })Finn symboler i arbeidsområdet<a href={typesUrl}><code>Symbol[]</code></a>
file.read({ query })Les en fil{ type: "raw" | "patch", content: string }
file.status({ query? })Hent status for sporede filer<a href={typesUrl}><code>File[]</code></a>

find.files støtter noen få valgfrie søkefelt:

  • type: "file" eller "directory"
  • directory: overstyr prosjektroten for søket
  • limit: maksimalt antall resultater (1–200)

Eksempler

javascript
// Search and read files
const textResults = await client.find.text({
  query: { pattern: "function.*opencode" },
})

const files = await client.find.files({
  query: { query: "*.ts", type: "file" },
})

const directories = await client.find.files({
  query: { query: "packages", type: "directory", limit: 20 },
})

const content = await client.file.read({
  query: { path: "src/index.ts" },
})

TUI

MetodeBeskrivelseSvar
tui.appendPrompt({ body })Legg til tekst i promptenboolean
tui.openHelp()Åpne hjelpedialogenboolean
tui.openSessions()Åpne øktvelgerenboolean
tui.openThemes()Åpne temavelgerenboolean
tui.openModels()Åpne modellvelgerenboolean
tui.submitPrompt()Send inn gjeldende promptboolean
tui.clearPrompt()Tøm promptenboolean
tui.executeCommand({ body })Utfør en kommandoboolean
tui.showToast({ body })Vis toast-varselboolean

Eksempler

javascript
// Control TUI interface
await client.tui.appendPrompt({
  body: { text: "Add this to prompt" },
})

await client.tui.showToast({
  body: { message: "Task completed", variant: "success" },
})

Auth

MetodeBeskrivelseSvar
auth.set({ ... })Angi autentiseringsinformasjonboolean

Eksempler

javascript
await client.auth.set({
  path: { id: "anthropic" },
  body: { type: "api", key: "your-api-key" },
})

Hendelser

MetodeBeskrivelseSvar
event.subscribe()Strøm av server-sendte hendelserStrøm av server-sendte hendelser

Eksempler

javascript
// Listen to real-time events
const events = await client.event.subscribe()
for await (const event of events.stream) {
  console.log("Event:", event.type, event.properties)
}