설치
SDK는 선택적 종속성으로 플랫폼용 네이티브 Claude Code 바이너리를 번들로 제공합니다(예:
@anthropic-ai/claude-agent-sdk-darwin-arm64). Claude Code를 별도로 설치할 필요가 없습니다. 패키지 관리자가 선택적 종속성을 건너뛰면 SDK는 Native CLI binary for <platform> not found 오류를 발생시킵니다. 이 경우 pathToClaudeCodeExecutable을 별도로 설치된 claude 바이너리로 설정하세요.단일 실행 파일로 컴파일
bun build --compile을 사용하여 애플리케이션을 단일 파일 실행 파일로 컴파일하면 SDK는 런타임에 번들된 CLI 바이너리를 확인할 수 없습니다. require.resolve는 컴파일된 실행 파일의 $bunfs 가상 파일 시스템 내에서 작동하지 않으므로 SDK는 Native CLI binary for <platform> not found 오류를 발생시킵니다.
이를 해결하려면 플랫폼 바이너리를 파일 자산으로 포함하고, 시작 시 extractFromBunfs()를 사용하여 실제 경로로 추출한 다음, 해당 경로를 pathToClaudeCodeExecutable에 전달하세요.
extractFromBunfs() 헬퍼는 @anthropic-ai/claude-agent-sdk v0.3.144 이상이 필요합니다. 아래 예제는 Apple Silicon의 macOS용으로 빌드합니다:
extractFromBunfs()는 컴파일된 실행 파일의 가상 파일 시스템에서 포함된 바이너리를 사용자별 임시 디렉터리로 복사하고 실제 경로를 반환합니다. 컴파일된 실행 파일 외부에서는 입력 경로를 변경하지 않고 반환하므로 동일한 코드가 수정 없이 개발 환경에서 실행됩니다.
각 컴파일된 실행 파일은 단일 플랫폼의 바이너리를 포함합니다. 가져오기의 플랫폼 패키지를 --target과 일치시키세요:
- 크로스 컴파일하려면 일치하지 않는 플랫폼 패키지를 설치하세요. 예를 들어
npm install @anthropic-ai/claude-agent-sdk-linux-x64 --force입니다. - Windows에서 바이너리 하위 경로는
claude.exe입니다. 예를 들어@anthropic-ai/claude-agent-sdk-win32-x64/claude.exe입니다.
함수
query()
Claude Code와 상호작용하기 위한 주요 함수입니다. 메시지가 도착할 때 스트리밍하는 비동기 생성기를 만듭니다.
매개변수
| 매개변수 | 타입 | 설명 |
|---|---|---|
prompt | string | AsyncIterable<SDKUserMessage> | 문자열 또는 스트리밍 모드용 비동기 반복 가능 객체로서의 입력 프롬프트 |
options | Options | 선택적 구성 객체 (아래 Options 타입 참조) |
반환값
Query 객체를 반환하며, 이는 추가 메서드를 포함하는 AsyncGenerator<SDKMessage, void>를 확장합니다.
startup()
프롬프트를 사용할 수 있기 전에 CLI 서브프로세스를 생성하고 초기화 핸드셰이크를 완료하여 미리 준비합니다. 반환된 WarmQuery 핸들은 나중에 프롬프트를 수락하고 이미 준비된 프로세스에 작성하므로, 첫 번째 query() 호출은 서브프로세스 생성 및 초기화 비용을 지불하지 않고 해결됩니다.
매개변수
| 매개변수 | 타입 | 설명 |
|---|---|---|
options | Options | 선택적 구성 객체입니다. query()의 options 매개변수와 동일합니다 |
initializeTimeoutMs | number | 서브프로세스 초기화를 기다릴 최대 시간(밀리초)입니다. 기본값은 60000입니다. 초기화가 시간 내에 완료되지 않으면 프로미스는 타임아웃 오류로 거부됩니다 |
반환값
서브프로세스가 생성되고 초기화 핸드셰이크를 완료하면 해결되는Promise<WarmQuery>를 반환합니다.
예제
startup()을 조기에 호출합니다(예: 애플리케이션 부팅 시). 그런 다음 프롬프트가 준비되면 반환된 핸들에서 .query()를 호출합니다. 이렇게 하면 서브프로세스 생성 및 초기화가 중요 경로에서 벗어납니다.
tool()
SDK MCP 서버와 함께 사용하기 위한 타입 안전 MCP 도구 정의를 만듭니다.
매개변수
| 매개변수 | 타입 | 설명 |
|---|---|---|
name | string | 도구의 이름 |
description | string | 도구가 수행하는 작업에 대한 설명 |
inputSchema | Schema extends AnyZodRawShape | 도구의 입력 매개변수를 정의하는 Zod 스키마 (Zod 3 및 Zod 4 모두 지원) |
handler | (args, extra) => Promise<CallToolResult> | 도구 로직을 실행하는 비동기 함수 |
extras | { annotations?: ToolAnnotations } | 클라이언트에 동작 힌트를 제공하는 선택적 MCP 도구 주석 |
ToolAnnotations
@modelcontextprotocol/sdk/types.js에서 다시 내보냅니다. 모든 필드는 선택적 힌트입니다. 클라이언트는 보안 결정을 위해 이들을 신뢰해서는 안 됩니다.
| 필드 | 타입 | 기본값 | 설명 |
|---|---|---|---|
title | string | undefined | 도구의 사람이 읽을 수 있는 제목 |
readOnlyHint | boolean | false | true이면 도구는 환경을 수정하지 않습니다 |
destructiveHint | boolean | true | true이면 도구는 파괴적인 업데이트를 수행할 수 있습니다 (readOnlyHint가 false일 때만 의미 있음) |
idempotentHint | boolean | false | true이면 동일한 인수로 반복 호출해도 추가 효과가 없습니다 (readOnlyHint가 false일 때만 의미 있음) |
openWorldHint | boolean | true | true이면 도구는 외부 엔티티와 상호작용합니다 (예: 웹 검색). false이면 도구의 도메인은 폐쇄적입니다 (예: 메모리 도구) |
createSdkMcpServer()
애플리케이션과 동일한 프로세스에서 실행되는 MCP 서버 인스턴스를 만듭니다.
매개변수
| 매개변수 | 타입 | 설명 |
|---|---|---|
options.name | string | MCP 서버의 이름 |
options.version | string | 선택적 버전 문자열 |
options.tools | Array<SdkMcpToolDefinition> | tool()로 만든 도구 정의의 배열 |
listSessions()
가벼운 메타데이터를 포함한 과거 세션을 발견하고 나열합니다. 프로젝트 디렉토리별로 필터링하거나 모든 프로젝트에서 세션을 나열합니다.
매개변수
| 매개변수 | 타입 | 기본값 | 설명 |
|---|---|---|---|
options.dir | string | undefined | 세션을 나열할 디렉토리입니다. 생략하면 모든 프로젝트에서 세션을 반환합니다 |
options.limit | number | undefined | 반환할 최대 세션 수 |
options.includeWorktrees | boolean | true | dir이 git 저장소 내에 있을 때 모든 worktree 경로에서 세션을 포함합니다 |
반환 타입: SDKSessionInfo
| 속성 | 타입 | 설명 |
|---|---|---|
sessionId | string | 고유 세션 식별자 (UUID) |
summary | string | 표시 제목: 사용자 정의 제목, 자동 생성된 요약 또는 첫 번째 프롬프트 |
lastModified | number | 에포크 이후 밀리초 단위의 마지막 수정 시간 |
fileSize | number | undefined | 세션 파일 크기(바이트)입니다. 로컬 JSONL 저장소에만 채워집니다 |
customTitle | string | undefined | 사용자가 설정한 세션 제목 (/rename을 통해) |
firstPrompt | string | undefined | 세션의 첫 번째 의미 있는 사용자 프롬프트 |
gitBranch | string | undefined | 세션 끝의 git 분기 |
cwd | string | undefined | 세션의 작업 디렉토리 |
tag | string | undefined | 사용자가 설정한 세션 태그 (tagSession() 참조) |
createdAt | number | undefined | 첫 번째 항목의 타임스탬프에서 에포크 이후 밀리초 단위의 생성 시간 |
예제
프로젝트의 10개 최신 세션을 인쇄합니다. 결과는lastModified 내림차순으로 정렬되므로 첫 번째 항목이 가장 최신입니다. 모든 프로젝트에서 검색하려면 dir을 생략합니다.
getSessionMessages()
과거 세션 트랜스크립트에서 사용자 및 어시스턴트 메시지를 읽습니다.
매개변수
| 매개변수 | 타입 | 기본값 | 설명 |
|---|---|---|---|
sessionId | string | 필수 | 읽을 세션 UUID (listSessions() 참조) |
options.dir | string | undefined | 세션을 찾을 프로젝트 디렉토리입니다. 생략하면 모든 프로젝트를 검색합니다 |
options.limit | number | undefined | 반환할 최대 메시지 수 |
options.offset | number | undefined | 시작 부분에서 건너뛸 메시지 수 |
반환 타입: SessionMessage
| 속성 | 타입 | 설명 |
|---|---|---|
type | "user" | "assistant" | 메시지 역할 |
uuid | string | 고유 메시지 식별자 |
session_id | string | 이 메시지가 속한 세션 |
message | unknown | 트랜스크립트의 원본 메시지 페이로드 |
parent_tool_use_id | string | null | 서브에이전트 메시지의 경우 생성 Agent 도구 호출의 tool_use_id입니다. 메인 세션 메시지 및 이전 세션의 경우 null |
예제
getSessionInfo()
전체 프로젝트 디렉토리를 스캔하지 않고 ID로 단일 세션의 메타데이터를 읽습니다.
매개변수
| 매개변수 | 타입 | 기본값 | 설명 |
|---|---|---|---|
sessionId | string | 필수 | 조회할 세션의 UUID |
options.dir | string | undefined | 프로젝트 디렉토리 경로입니다. 생략하면 모든 프로젝트 디렉토리를 검색합니다 |
SDKSessionInfo를 반환하거나, 세션을 찾을 수 없으면 undefined를 반환합니다.
renameSession()
사용자 정의 제목 항목을 추가하여 세션의 이름을 바꿉니다. 반복 호출은 안전합니다. 가장 최신 제목이 우선합니다.
매개변수
| 매개변수 | 타입 | 기본값 | 설명 |
|---|---|---|---|
sessionId | string | 필수 | 이름을 바꿀 세션의 UUID |
title | string | 필수 | 새 제목입니다. 공백을 제거한 후 비어 있지 않아야 합니다 |
options.dir | string | undefined | 프로젝트 디렉토리 경로입니다. 생략하면 모든 프로젝트 디렉토리를 검색합니다 |
tagSession()
세션에 태그를 지정합니다. null을 전달하여 태그를 지웁니다. 반복 호출은 안전합니다. 가장 최신 태그가 우선합니다.
매개변수
| 매개변수 | 타입 | 기본값 | 설명 |
|---|---|---|---|
sessionId | string | 필수 | 태그를 지정할 세션의 UUID |
tag | string | null | 필수 | 태그 문자열 또는 지우려면 null |
options.dir | string | undefined | 프로젝트 디렉토리 경로입니다. 생략하면 모든 프로젝트 디렉토리를 검색합니다 |
resolveSettings()
CLI와 동일한 병합 엔진을 사용하여 주어진 디렉토리에 대한 효과적인 Claude Code 설정을 해결하며, Claude CLI를 생성하지 않습니다. query() 호출을 호출하기 전에 어떤 구성을 볼 수 있는지 검사하는 데 사용합니다.
이 함수는 알파 버전이며 안정화 전에 API가 변경될 수 있습니다. CLI 시작과의 패리티를 위해 macOS plist 및 Windows HKLM/HKCU를 포함한 MDM 소스를 읽지만, 관리자가 구성한
policyHelper 서브프로세스를 실행하지 않습니다. permissions.defaultMode 필드는 프로젝트 설정을 포함한 모든 계층에서 그대로 반환됩니다. CLI가 권한 상승 모드를 적용하기 전에 적용하는 신뢰 필터는 적용되지 않습니다.매개변수
resolveSettings()는 단일 옵션 객체를 수락합니다. 모든 필드는 선택적입니다.
| 매개변수 | 타입 | 기본값 | 설명 |
|---|---|---|---|
options.cwd | string | process.cwd() | 프로젝트 및 로컬 설정을 상대적으로 해결할 디렉토리 |
options.settingSources | SettingSource[] | 모든 소스 | 로드할 파일 시스템 소스입니다. 사용자, 프로젝트 및 로컬 설정을 건너뛰려면 []를 전달합니다. 관리 정책 설정은 모든 경우에 로드됩니다 |
options.managedSettings | Settings | undefined | 관리 정책 우선순위 수준에서 병합된 제한적 정책 계층 설정입니다. model과 같은 제한적이지 않은 키는 자동으로 삭제됩니다 |
options.serverManagedSettings | Settings | undefined | /api/claude_code/settings의 서버 관리 설정 페이로드입니다. 제한적이지 않은 키는 필터링 없이 통과합니다 |
반환 타입: ResolvedSettings
resolveSettings()는 병합된 설정과 각 키에 기여한 소스를 설명하는 객체를 반환합니다.
| 속성 | 타입 | 설명 |
|---|---|---|
effective | Settings | 모든 활성화된 소스를 우선순위 순서로 적용한 후 병합된 설정 |
provenance | Partial<Record<keyof Settings, ProvenanceEntry>> | effective의 각 최상위 키에 대해 값을 제공한 소스 |
sources | Array<{ source, settings, path?, policyOrigin? }> | 소스별 원본 설정, 가장 낮은 우선순위에서 가장 높은 우선순위 순서로 정렬됨 |
예제
아래 예제는 프로젝트 디렉토리에 대한 설정을 해결하고 정리 기간을 제어하는 소스를 인쇄합니다.타입
Options
query() 함수의 구성 객체입니다.
| 속성 | 타입 | 기본값 | 설명 |
|---|---|---|---|
abortController | AbortController | new AbortController() | 작업 취소를 위한 컨트롤러 |
additionalDirectories | string[] | [] | Claude가 액세스할 수 있는 추가 디렉토리 |
agent | string | undefined | 메인 스레드의 에이전트 이름입니다. 에이전트는 agents 옵션 또는 설정에서 정의되어야 합니다 |
agents | Record<string, [AgentDefinition](#agentdefinition)> | undefined | 프로그래밍 방식으로 서브에이전트 정의 |
agentProgressSummaries | boolean | false | true일 때 서브에이전트에 대한 한 줄 진행 요약을 생성하고 summary 필드를 통해 task_progress 이벤트에서 전달합니다. 포그라운드 및 백그라운드 서브에이전트에 적용됩니다 |
allowDangerouslySkipPermissions | boolean | false | 권한 건너뛰기 활성화합니다. permissionMode: 'bypassPermissions'를 사용할 때 필수입니다 |
allowedTools | string[] | [] | 프롬프트 없이 자동 승인할 도구입니다. 이것은 Claude를 이 도구들로만 제한하지 않습니다. 나열되지 않은 도구는 permissionMode 및 canUseTool로 넘어갑니다. disallowedTools를 사용하여 도구를 차단합니다. 권한 참조 |
betas | SdkBeta[] | [] | 베타 기능 활성화 |
canUseTool | CanUseTool | undefined | 도구 사용을 위한 사용자 정의 권한 함수 |
continue | boolean | false | 가장 최근 대화 계속 |
cwd | string | process.cwd() | 현재 작업 디렉토리 |
debug | boolean | false | Claude Code 프로세스에 대한 디버그 모드 활성화 |
debugFile | string | undefined | 특정 파일 경로에 디버그 로그를 작성합니다. 암묵적으로 디버그 모드를 활성화합니다 |
disallowedTools | string[] | [] | 거부할 도구입니다. Bash와 같은 단순 이름은 Claude의 컨텍스트에서 도구를 제거합니다. Bash(rm *)와 같은 범위 지정 규칙은 도구를 사용 가능하게 유지하고 bypassPermissions를 포함한 모든 권한 모드에서 일치하는 호출을 거부합니다. 권한 참조 |
effort | 'low' | 'medium' | 'high' | 'xhigh' | 'max' | 'high' | Claude가 응답에 투입하는 노력의 양을 제어합니다. 적응형 사고와 함께 작동하여 사고 깊이를 안내합니다 |
enableFileCheckpointing | boolean | false | 되감기를 위한 파일 변경 추적을 활성화합니다. 파일 체크포인팅 참조 |
env | Record<string, string | undefined> | process.env | 환경 변수입니다. 설정하면 이는 process.env와 병합하는 대신 서브프로세스 환경을 대체하므로 PATH와 같은 상속된 변수를 유지하려면 { ...process.env, YOUR_VAR: 'value' }를 전달합니다. 느린 또는 정지된 API 응답 처리에서 이 패턴의 예제를 참조하고, 기본 CLI가 읽는 변수는 환경 변수를 참조하세요. User-Agent 헤더에서 앱을 식별하려면 CLAUDE_AGENT_SDK_CLIENT_APP을 설정합니다 |
executable | 'bun' | 'deno' | 'node' | 자동 감지 | 사용할 JavaScript 런타임 |
executableArgs | string[] | [] | 실행 파일에 전달할 인수 |
extraArgs | Record<string, string | null> | {} | 추가 인수 |
fallbackModel | string | undefined | 기본 모델이 실패할 경우 사용할 모델 |
forkSession | boolean | false | resume으로 재개할 때 원본 세션을 계속하는 대신 새 세션 ID로 포크합니다 |
forwardSubagentText | boolean | false | 서브에이전트의 텍스트 및 사고 블록을 parent_tool_use_id가 설정된 어시스턴트 및 사용자 메시지로 전달하여 소비자가 중첩된 대화를 렌더링할 수 있습니다. 기본적으로 서브에이전트의 tool_use 및 tool_result 블록만 내보내집니다 |
hooks | Partial<Record<HookEvent, HookCallbackMatcher[]>> | {} | 이벤트에 대한 훅 콜백 |
includeHookEvents | boolean | false | 훅 라이프사이클 이벤트를 SDKHookStartedMessage, SDKHookProgressMessage 및 SDKHookResponseMessage로 메시지 스트림에 포함합니다 |
includePartialMessages | boolean | false | 부분 메시지 이벤트 포함 |
loadTimeoutMs | number | 60000 | 알파. 재개 구체화 중 각 sessionStore.load() 및 sessionStore.listSubkeys() 호출에 대한 밀리초 단위의 타임아웃입니다. 어댑터가 이 윈도우 내에서 정착하지 않으면 쿼리가 중단되는 대신 실패합니다. sessionStore가 설정되지 않으면 무시됩니다 |
managedSettings | Settings | undefined | 생성 부모 프로세스에서 제공하는 정책 계층 설정입니다. 머신에 IT 제어 관리 설정 계층이 이미 있으면 삭제되며, 해당 관리자가 parentSettingsBehavior: 'merge'로 옵트인하지 않는 한 삭제됩니다. 제한적 전용 키로 필터링됩니다 |
maxBudgetUsd | number | undefined | 클라이언트 측 비용 추정이 이 USD 값에 도달하면 쿼리를 중지합니다. total_cost_usd와 동일한 추정과 비교됩니다. 비용 및 사용량 추적 참조 |
maxThinkingTokens | number | undefined | 더 이상 사용되지 않음: 대신 thinking을 사용합니다. 사고 프로세스의 최대 토큰 |
maxTurns | number | undefined | 최대 에이전트 턴 (도구 사용 왕복) |
mcpServers | Record<string, [McpServerConfig](#mcpserverconfig)> | {} | MCP 서버 구성 |
model | string | CLI의 기본값 | 사용할 Claude 모델 |
onElicitation | (request: ElicitationRequest, options: { signal: AbortSignal }) => Promise<ElicitationResult> | undefined | MCP 유도 요청을 처리하기 위한 콜백입니다. MCP 서버가 사용자 입력을 요청하고 훅이 먼저 처리하지 않을 때 호출됩니다. 제공되지 않으면 처리되지 않은 유도 요청이 자동으로 거부됩니다 |
outputFormat | { type: 'json_schema', schema: JSONSchema } | undefined | 에이전트 결과의 출력 형식을 정의합니다. 구조화된 출력 참조 |
outputStyle | string | undefined | Options 필드가 아닙니다. 대신 인라인 settings 객체 또는 설정 파일에서 outputStyle을 설정합니다. 출력 스타일 활성화 참조 |
pathToClaudeCodeExecutable | string | 번들된 네이티브 바이너리에서 자동 해결 | Claude Code 실행 파일의 경로입니다. 설치 중에 선택적 종속성을 건너뛰었거나 플랫폼이 지원되는 집합에 없을 때만 필요합니다 |
permissionMode | PermissionMode | 'default' | 세션의 권한 모드 |
permissionPromptToolName | string | undefined | 권한 프롬프트용 MCP 도구 이름 |
persistSession | boolean | true | false일 때 디스크에 세션 지속성을 비활성화합니다. 세션을 나중에 재개할 수 없습니다 |
planModeInstructions | string | undefined | 계획 모드에 대한 사용자 정의 워크플로우 지침입니다. permissionMode가 'plan'일 때 이 문자열은 기본 계획 모드 워크플로우 본문을 대체합니다. CLI는 여전히 읽기 전용 적용 프리앰블 및 ExitPlanMode 프로토콜 바닥글로 래핑합니다 |
plugins | SdkPluginConfig[] | [] | 로컬 경로에서 사용자 정의 플러그인을 로드합니다. 플러그인 참조 |
promptSuggestions | boolean | false | 프롬프트 제안을 활성화합니다. 각 턴 후 예측된 다음 사용자 프롬프트를 포함하는 prompt_suggestion 메시지를 내보냅니다 |
resume | string | undefined | 재개할 세션 ID |
resumeSessionAt | string | undefined | 특정 메시지 UUID에서 세션 재개 |
sandbox | SandboxSettings | undefined | 프로그래밍 방식으로 샌드박스 동작을 구성합니다. 샌드박스 설정 참조 |
sessionId | string | 자동 생성 | 자동 생성하는 대신 세션에 특정 UUID를 사용합니다 |
sessionStore | SessionStore | undefined | 세션 대화를 외부 백엔드로 미러링하여 모든 호스트가 이를 재개할 수 있습니다. 세션을 외부 저장소에 유지 참조 |
sessionStoreFlush | 'batched' | 'eager' | 'batched' | 알파. sessionStore의 플러시 모드입니다. sessionStore가 설정되지 않으면 무시됩니다 |
settings | string | Settings | undefined | 인라인 설정 객체 또는 설정 파일의 경로입니다. 우선순위 순서에서 플래그 설정 계층을 채웁니다. applyFlagSettings()로 런타임에 변경합니다 |
settingSources | SettingSource[] | CLI 기본값 (모든 소스) | 로드할 파일 시스템 설정을 제어합니다. 사용자, 프로젝트 및 로컬 설정을 비활성화하려면 []을 전달합니다. 관리되는 정책 설정은 어쨌든 로드됩니다. Claude Code 기능 사용 참조 |
skills | string[] | 'all' | undefined | 세션에서 사용 가능한 스킬입니다. 모든 발견된 스킬을 활성화하려면 'all'을 전달하거나 스킬 이름 목록을 전달합니다. 설정하면 SDK는 allowedTools에 Skill 도구를 자동으로 추가합니다. tools도 전달하는 경우 해당 목록에 'Skill'을 포함합니다. 스킬 참조 |
spawnClaudeCodeProcess | (options: SpawnOptions) => SpawnedProcess | undefined | Claude Code 프로세스를 생성하는 사용자 정의 함수입니다. VM, 컨테이너 또는 원격 환경에서 Claude Code를 실행하는 데 사용합니다 |
stderr | (data: string) => void | undefined | stderr 출력에 대한 콜백 |
strictMcpConfig | boolean | false | mcpServers에 전달된 서버만 사용하고 프로젝트 .mcp.json, 사용자 설정, 플러그인 제공 MCP 서버 및 claude.ai 커넥터를 무시합니다 |
systemPrompt | string | { type: 'preset'; preset: 'claude_code'; append?: string; excludeDynamicSections?: boolean } | undefined (최소 프롬프트) | 시스템 프롬프트 구성입니다. 사용자 정의 프롬프트의 경우 문자열을 전달하거나, Claude Code의 시스템 프롬프트를 사용하려면 { type: 'preset', preset: 'claude_code' }를 전달합니다. 프리셋 객체 형식을 사용할 때 append를 추가하여 추가 지침으로 확장하고, excludeDynamicSections: true를 설정하여 세션별 컨텍스트를 첫 번째 사용자 메시지로 이동하여 머신 간 프롬프트 캐시 재사용 개선 |
taskBudget | { total: number } | undefined | 알파. API 측 작업 예산 (토큰 단위)입니다. 설정하면 모델은 도구 사용을 조절하고 제한 전에 마무리할 수 있도록 남은 토큰 예산을 알려집니다 |
thinking | ThinkingConfig | 지원되는 모델의 경우 { type: 'adaptive' } | Claude의 사고/추론 동작을 제어합니다. ThinkingConfig 참조 |
title | string | undefined | 세션의 표시 제목입니다. resume 또는 continue를 통해 재개할 때 재개된 세션의 지속된 제목이 우선합니다. renameSession()을 사용하여 기존 세션의 제목을 변경합니다 |
toolAliases | Record<string, string> | undefined | 기본 제공 도구 이름을 MCP 도구 이름으로 매핑하여 Claude가 기본 제공 대신 MCP 구현을 호출하도록 합니다. 예를 들어 { Bash: 'mcp__workspace__bash' } |
toolConfig | ToolConfig | undefined | 기본 제공 도구 동작의 구성입니다. ToolConfig 참조 |
tools | string[] | { type: 'preset'; preset: 'claude_code' } | undefined | 도구 구성입니다. 도구 이름의 배열을 전달하거나 프리셋을 사용하여 Claude Code의 기본 도구를 가져옵니다 |
느린 또는 정지된 API 응답 처리
CLI 서브프로세스는 API 타임아웃 및 정지 감지를 제어하는 여러 환경 변수를 읽습니다.env 옵션을 통해 전달합니다:
API_TIMEOUT_MS: Anthropic 클라이언트의 요청당 타임아웃 (밀리초 단위). 기본값600000. 메인 루프 및 모든 서브에이전트에 적용됩니다.CLAUDE_CODE_MAX_RETRIES: 최대 API 재시도 횟수. 기본값10. 각 재시도는 자체API_TIMEOUT_MS윈도우를 가지므로 최악의 경우 벽시간은 대략API_TIMEOUT_MS × (CLAUDE_CODE_MAX_RETRIES + 1)더하기 백오프입니다.CLAUDE_ASYNC_AGENT_STALL_TIMEOUT_MS:run_in_background으로 시작된 서브에이전트에 대한 정지 감시견입니다. 기본값600000. 각 스트림 이벤트에서 재설정되며, 정지 시 서브에이전트를 중단하고 작업을 실패로 표시하며 부분 결과와 함께 오류를 부모에게 표시합니다. 동기 서브에이전트에는 적용되지 않습니다.CLAUDE_ENABLE_STREAM_WATCHDOG=1및CLAUDE_STREAM_IDLE_TIMEOUT_MS: 헤더가 도착했지만 응답 본문이 스트리밍을 중지할 때 요청을 중단합니다. 기본적으로 꺼져 있습니다.CLAUDE_STREAM_IDLE_TIMEOUT_MS는 기본값300000이고 해당 최소값으로 고정됩니다. 중단된 요청은 일반 재시도 경로를 거칩니다.
Query 객체
query() 함수에서 반환된 인터페이스입니다.
메서드
| 메서드 | 설명 |
|---|---|
interrupt() | 쿼리를 중단합니다 (스트리밍 입력 모드에서만 사용 가능) |
rewindFiles(userMessageId, options?) | 파일을 지정된 사용자 메시지의 상태로 복원합니다. 변경 사항을 미리 보려면 { dryRun: true }를 전달합니다. enableFileCheckpointing: true가 필요합니다. 파일 체크포인팅 참조 |
setPermissionMode() | 권한 모드를 변경합니다 (스트리밍 입력 모드에서만 사용 가능) |
setModel() | 모델을 변경합니다 (스트리밍 입력 모드에서만 사용 가능) |
setMaxThinkingTokens() | 더 이상 사용되지 않음: 대신 thinking 옵션을 사용합니다. 최대 사고 토큰을 변경합니다 |
applyFlagSettings(settings) | 런타임에 세션의 플래그 설정 계층으로 설정을 병합합니다 (스트리밍 입력 모드에서만 사용 가능). applyFlagSettings() 참조 |
initializationResult() | 지원되는 명령, 모델, 계정 정보 및 출력 스타일 구성을 포함한 전체 초기화 결과를 반환합니다 |
supportedCommands() | 사용 가능한 슬래시 명령을 반환합니다 |
supportedModels() | 표시 정보를 포함한 사용 가능한 모델을 반환합니다 |
supportedAgents() | 사용 가능한 서브에이전트를 AgentInfo[]로 반환합니다 |
mcpServerStatus() | 연결된 MCP 서버의 상태를 반환합니다 |
accountInfo() | 계정 정보를 반환합니다 |
reconnectMcpServer(serverName) | 이름으로 MCP 서버를 다시 연결합니다 |
toggleMcpServer(serverName, enabled) | 이름으로 MCP 서버를 활성화 또는 비활성화합니다 |
setMcpServers(servers) | 이 세션의 MCP 서버 집합을 동적으로 바꿉니다. 추가, 제거 및 오류가 발생한 서버에 대한 정보를 반환합니다 |
streamInput(stream) | 다중 턴 대화를 위해 입력 메시지를 쿼리로 스트리밍합니다 |
stopTask(taskId) | ID로 실행 중인 백그라운드 작업을 중지합니다 |
close() | 쿼리를 닫고 기본 프로세스를 종료합니다. 쿼리를 강제로 종료하고 모든 리소스를 정리합니다 |
applyFlagSettings()
실행 중인 세션에서 설정을 변경하고 쿼리를 다시 시작하지 않습니다. 전용 설정자가 없는 설정이 변경되어야 할 때 사용합니다. 예를 들어 에이전트가 신뢰할 수 없는 입력을 읽은 후 permissions를 강화합니다. setModel() 및 setPermissionMode()는 이 두 키에 대한 전용 설정자입니다. applyFlagSettings()는 설정 키의 모든 부분 집합을 허용하는 일반 형식이며, 여기에 model을 전달하는 것은 setModel()과 동일하게 작동합니다.
다음 턴에 적용되는 키만 있습니다:
- 다음 턴에 적용됨:
model,effortLevel,ultracode,permissions,hooks,skillOverrides,fastMode,awaySummaryEnabled,agent.agent를 전환하면 해당 에이전트의 모델 재정의, 훅 및 시스템 프롬프트도 다음 턴에 적용됩니다. - 세션 중 효과 없음: 시스템 프롬프트 옵션입니다. 이들은 시작 시 한 번 해결되므로 실행 중인 세션은 호출이 성공하더라도 원본 값을 유지합니다. 이를 변경하려면 새 세션을 시작합니다.
query()의 인라인 settings 옵션이 시작 시 채우는 계층과 동일합니다. 플래그 설정은 설정 우선순위 순서의 상단 근처에 있습니다: 사용자, 프로젝트 및 로컬 설정을 재정의하며, 관리되는 정책 설정만 이를 재정의할 수 있습니다. 이는 우선순위 섹션이 프로그래밍 방식의 옵션이라고 부르는 것과 동일한 계층입니다.
연속 호출은 최상위 키를 얕게 병합합니다. { permissions: {...} }를 포함한 두 번째 호출은 이전 호출의 전체 permissions 객체를 대체하며 깊게 병합하지 않습니다. 플래그 계층에서 키를 지우고 낮은 우선순위 소스로 돌아가려면 해당 키에 null을 전달합니다. undefined를 전달하면 JSON 직렬화가 이를 삭제하므로 효과가 없습니다.
스트리밍 입력 모드에서만 사용 가능하며, 이는 setModel() 및 setPermissionMode()와 동일한 제약입니다.
아래 예제는 세션 중간에 활성 모델을 전환한 다음 재정의를 지우므로 모델이 사용자 또는 프로젝트 설정이 지정하는 것으로 돌아갑니다.
applyFlagSettings()는 TypeScript 전용입니다. Python SDK는 동등한 메서드를 노출하지 않습니다.WarmQuery
startup()에서 반환된 핸들입니다. 서브프로세스가 이미 생성되고 초기화되었으므로 이 핸들에서 query()를 호출하면 시작 지연 없이 준비된 프로세스에 프롬프트를 직접 작성합니다.
메서드
| 메서드 | 설명 |
|---|---|
query(prompt) | 미리 준비된 서브프로세스에 프롬프트를 보내고 Query를 반환합니다. WarmQuery당 한 번만 호출할 수 있습니다 |
close() | 프롬프트를 보내지 않고 서브프로세스를 닫습니다. 더 이상 필요하지 않은 따뜻한 쿼리를 버리는 데 사용합니다 |
WarmQuery는 AsyncDisposable을 구현하므로 자동 정리를 위해 await using과 함께 사용할 수 있습니다.
SDKControlInitializeResponse
initializationResult()의 반환 타입입니다. 세션 초기화 데이터를 포함합니다.
initialize를 보낼 때 제어 응답 래퍼는 선택적 pending_permission_requests 배열도 전달합니다. 필드는 응답 래퍼 자체에 있으며, 위의 SDKControlInitializeResponse 페이로드에는 없습니다. 각 항목은 세션이 실행 중일 때 권한 요청에 대해 스트리밍하는 것과 동일한 { type: "control_request", request_id, request } 형태의 완전한 control_request 메시지입니다.
이들은 클라이언트가 연결되기 전에 발급되었으며 여전히 회신을 기다리고 있는 요청이므로 이 배열을 읽어 진행 중인 권한 프롬프트를 즉시 표시합니다. 이들은 다시 전송되지 않습니다.
AgentDefinition
프로그래밍 방식으로 정의된 서브에이전트의 구성입니다.
| 필드 | 필수 | 설명 |
|---|---|---|
description | 예 | 이 에이전트를 사용할 시기에 대한 자연어 설명 |
tools | 아니오 | 허용된 도구 이름의 배열입니다. 생략하면 부모의 모든 도구를 상속합니다. 에이전트의 컨텍스트에 스킬을 미리 로드하려면 'Skill'을 여기에 나열하는 대신 skills 필드를 사용합니다 |
disallowedTools | 아니오 | 이 에이전트에 대해 명시적으로 허용하지 않을 도구 이름의 배열 |
prompt | 예 | 에이전트의 시스템 프롬프트 |
model | 아니오 | 이 에이전트의 모델 재정의입니다. 'sonnet', 'opus', 'haiku', 'inherit' 같은 별칭 또는 전체 모델 ID를 허용합니다. 생략하거나 'inherit'이면 메인 모델을 사용합니다 |
mcpServers | 아니오 | 이 에이전트에 사용 가능한 MCP 서버 사양 |
skills | 아니오 | 에이전트 컨텍스트에 미리 로드할 스킬 이름의 배열 |
initialPrompt | 아니오 | 이 에이전트가 메인 스레드 에이전트로 실행될 때 첫 번째 사용자 턴으로 자동 제출됨 |
maxTurns | 아니오 | 중지하기 전의 최대 에이전트 턴 수 (API 왕복) |
background | 아니오 | 호출될 때 이 에이전트를 비차단 백그라운드 작업으로 실행 |
memory | 아니오 | 이 에이전트의 메모리 소스: 'user', 'project' 또는 'local' |
effort | 아니오 | 이 에이전트의 추론 노력 수준입니다. 명명된 수준 또는 정수를 허용합니다 |
permissionMode | 아니오 | 이 에이전트 내 도구 실행을 위한 권한 모드입니다. PermissionMode 참조 |
criticalSystemReminder_EXPERIMENTAL | 아니오 | 실험적: 시스템 프롬프트에 추가된 중요한 알림 |
AgentMcpServerSpec
서브에이전트에 사용 가능한 MCP 서버를 지정합니다. 서버 이름 (부모의 mcpServers 구성에서 서버를 참조하는 문자열) 또는 서버 이름을 구성에 매핑하는 인라인 서버 구성 레코드일 수 있습니다.
McpServerConfigForProcessTransport는 McpStdioServerConfig | McpSSEServerConfig | McpHttpServerConfig | McpSdkServerConfig입니다.
SettingSource
SDK가 설정을 로드하는 파일 시스템 기반 구성 소스를 제어합니다.
| 값 | 설명 | 위치 |
|---|---|---|
'user' | 전역 사용자 설정 | ~/.claude/settings.json |
'project' | 공유 프로젝트 설정 (버전 제어됨) | .claude/settings.json |
'local' | 로컬 프로젝트 설정 (gitignored) | .claude/settings.local.json |
기본 동작
settingSources가 생략되거나 undefined일 때 query()는 Claude Code CLI와 동일한 파일 시스템 설정을 로드합니다: 사용자, 프로젝트 및 로컬입니다. 관리되는 정책 설정은 모든 경우에 로드됩니다. Claude Code 기능 사용을 참조하여 이 옵션과 관계없이 읽히는 입력과 이를 비활성화하는 방법을 확인하세요.
settingSources를 사용하는 이유
파일 시스템 설정 비활성화:설정 우선순위
여러 소스가 로드될 때 설정은 이 우선순위로 병합됩니다 (높음에서 낮음):- 로컬 설정 (
.claude/settings.local.json) - 프로젝트 설정 (
.claude/settings.json) - 사용자 설정 (
~/.claude/settings.json)
agents, allowedTools 및 settings와 같은 프로그래밍 방식의 옵션은 사용자, 프로젝트 및 로컬 파일 시스템 설정을 재정의합니다. 관리되는 정책 설정은 프로그래밍 방식의 옵션보다 우선합니다.
PermissionMode
CanUseTool
도구 사용을 제어하기 위한 사용자 정의 권한 함수 타입입니다.
| 옵션 | 타입 | 설명 |
|---|---|---|
signal | AbortSignal | 작업을 중단해야 하는 경우 신호됨 |
suggestions | PermissionUpdate[] | 사용자가 이 도구에 대해 다시 프롬프트되지 않도록 제안된 권한 업데이트입니다. Bash 프롬프트는 localSettings 대상을 포함하는 제안을 포함하므로 updatedPermissions에서 반환하면 규칙을 .claude/settings.local.json에 작성하고 세션 간에 유지합니다. |
blockedPath | string | 해당하는 경우 권한 요청을 트리거한 파일 경로 |
decisionReason | string | 이 권한 요청이 트리거된 이유를 설명합니다 |
toolUseID | string | 어시스턴트 메시지 내 이 특정 도구 호출의 고유 식별자 |
agentID | string | 서브에이전트 내에서 실행 중인 경우 서브에이전트의 ID |
PermissionResult
권한 확인의 결과입니다.
ToolConfig
기본 제공 도구 동작의 구성입니다.
| 필드 | 타입 | 설명 |
|---|---|---|
askUserQuestion.previewFormat | 'markdown' | 'html' | AskUserQuestion 옵션의 preview 필드를 옵트인하고 콘텐츠 형식을 설정합니다. 설정하지 않으면 Claude는 미리보기를 내보내지 않습니다 |
McpServerConfig
MCP 서버의 구성입니다.
McpStdioServerConfig
McpSSEServerConfig
McpHttpServerConfig
McpSdkServerConfigWithInstance
McpClaudeAIProxyServerConfig
SdkPluginConfig
SDK에서 플러그인을 로드하기 위한 구성입니다.
| 필드 | 타입 | 설명 |
|---|---|---|
type | 'local' | 'local'이어야 합니다 (현재 로컬 플러그인만 지원됨) |
path | string | 플러그인 디렉토리의 절대 또는 상대 경로 |
메시지 타입
SDKMessage
쿼리에서 반환된 모든 가능한 메시지의 합집합 타입입니다.
SDKAssistantMessage
어시스턴트 응답 메시지입니다.
message 필드는 Anthropic SDK의 BetaMessage입니다. id, content, model, stop_reason 및 usage와 같은 필드를 포함합니다.
SDKAssistantMessageError는 다음 중 하나입니다: 'authentication_failed', 'oauth_org_not_allowed', 'billing_error', 'rate_limit', 'overloaded', 'invalid_request', 'model_not_found', 'server_error', 'max_output_tokens' 또는 'unknown'. 'model_not_found'는 선택한 모델이 존재하지 않거나 계정 또는 배포에서 사용할 수 없음을 의미합니다. 'overloaded'는 API가 서버가 용량에 도달했기 때문에 529를 반환했음을 의미하며, 이는 할당량에 대한 429인 'rate_limit'과는 다릅니다.
SDKUserMessage
사용자 입력 메시지입니다.
shouldQuery를 false로 설정하여 어시스턴트 턴을 트리거하지 않고 메시지를 트랜스크립트에 추가합니다. 메시지는 보류되고 턴을 트리거하는 다음 사용자 메시지로 병합됩니다. 이를 사용하여 모델 호출을 소비하지 않고 대역 외에서 실행한 명령의 출력과 같은 컨텍스트를 주입합니다.
SDKUserMessageReplay
필수 UUID를 포함한 재생된 사용자 메시지입니다.
SDKResultMessage
최종 결과 메시지입니다.
subtype 이상의 진단 세부 정보를 전달합니다:
api_error_status: 대화를 종료한 API 오류의 HTTP 상태 코드입니다. API 오류 없이 턴이 종료되었을 때는 없거나null입니다.ttft_ms: 첫 번째 토큰까지의 시간(밀리초)입니다. 성공 경로에만 표시됩니다.terminal_reason: 루프가 종료된 이유입니다."completed","max_turns","tool_deferred","aborted_streaming","aborted_tools","hook_stopped","stop_hook_prevented","blocking_limit","rapid_refill_breaker","prompt_too_long","image_error"또는"model_error"중 하나입니다.fast_mode_state:"on","off"또는"cooldown"중 하나입니다.
origin 필드는 이 결과를 트리거한 사용자 메시지의 SDKMessageOrigin을 전달합니다. 백그라운드 작업이 완료되고 SDK가 합성 후속 턴을 주입할 때, 결과 SDKResultMessage는 origin: { kind: "task-notification" }을 전달합니다. 이 필드를 확인하여 프롬프트에 답하는 결과와 백그라운드 작업 후속을 위해 내보낸 결과를 구분하여 후자를 라우팅하거나 억제할 수 있습니다. 이 필드는 시작 오류와 같이 사용자 턴 이전에 내보낸 결과에는 없습니다.
PreToolUse 훅이 permissionDecision: "defer"를 반환할 때, 결과는 stop_reason: "tool_deferred"를 가지며 deferred_tool_use는 보류 중인 도구의 id, name 및 input을 전달합니다. 이 필드를 읽어 요청을 자신의 UI에 표시한 다음 동일한 session_id로 재개하여 계속합니다. 전체 왕복은 나중을 위해 도구 호출 연기를 참조하십시오.
SDKSystemMessage
시스템 초기화 메시지입니다.
SDKPartialAssistantMessage
스트리밍 부분 메시지 (includePartialMessages가 true일 때만).
SDKCompactBoundaryMessage
대화 압축 경계를 나타내는 메시지입니다.
SDKPluginInstallMessage
플러그인 설치 진행 이벤트입니다. CLAUDE_CODE_SYNC_PLUGIN_INSTALL이 설정되면 내보내지므로 Agent SDK 애플리케이션이 첫 번째 턴 전에 마켓플레이스 플러그인 설치를 추적할 수 있습니다. started 및 completed 상태는 전체 설치를 괄호로 묶습니다. installed 및 failed 상태는 개별 마켓플레이스를 보고하고 name을 포함합니다.
SDKPermissionDeniedMessage
권한 시스템이 대화형 프롬프트 없이 도구 호출을 자동으로 거부할 때 내보내지는 스트림 이벤트입니다. 이를 사용하여 거부를 UI에 렌더링할 수 있으며, 뒤따르는 is_error 도구 결과만 관찰하는 것이 아닙니다. 대화형 요청 경로는 canUseTool 콜백을 통해 애플리케이션에 별도로 도달합니다. PreToolUse 훅에서 발급된 거부는 이 이벤트를 통해 보고되지 않습니다.
이 이벤트는 Claude Code v2.1.136 이상이 필요합니다.
| 필드 | 타입 | 설명 |
|---|---|---|
tool_name | string | 거부된 도구의 이름 |
tool_use_id | string | 이 거부가 답하는 tool_use 블록의 ID |
agent_id | string | 거부된 호출이 서브에이전트 내부에서 발생한 경우 서브에이전트 ID입니다. 호스트 측 라우팅을 위해 can_use_tool의 필드를 미러링합니다 |
decision_reason_type | string | "rule", "mode", "classifier" 또는 "asyncAgent"와 같이 결정한 구성 요소의 판별자 |
decision_reason | string | 사용 가능할 때 결정 구성 요소의 인간이 읽을 수 있는 이유 |
message | string | tool_result에서 모델에 반환된 거부 메시지 |
SDKPermissionDenial
거부된 도구 사용에 대한 정보입니다.
SDKMessageOrigin
사용자 역할 메시지의 출처입니다. 이는 SDKUserMessage의 origin으로 나타나며 해당 SDKResultMessage로 전달되므로 주어진 턴을 트리거한 것을 알 수 있습니다.
kind | 의미 |
|---|---|
human | 최종 사용자의 직접 입력입니다. 사용자 메시지에서 없는 origin도 인간 입력을 의미합니다. |
channel | 채널에 도착한 메시지입니다. server는 소스 MCP 서버 이름입니다. |
peer | SendMessage를 통한 다른 에이전트 세션의 메시지입니다. from은 발신자 주소이고 name은 사용 가능할 때 발신자의 표시 이름입니다. |
task-notification | 백그라운드 작업이 완료된 후 주입된 합성 턴입니다. SDKTaskNotificationMessage를 참조하십시오. |
coordinator | 에이전트 팀의 팀 코디네이터로부터의 메시지입니다. |
훅 타입
훅 사용에 대한 포괄적인 가이드, 예제 및 일반적인 패턴은 훅 가이드를 참조하세요.HookEvent
사용 가능한 훅 이벤트입니다.
HookCallback
훅 콜백 함수 타입입니다.
HookCallbackMatcher
선택적 매처를 포함한 훅 구성입니다.
HookInput
모든 훅 입력 타입의 합집합 타입입니다.
BaseHookInput
모든 훅 입력 타입이 확장하는 기본 인터페이스입니다.
PreToolUseHookInput
PostToolUseHookInput
PostToolUseFailureHookInput
PostToolBatchHookInput
배치의 모든 도구 호출이 해결된 후, 다음 모델 요청 전에 한 번 실행됩니다. tool_response는 모델이 보는 직렬화된 tool_result 콘텐츠를 전달합니다. 형태는 PostToolUseHookInput의 구조화된 Output 객체와 다릅니다.
NotificationHookInput
UserPromptSubmitHookInput
SessionStartHookInput
SessionEndHookInput
StopHookInput
SubagentStartHookInput
SubagentStopHookInput
PreCompactHookInput
PermissionRequestHookInput
SetupHookInput
TeammateIdleHookInput
TaskCompletedHookInput
ConfigChangeHookInput
WorktreeCreateHookInput
WorktreeRemoveHookInput
MessageDisplayHookInput
HookJSONOutput
훅 반환값입니다.
AsyncHookJSONOutput
SyncHookJSONOutput
도구 입력 타입
모든 기본 제공 Claude Code 도구의 입력 스키마 문서입니다. 이 타입은@anthropic-ai/claude-agent-sdk에서 내보내지며 타입 안전 도구 상호작용에 사용할 수 있습니다.
ToolInputSchemas
모든 도구 입력 타입의 합집합으로, @anthropic-ai/claude-agent-sdk에서 내보냅니다.
Agent
도구 이름:Agent (이전 Task, 여전히 별칭으로 수락됨)
AskUserQuestion
도구 이름:AskUserQuestion
Bash
도구 이름:Bash
Monitor
도구 이름:Monitor
persistent: true를 설정합니다. Monitor는 Bash와 동일한 권한 규칙을 따릅니다. Monitor 도구 참조에서 동작 및 공급자 가용성을 참조하세요.
TaskOutput
도구 이름:TaskOutput
Edit
도구 이름:Edit
Read
도구 이름:Read
pages를 사용합니다 (예: "1-5").
Write
도구 이름:Write
Glob
도구 이름:Glob
Grep
도구 이름:Grep
TaskStop
도구 이름:TaskStop
NotebookEdit
도구 이름:NotebookEdit
WebFetch
도구 이름:WebFetch
WebSearch
도구 이름:WebSearch
Workflow
도구 이름:Workflow
Workflow 도구는 Agent SDK v0.3.149 이상에서 사용 가능합니다. script, name 또는 scriptPath 중 최소 하나가 필요합니다.
| 필드 | 타입 | 설명 |
|---|---|---|
script | string | 인라인 워크플로우 스크립트입니다. export const meta = { name, description, phases }로 시작해야 하며, 그 뒤에 agent(), parallel(), pipeline() 및 phase()를 사용하는 스크립트 본문이 따릅니다 |
name | string | 기본 제공 워크플로우의 이름 또는 .claude/workflows/에 저장된 워크플로우입니다. 스크립트로 확인됩니다 |
scriptPath | string | 디스크의 워크플로우 스크립트 파일 경로입니다. script 및 name보다 우선합니다. 모든 호출은 스크립트를 유지하고 결과에서 경로를 반환하므로, 해당 파일을 편집하고 동일한 scriptPath로 다시 호출하여 반복할 수 있습니다 |
args | unknown | 스크립트에 전역 args로 노출되는 입력 값으로, 연구 질문이나 파일 경로 목록과 같은 매개변수화된 명명된 워크플로우용입니다. 배열과 객체를 JSON 인코딩된 문자열이 아닌 실제 JSON 값으로 전달합니다 |
resumeFromRunId | string | 재개할 이전 Workflow 호출의 실행 ID입니다. 입력이 변경되지 않은 완료된 agent() 호출은 캐시된 결과를 반환합니다. 변경되거나 새로운 호출만 실시간으로 실행됩니다. 동일한 세션만 해당됩니다 |
TodoWrite
도구 이름:TodoWrite
TypeScript Agent SDK 0.3.142부터
TodoWrite는 기본적으로 비활성화됩니다. 대신 TaskCreate, TaskGet, TaskUpdate 및 TaskList를 사용하세요. 모니터링 코드를 업데이트하려면 작업 도구로 마이그레이션을 참조하거나, CLAUDE_CODE_ENABLE_TASKS=0을 설정하여 TodoWrite로 되돌립니다.TaskCreate
도구 이름:TaskCreate
TaskUpdate
도구 이름:TaskUpdate
status를 "deleted"로 설정하여 제거합니다.
TaskGet
도구 이름:TaskGet
null을 반환합니다.
TaskList
도구 이름:TaskList
ExitPlanMode
도구 이름:ExitPlanMode
ListMcpResources
도구 이름:ListMcpResourcesTool
ReadMcpResource
도구 이름:ReadMcpResourceTool
EnterWorktree
도구 이름:EnterWorktree
path를 전달합니다. name 및 path는 상호 배타적입니다.
도구 출력 타입
모든 기본 제공 Claude Code 도구의 출력 스키마 문서입니다. 이 타입은@anthropic-ai/claude-agent-sdk에서 내보내지며 각 도구에서 반환된 실제 응답 데이터를 나타냅니다.
ToolOutputSchemas
모든 도구 출력 타입의 합집합입니다.
Agent
도구 이름:Agent (이전 Task, 여전히 별칭으로 수락됨)
status 필드에서 구분됩니다: 완료된 작업의 경우 "completed", 백그라운드 작업의 경우 "async_launched", 대화형 서브에이전트의 경우 "sub_agent_entered".
AskUserQuestion
도구 이름:AskUserQuestion
response는 사용자가 구조화된 질문에 답하는 대신 자유 형식 답변을 입력했을 때 설정됩니다. 존재할 때, Claude는 질문별 답변 목록 대신 “사용자가 응답했습니다: …”를 받습니다.
Bash
도구 이름:Bash
backgroundTaskId를 포함합니다.
Monitor
도구 이름:Monitor
TaskStop과 함께 사용하여 감시를 조기에 취소합니다.
Edit
도구 이름:Edit
Read
도구 이름:Read
type 필드에서 구분됩니다.
Write
도구 이름:Write
Glob
도구 이름:Glob
Grep
도구 이름:Grep
mode에 따라 다릅니다: 파일 목록, 일치 항목이 있는 콘텐츠 또는 일치 항목 수.
TaskStop
도구 이름:TaskStop
NotebookEdit
도구 이름:NotebookEdit
WebFetch
도구 이름:WebFetch
WebSearch
도구 이름:WebSearch
Workflow
도구 이름:Workflow
error를 확인하십시오: 구문 검사에 실패한 스크립트는 status: "async_launched"를 반환하고 error가 설정되며, 실행되지 않습니다.
| 필드 | 타입 | 설명 |
|---|---|---|
status | "async_launched" | 도구가 호출을 수락했습니다. 이것이 필드가 취하는 유일한 값입니다 |
taskId | string | 실행을 위한 백그라운드 작업 식별자 |
runId | string | 나중의 호출에서 resumeFromRunId로 전달할 워크플로우 실행 식별자 |
summary | string | 워크플로우가 수행하는 작업에 대한 한 줄 설명 |
transcriptDir | string | 실행 중에 서브에이전트 트랜스크립트가 작성되는 디렉토리 |
scriptPath | string | 이 실행을 위해 유지된 워크플로우 스크립트의 경로입니다. 스크립트를 다시 보내지 않고 다시 실행하려면 편집하고 scriptPath로 다시 전달하십시오 |
error | string | 스크립트가 구문 검사에 실패할 때 설정됩니다. 존재할 때, async_launched 상태에도 불구하고 실행이 시작되지 않았습니다 |
TodoWrite
도구 이름:TodoWrite
TypeScript Agent SDK 0.3.142부터
TodoWrite는 기본적으로 비활성화됩니다. 대신 TaskCreate, TaskGet, TaskUpdate, TaskList를 사용하십시오. 모니터링 코드를 업데이트하려면 작업 도구로 마이그레이션을 참조하거나, CLAUDE_CODE_ENABLE_TASKS=0을 설정하여 TodoWrite로 되돌립니다.TaskCreate
도구 이름:TaskCreate
TaskUpdate
도구 이름:TaskUpdate
TaskGet
도구 이름:TaskGet
null을 반환합니다.
TaskList
도구 이름:TaskList
ExitPlanMode
도구 이름:ExitPlanMode
ListMcpResources
도구 이름:ListMcpResourcesTool
ReadMcpResource
도구 이름:ReadMcpResourceTool
EnterWorktree
도구 이름:EnterWorktree
권한 타입
PermissionUpdate
권한 업데이트 작업입니다.
PermissionBehavior
PermissionUpdateDestination
PermissionRuleValue
기타 타입
ApiKeySource
SdkBeta
betas 옵션을 통해 활성화할 수 있는 사용 가능한 베타 기능입니다. 베타 헤더를 참조하세요.
SlashCommand
사용 가능한 슬래시 명령에 대한 정보입니다.
ModelInfo
사용 가능한 모델에 대한 정보입니다.
AgentInfo
Agent 도구를 통해 호출할 수 있는 사용 가능한 서브에이전트에 대한 정보입니다.
| 필드 | 타입 | 설명 |
|---|---|---|
name | string | 에이전트 타입 식별자 (예: "Explore", "general-purpose") |
description | string | 이 에이전트를 사용할 시기에 대한 설명 |
model | string | undefined | 이 에이전트가 사용하는 모델 별칭입니다. 생략하면 부모의 모델을 상속합니다 |
McpServerStatus
연결된 MCP 서버의 상태입니다.
McpServerStatusConfig
mcpServerStatus()에서 보고한 MCP 서버의 구성입니다. 이는 모든 MCP 서버 전송 타입의 합집합입니다.
McpServerConfig를 참조하세요.
AccountInfo
인증된 사용자의 계정 정보입니다.
ModelUsage
결과 메시지에서 반환된 모델별 사용 통계입니다. costUSD 값은 클라이언트 측 추정입니다. 비용 및 사용량 추적에서 청구 주의 사항을 참조하세요.
ConfigScope
NonNullableUsage
모든 nullable 필드가 non-nullable로 만들어진 Usage의 버전입니다.
Usage
토큰 사용 통계입니다. 이는 @anthropic-ai/sdk의 BetaUsage 타입입니다.
BetaServerToolUsage와 BetaIterationsUsage는 @anthropic-ai/sdk에서 정의됩니다.
CallToolResult
MCP 도구 결과 타입 (@modelcontextprotocol/sdk/types.js에서). structuredContent는 content와 함께 반환될 수 있는 JSON 객체이며, 이미지 블록을 포함합니다. 구조화된 데이터 반환을 참조하세요.
ThinkingConfig
Claude의 사고/추론 동작을 제어합니다. 더 이상 사용되지 않는 maxThinkingTokens보다 우선합니다.
display 필드는 사고 텍스트가 "summarized" 또는 "omitted"로 반환되는지 제어합니다. Claude Opus 4.7 이상에서 API 기본값은 "omitted"이므로, thinking 블록에서 사고 콘텐츠를 받으려면 "summarized"를 설정하세요.
SpawnedProcess
사용자 정의 프로세스 생성을 위한 인터페이스 (spawnClaudeCodeProcess 옵션과 함께 사용). ChildProcess는 이미 이 인터페이스를 만족합니다.
SpawnOptions
사용자 정의 생성 함수에 전달된 옵션입니다.
signal 필드는 프로세스를 종료할 시기를 생성 함수에 알립니다. 이를 Node의 spawn()에 signal 옵션으로 전달하거나, VM 또는 컨테이너 종료 핸들러에 전달하세요.이 신호는 Options.abortController가 중단되는 순간 즉시 발생하지 않습니다. SDK는 먼저 프로세스의 stdin을 닫고 CLI가 깔끔하게 종료될 수 있도록 약 2초를 기다린 후, 이 신호를 중단합니다. 호출자가 중단되는 순간 즉시 반응하려면, 생성 함수가 인클로징 스코프에서 참조할 수 있는 자신의 Options.abortController.signal을 수신하세요.McpSetServersResult
setMcpServers() 작업의 결과입니다.
RewindFilesResult
rewindFiles() 작업의 결과입니다.
SDKStatusMessage
상태 업데이트 메시지 (예: 압축).
SDKTaskNotificationMessage
백그라운드 작업이 완료, 실패 또는 중지될 때의 알림입니다. 백그라운드 작업에는 run_in_background Bash 명령, Monitor 감시 및 백그라운드 서브에이전트가 포함됩니다.
SDKToolUseSummaryMessage
대화에서의 도구 사용 요약입니다.
SDKHookStartedMessage
훅이 실행을 시작할 때 내보내집니다.
SDKHookProgressMessage
훅이 실행 중일 때 stdout/stderr 출력과 함께 내보내집니다.
SDKHookResponseMessage
훅이 실행을 완료할 때 내보내집니다.
SDKToolProgressMessage
도구가 실행 중일 때 진행 상황을 나타내기 위해 주기적으로 내보내집니다.
SDKAuthStatusMessage
인증 흐름 중에 내보내집니다.
SDKTaskStartedMessage
백그라운드 작업이 시작될 때 내보내집니다. task_type 필드는 백그라운드 Bash 명령 및 Monitor 감시의 경우 "local_bash", 서브에이전트의 경우 "local_agent" 또는 "remote_agent"입니다.
SDKTaskProgressMessage
서브에이전트 또는 백그라운드 작업이 실행 중일 때 주기적으로 내보내집니다. summary 필드는 agentProgressSummaries가 활성화되었을 때만 채워집니다.
SDKTaskUpdatedMessage
백그라운드 작업의 상태가 변경될 때 내보내집니다. 예를 들어 running에서 completed로 전환될 때입니다. patch를 task_id로 키가 지정된 로컬 작업 맵에 병합합니다. end_time 필드는 Unix epoch 타임스탬프(밀리초)이며 Date.now()와 비교할 수 있습니다.
SDKFilesPersistedEvent
파일 체크포인트가 디스크에 지속될 때 내보내집니다.
SDKRateLimitEvent
세션이 속도 제한을 만날 때 내보내집니다.
SDKLocalCommandOutputMessage
로컬 슬래시 명령의 출력 (예: /voice 또는 /usage). 트랜스크립트에서 어시스턴트 스타일 텍스트로 표시됩니다.
SDKCommandsChangedMessage
사용 가능한 명령 집합이 세션 중간에 변경될 때 내보내집니다. 예를 들어 에이전트가 하위 디렉토리에 들어갈 때 스킬이 발견될 때입니다. commands 배열은 전체 업데이트된 목록이므로, 캐시된 명령 목록을 이 페이로드로 바꾸세요. supportedCommands()를 다시 호출하는 것은 동등하지 않습니다. 해당 메서드는 초기화 시 캡처된 스냅샷을 반환하며 세션 중간 변경을 반영하지 않습니다.
SDKPromptSuggestionMessage
promptSuggestions가 활성화되었을 때 각 턴 후에 내보내집니다. 예측된 다음 사용자 프롬프트를 포함합니다.
AbortError
중단 작업을 위한 사용자 정의 오류 클래스입니다.
샌드박스 구성
SandboxSettings
샌드박스 동작의 구성입니다. 이를 사용하여 명령 샌드박싱을 활성화하고 프로그래밍 방식으로 네트워크 제한을 구성합니다.
| 속성 | 타입 | 기본값 | 설명 |
|---|---|---|---|
enabled | boolean | false | 명령 실행을 위한 샌드박스 모드 활성화 |
failIfUnavailable | boolean | true | enabled가 true이지만 샌드박스를 시작할 수 없는 경우 시작 시 중지합니다. stderr에 경고와 함께 샌드박스되지 않은 실행으로 폴백하려면 false로 설정합니다 |
autoAllowBashIfSandboxed | boolean | true | 샌드박스가 활성화되었을 때 bash 명령 자동 승인 |
excludedCommands | string[] | [] | 항상 샌드박스 제한을 무시하는 명령 (예: ['docker']). 이들은 모델 개입 없이 자동으로 샌드박스되지 않은 상태로 실행됩니다 |
allowUnsandboxedCommands | boolean | true | 모델이 샌드박스 외부에서 명령을 실행하도록 요청하도록 허용합니다. true일 때 모델은 도구 입력에서 dangerouslyDisableSandbox를 설정할 수 있으며, 이는 권한 시스템으로 폴백됩니다 |
network | SandboxNetworkConfig | undefined | 네트워크 특정 샌드박스 구성 |
filesystem | SandboxFilesystemConfig | undefined | 읽기/쓰기 제한을 위한 파일 시스템 특정 샌드박스 구성 |
ignoreViolations | Record<string, string[]> | undefined | 무시할 위반 카테고리를 패턴에 매핑합니다 (예: { file: ['/tmp/*'], network: ['localhost'] }) |
enableWeakerNestedSandbox | boolean | false | 호환성을 위해 더 약한 중첩 샌드박스 활성화 |
ripgrep | { command: string; args?: string[] } | undefined | 샌드박스 환경을 위한 사용자 정의 ripgrep 바이너리 구성 |
샌드박스는 플랫폼 지원에 따라 다르며, Linux에서는
bubblewrap 및 socat과 같은 도구가 필요합니다. enabled가 true이고 샌드박스를 시작할 수 없는 경우 query()는 subtype: "error_during_execution"이 있는 result 메시지를 보고하고 errors에 이유를 표시한 후 중지합니다. query()가 메시지를 생성하기 전에 예외를 발생시킬 것으로 예상하는 대신 해당 subtype을 감시합니다.대신 샌드박스되지 않은 상태로 실행하려면 failIfUnavailable: false를 설정합니다.사용 예제
SandboxNetworkConfig
샌드박스 모드를 위한 네트워크 특정 구성입니다. 이러한 설정은 부모 SandboxSettings에서 enabled가 true일 때 샌드박스된 Bash 명령에 적용됩니다. 이들은 권한 규칙을 대신 사용하는 WebFetch 도구를 제한하지 않습니다.
| 속성 | 타입 | 기본값 | 설명 |
|---|---|---|---|
allowedDomains | string[] | [] | 샌드박스된 프로세스가 액세스할 수 있는 도메인 이름 |
deniedDomains | string[] | [] | 샌드박스된 프로세스가 액세스할 수 없는 도메인 이름입니다. allowedDomains보다 우선합니다 |
allowManagedDomainsOnly | boolean | false | 관리형 설정 전용입니다. 관리형 설정에서 설정되었을 때 관리형 설정의 allowedDomains 항목만 적용되며 사용자, 프로젝트 또는 로컬 설정의 항목은 무시됩니다. SDK 옵션을 통해 설정되었을 때는 효과가 없습니다 |
allowLocalBinding | boolean | false | 프로세스가 로컬 포트에 바인딩하도록 허용합니다 (예: 개발 서버의 경우) |
allowUnixSockets | string[] | [] | 프로세스가 액세스할 수 있는 Unix 소켓 경로 (예: Docker 소켓) |
allowAllUnixSockets | boolean | false | 모든 Unix 소켓에 대한 액세스 허용 |
httpProxyPort | number | undefined | 네트워크 요청을 위한 HTTP 프록시 포트 |
socksProxyPort | number | undefined | 네트워크 요청을 위한 SOCKS 프록시 포트 |
기본 제공 샌드박스 프록시는 요청된 호스트명을 기반으로
allowedDomains를 적용하며 TLS 트래픽을 종료하거나 검사하지 않으므로 도메인 프론팅과 같은 기술이 이를 우회할 수 있습니다. 자세한 내용은 샌드박싱 보안 제한 사항을 참조하고 TLS 종료 프록시 구성에 대해서는 안전한 배포를 참조합니다.SandboxFilesystemConfig
샌드박스 모드를 위한 파일 시스템 특정 구성입니다.
| 속성 | 타입 | 기본값 | 설명 |
|---|---|---|---|
allowWrite | string[] | [] | 쓰기 액세스를 허용할 파일 경로 패턴 |
denyWrite | string[] | [] | 쓰기 액세스를 거부할 파일 경로 패턴 |
denyRead | string[] | [] | 읽기 액세스를 거부할 파일 경로 패턴 |
샌드박스되지 않은 명령에 대한 권한 폴백
allowUnsandboxedCommands가 활성화되었을 때 모델은 도구 입력에서 dangerouslyDisableSandbox: true를 설정하여 샌드박스 외부에서 명령을 실행하도록 요청할 수 있습니다. 이러한 요청은 기존 권한 시스템으로 폴백되므로 canUseTool 핸들러가 호출되어 사용자 정의 인증 로직을 구현할 수 있습니다.
excludedCommands vs allowUnsandboxedCommands:excludedCommands: 항상 자동으로 샌드박스를 무시하는 명령의 정적 목록 (예:['docker']). 모델은 이에 대한 제어가 없습니다.allowUnsandboxedCommands: 모델이 도구 입력에서dangerouslyDisableSandbox: true를 설정하여 런타임에 샌드박스되지 않은 실행을 요청하도록 합니다.
- 모델 요청 감사: 모델이 샌드박스되지 않은 실행을 요청할 때 로그합니다
- 허용 목록 구현: 특정 명령만 샌드박스되지 않은 상태로 실행하도록 허용합니다
- 승인 워크플로우 추가: 권한 있는 작업에 대한 명시적 인증이 필요합니다
참고 항목
- SDK 개요 - 일반 SDK 개념
- Python SDK 참조 - Python SDK 문서
- CLI 참조 - 명령줄 인터페이스
- 일반적인 워크플로우 - 단계별 가이드