콘텐츠로 이동

SDK

Type-safe JS client for opencode server.

opencode JS/TS SDK는 서버와 상호 작용을 위한 유형 안전한 클라이언트를 제공합니다. 통합 및 제어 opencode programmatically를 구축하는 데 사용됩니다.

Learn more 서버가 어떻게 작동하나요? 예를 들어, 커뮤니티에 의해 구축 된 projects를 확인하십시오.


설치

npm에서 SDK 설치:

Terminal window
npm install @opencode-ai/sdk

클라이언트 만들기

opencode의 인스턴스 만들기:

import { createOpencode } from "@opencode-ai/sdk"
const { client } = await createOpencode()

서버와 클라이언트 모두 시작

옵션

옵션유형설명기본
hostnamestring서버 호스트명127.0.0.1
portnumber서버포트4096
signalAbortSignal취소 신호undefined
timeoutnumber서버 시작시의 시간 아웃5000
configConfig구성 객체{}

콘피그

구성 객체를 전달할 수 있습니다. 인스턴스는 여전히 opencode.json를 선택하지만 구성 인라인을 추가 할 수 있습니다.

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()

클라이언트만

opencode의 실행 인스턴스가 이미 있다면 클라이언트 인스턴스를 만들 수 있습니다.

import { createOpencodeClient } from "@opencode-ai/sdk"
const client = createOpencodeClient({
baseUrl: "http://localhost:4096",
})

옵션

옵션유형설명기본
baseUrlstring서버의 URLhttp://localhost:4096
fetchfunction사용자 정의 fetch 구현globalThis.fetch
parseAsstring응답 파싱 방법auto
responseStylestring반품 스타일: data 또는 fieldsfields
throwOnErrorboolean반품 시 오류false

유형

SDK에는 모든 API 유형의 TypeScript 정의가 포함되어 있습니다. 직접 가져 오기 :

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

모든 유형은 서버의 OpenAPI 사양에서 생성되며 types 파일에서 사용할 수 있습니다.


오류

SDK는 잡을 수 있는 오류를 던질 수 있습니다:

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

API

SDK는 type-safe 클라이언트를 통해 모든 서버 API를 노출합니다.


글로벌

방법설명응답
global.health()서버 건강 및 버전 확인{ healthy: true, version: string }

예제

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

방법설명응답
app.log()로그 항목 작성boolean
app.agents()이용 가능한 모든 에이전트 에이전트[]

예제

// 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()

프로젝트

방법설명응답
project.list()모든 프로젝트 보기Project[]
project.current()현재 프로젝트 가져 오기Project

예제

// List all projects
const projects = await client.project.list()
// Get current project
const currentProject = await client.project.current()

경로

방법설명응답
path.get()현재 경로 가져 오기Path

예제

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

콘피그

방법설명응답
config.get()구성 정보Config
config.providers()목록 제공업체 및 기본 모델{ providers: Provider[], default: { [key: string]: string } }

예제

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

세션

방법묘사
session.list()세션 일람Session[]
session.get({ path })세션 가져 오기Session
session.children({ path })목록 어린이 세션반품 Session
session.create({ body })세션 만들기리턴 Session
session.delete({ path })세션 삭제boolean 반품
session.update({ path, body })업데이트 세션 속성반품 Session
session.init({ path, body })Analyze 앱을 만들고 AGENTS.mdboolean를 반환
session.abort({ path })운영 중인 세션반품 boolean
session.share({ path })공유 세션반품 Session
session.unshare({ path })공유 세션반품 Session
session.summarize({ path, body })세션 요약반품 boolean
session.messages({ path })세션의 메시지 목록{ info: Message, parts: Part}[]
session.message({ path })메시지 상세정보반품 { info: Message, parts: Part[]}
session.prompt({ path, body })prompt 메시지 보내기body.noReply: true 반환 UserMessage (콘텍스트 전용). 기본 반환 AssistantMessage 에 AI 응답
session.command({ path, body })세션으로 명령을 전송{ info: AssistantMessage, parts: Part[]}
session.shell({ path, body })shell 명령을 실행AssistantMessage
session.revert({ path, body })메시지 다시 변환Session
session.unrevert({ path })통일된 메시지반품 Session
postSessionByIdPermissionsByPermissionId({ path, body })허가 요청 대응반품 boolean

예제

// 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." }],
},
})

파일

방법설명응답
find.text({ query })파일에서 텍스트 검색path, lines, line_number, absolute_offset, submatches와 일치하는 개체의 배열
find.files({ query })이름의 파일 및 디렉토리 찾기string[] (경로)
find.symbols({ query })업무 공간 기호 찾기Symbol[]
file.read({ query })파일 보기{ type: "raw" | "patch", content: string }
file.status({ query? })트랙 된 파일 상태를 확인File[]

find.files는 몇몇 선택적인 조회 분야를 지원합니다:

  • type: "file" 또는 "directory"
  • directory: 검색에 대한 프로젝트 루트를 override
  • limit: 최대 결과 (1-200)

예제

// 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

방법설명응답
tui.appendPrompt({ body })프롬프트에 텍스트를 부여boolean
tui.openHelp()도움말 열기boolean
tui.openSessions()세션 선택 안내boolean
tui.openThemes()테마 선택 해제boolean
tui.openModels()모델 선택 안내boolean
tui.submitPrompt()현재 프롬프트 제출boolean
tui.clearPrompt()프롬프트 클리어boolean
tui.executeCommand({ body })명령어 실행boolean
tui.showToast({ body })쇼 토스트 알림boolean

예제

// Control TUI interface
await client.tui.appendPrompt({
body: { text: "Add this to prompt" },
})
await client.tui.showToast({
body: { message: "Task completed", variant: "success" },
})

가을
방법설명응답
auth.set({ ... })인증 자격 증명boolean

예제

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

이벤트

방법설명응답
event.subscribe()서버-sent 이벤트 스트림서버-sent 이벤트 스트림

예제

// 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)
}