AskUserQuestion 도구를 통해)입니다. 둘 다 canUseTool 콜백을 트리거하며, 이는 응답을 반환할 때까지 실행을 일시 중지합니다. 이는 Claude가 완료되고 다음 메시지를 기다리는 일반적인 대화 턴과는 다릅니다.
명확화 질문의 경우 Claude가 질문과 옵션을 생성합니다. 사용자의 역할은 이를 사용자에게 제시하고 선택 사항을 반환하는 것입니다. 이 흐름에 자신의 질문을 추가할 수 없습니다. 사용자에게 직접 물어봐야 할 사항이 있으면 애플리케이션 로직에서 별도로 수행하십시오.
콜백은 무기한 대기 상태로 유지될 수 있습니다. 콜백이 반환될 때까지 실행이 일시 중지되며, SDK는 쿼리 자체가 취소될 때만 대기를 취소합니다. 사용자가 프로세스가 합리적으로 실행 상태를 유지할 수 있는 것보다 더 오래 응답하는 데 시간이 걸릴 수 있다면, defer 훅 결정을 반환하십시오. 이를 통해 프로세스를 종료하고 나중에 지속된 세션에서 재개할 수 있습니다.
이 가이드는 각 유형의 요청을 감지하고 적절하게 응답하는 방법을 보여줍니다.
Claude가 입력이 필요한 시점 감지
쿼리 옵션에canUseTool 콜백을 전달합니다. 콜백은 Claude가 사용자 입력이 필요할 때마다 실행되며, 도구 이름과 입력을 인수로 받습니다.
- 도구가 승인 필요: Claude가 권한 규칙 또는 모드에 의해 자동 승인되지 않은 도구를 사용하려고 합니다. 도구에 대해
tool_name을 확인합니다(예:"Bash","Write"). - Claude가 질문함: Claude가
AskUserQuestion도구를 호출합니다.tool_name == "AskUserQuestion"을 확인하여 다르게 처리합니다.tools배열을 지정하는 경우 이것이 작동하려면AskUserQuestion을 포함하십시오. 자세한 내용은 명확화 질문 처리를 참조하십시오.
사용자에게 프롬프트하지 않고 도구를 자동으로 허용하거나 거부하려면 훅을 대신 사용하십시오. 훅은
canUseTool 전에 실행되며 자신의 로직에 따라 요청을 허용, 거부 또는 수정할 수 있습니다. PermissionRequest 훅을 사용하여 Claude가 승인을 기다리고 있을 때 외부 알림(Slack, 이메일, 푸시)을 보낼 수도 있습니다.도구 승인 요청 처리
쿼리 옵션에canUseTool 콜백을 전달하면, Claude가 자동 승인되지 않은 도구를 사용하려고 할 때 실행됩니다. 콜백은 세 가지 인수를 받습니다.
| 인수 | 설명 |
|---|---|
toolName | Claude가 사용하려는 도구의 이름(예: "Bash", "Write", "Edit") |
input | Claude가 도구에 전달하는 매개변수입니다. 내용은 도구에 따라 다릅니다. |
options (TS) / context (Python) | 선택적 suggestions(재프롬프트를 피하기 위한 제안된 PermissionUpdate 항목)과 취소 신호를 포함한 추가 컨텍스트입니다. TypeScript에서 signal은 AbortSignal입니다. Python에서 신호 필드는 향후 사용을 위해 예약되어 있습니다. Python의 경우 ToolPermissionContext를 참조하십시오. |
input 객체에는 도구별 매개변수가 포함됩니다. 일반적인 예:
| 도구 | 입력 필드 |
|---|---|
Bash | command, description, timeout |
Write | file_path, content |
Edit | file_path, old_string, new_string |
Read | file_path, offset, limit |
Python에서
can_use_tool은 스트리밍 모드와 스트림을 열어 두기 위해 {"continue_": True}를 반환하는 PreToolUse 훅이 필요합니다. 이 훅이 없으면 권한 콜백이 호출되기 전에 스트림이 닫힙니다.y 이외의 모든 입력이 거부로 처리되는 y/n 흐름을 사용합니다. 실제로는 사용자가 요청을 수정하거나, 피드백을 제공하거나, Claude를 완전히 리디렉션할 수 있는 더 풍부한 UI를 구축할 수 있습니다. 응답할 수 있는 모든 방법은 도구 요청에 응답을 참조하십시오.
도구 요청에 응답
콜백은 두 가지 응답 유형 중 하나를 반환합니다.| 응답 | Python | TypeScript |
|---|---|---|
| 허용 | PermissionResultAllow(updated_input=...) | { behavior: "allow", updatedInput } |
| 거부 | PermissionResultDeny(message=...) | { behavior: "deny", message } |
- 승인: 도구가 Claude가 요청한 대로 실행되도록 허용
- 변경 사항과 함께 승인: 실행 전에 입력 수정(예: 경로 정제, 제약 조건 추가)
- 승인 및 기억: 제안된 권한 규칙을 다시 에코하여 일치하는 호출이 다음 번에 프롬프트를 건너뛰도록 함
- 거부: 도구를 차단하고 이유를 Claude에 알림
- 대안 제안: 차단하지만 사용자가 원하는 것으로 Claude를 안내
- 완전히 리디렉션: 스트리밍 입력을 사용하여 Claude에 완전히 새로운 지시를 보냄
- 승인
- 변경 사항과 함께 승인
- 승인 및 기억
- 거부
- 대안 제안
- 완전히 리디렉션
사용자가 작업을 그대로 승인합니다. 콜백에서
input을 변경하지 않고 전달하면 도구가 Claude가 요청한 대로 정확히 실행됩니다.명확화 질문 처리
Claude가 여러 유효한 접근 방식이 있는 작업에 대해 더 많은 방향이 필요할 때AskUserQuestion 도구를 호출합니다. 이는 toolName이 AskUserQuestion으로 설정된 canUseTool 콜백을 트리거합니다. 입력에는 Claude의 질문이 객관식 옵션으로 포함되어 있으며, 이를 사용자에게 표시하고 선택 사항을 반환합니다.
다음 단계는 명확화 질문을 처리하는 방법을 보여줍니다.
canUseTool 콜백 전달
쿼리 옵션에
canUseTool 콜백을 전달합니다. 기본적으로 AskUserQuestion을 사용할 수 있습니다. Claude의 기능을 제한하기 위해 tools 배열을 지정하는 경우(예: Read, Glob 및 Grep만 있는 읽기 전용 에이전트), 그 배열에 AskUserQuestion을 포함하십시오. 그렇지 않으면 Claude가 명확화 질문을 할 수 없습니다.질문 입력 구문 분석
입력에는 전체 필드 설명은 질문 형식을 참조하십시오.
questions 배열의 Claude 질문이 포함됩니다. 각 질문에는 question(표시할 텍스트), options(선택 사항) 및 multiSelect(여러 선택이 허용되는지 여부)가 있습니다.사용자로부터 답변 수집
사용자에게 질문을 제시하고 선택 사항을 수집합니다. 이를 수행하는 방법은 애플리케이션에 따라 다릅니다. 터미널 프롬프트, 웹 양식, 모바일 대화 상자 등입니다.
Claude에 답변 반환
answers 객체를 레코드로 구성합니다. 여기서 각 키는 question 텍스트이고 각 값은 선택된 옵션의 label입니다.| 질문 객체에서 | 다음으로 사용 |
|---|---|
question 필드(예: "How should I format the output?") | 키 |
선택된 옵션의 label 필드(예: "Summary") | 값 |
", "로 조인합니다. 자유 텍스트 입력을 지원하는 경우 사용자의 사용자 정의 텍스트를 값으로 사용합니다.질문 형식
입력에는questions 배열의 Claude 생성 질문이 포함됩니다. 각 질문에는 다음 필드가 있습니다.
| 필드 | 설명 |
|---|---|
question | 표시할 전체 질문 텍스트 |
header | 질문의 짧은 레이블(최대 12자) |
options | 각각 label 및 description이 있는 2-4개 선택 사항의 배열입니다. TypeScript: 선택적으로 preview(아래 참조) |
multiSelect | true인 경우 사용자가 여러 옵션을 선택할 수 있습니다. |
옵션 미리보기(TypeScript)
toolConfig.askUserQuestion.previewFormat은 각 옵션에 preview 필드를 추가하므로 앱이 레이블 옆에 시각적 목업을 표시할 수 있습니다. 이 설정이 없으면 Claude는 미리보기를 생성하지 않으며 필드가 없습니다.
previewFormat | preview 포함 |
|---|---|
| 설정되지 않음(기본값) | 필드가 없습니다. Claude는 미리보기를 생성하지 않습니다. |
"markdown" | ASCII 아트 및 펜스 코드 블록 |
"html" | 스타일이 지정된 <div> 조각(SDK는 콜백이 실행되기 전에 <script>, <style> 및 <!DOCTYPE>을 거부합니다.) |
preview를 포함하고 도움이 되지 않는 옵션(예/아니오 확인, 텍스트 전용 선택)에서 생략합니다. 렌더링하기 전에 undefined를 확인하십시오.
응답 형식
각 질문의question 필드를 선택된 옵션의 label에 매핑하는 answers 객체를 반환합니다.
| 필드 | 설명 |
|---|---|
questions | 원본 질문 배열을 전달합니다(도구 처리에 필수). |
answers | 키가 질문 텍스트이고 값이 선택된 레이블인 객체입니다. |
response | 선택적 자유형 회신으로 사용자가 구조화된 질문에 답하는 대신 입력한 내용입니다. |
", "로 조인합니다. “Other” 옵션과 같은 질문별 자유 텍스트의 경우 사용자의 텍스트를 자유 텍스트 입력 지원에 표시된 대로 answers[question]에 입력합니다. response는 사용자가 질문 카드를 닫고 특정 질문에 대한 답변이 아닌 일반적인 회신을 입력할 수 있는 UI가 있을 때만 설정합니다. response가 설정되면 Claude는 질문별 답변 목록 대신 “사용자가 응답했습니다: …”를 받습니다.
자유 텍스트 입력 지원
Claude의 사전 정의된 옵션이 항상 사용자가 원하는 것을 다루지는 않습니다. 사용자가 자신의 답변을 입력하도록 허용하려면:- Claude의 옵션 후에 추가 “Other” 선택을 표시하여 텍스트 입력을 허용합니다.
- 사용자의 사용자 정의 텍스트를 답변 값으로 사용합니다(“Other”라는 단어가 아님).
완전한 예제
Claude는 진행하기 위해 사용자 입력이 필요할 때 명확화 질문을 합니다. 예를 들어 모바일 앱의 기술 스택을 결정하는 데 도움을 달라는 요청을 받으면 Claude는 크로스 플랫폼 대 네이티브, 백엔드 선호도 또는 대상 플랫폼에 대해 물어볼 수 있습니다. 이러한 질문은 Claude가 추측하기보다는 사용자의 선호도와 일치하는 결정을 내리는 데 도움이 됩니다. 이 예제는 터미널 애플리케이션에서 이러한 질문을 처리합니다. 각 단계에서 발생하는 일은 다음과 같습니다.- 요청 라우팅:
canUseTool콜백은 도구 이름이"AskUserQuestion"인지 확인하고 전용 핸들러로 라우팅합니다. - 질문 표시: 핸들러는
questions배열을 반복하고 각 질문을 번호가 매겨진 옵션과 함께 인쇄합니다. - 입력 수집: 사용자는 숫자를 입력하여 옵션을 선택하거나 자유 텍스트를 직접 입력할 수 있습니다(예: “jquery”, “i don’t know”).
- 답변 매핑: 코드는 입력이 숫자(옵션의 레이블 사용)인지 자유 텍스트(텍스트 직접 사용)인지 확인합니다.
- Claude에 반환: 응답에는 원본
questions배열과answers매핑이 모두 포함됩니다.
제한 사항
- 서브에이전트:
AskUserQuestion은 현재 Agent 도구를 통해 생성된 서브에이전트에서 사용할 수 없습니다. - 질문 제한: 각
AskUserQuestion호출은 각각 2-4개 옵션이 있는 1-4개 질문을 지원합니다.
사용자 입력을 얻는 다른 방법
canUseTool 콜백과 AskUserQuestion 도구는 대부분의 승인 및 명확화 시나리오를 다루지만, SDK는 사용자로부터 입력을 얻는 다른 방법을 제공합니다.
스트리밍 입력
다음이 필요할 때 스트리밍 입력을 사용하십시오.- 에이전트 중간에 중단: Claude가 작업 중일 때 취소 신호를 보내거나 방향을 변경합니다.
- 추가 컨텍스트 제공: Claude가 물어볼 때까지 기다리지 않고 필요한 정보를 추가합니다.
- 채팅 인터페이스 구축: 장시간 실행되는 작업 중에 사용자가 후속 메시지를 보낼 수 있습니다.
사용자 정의 도구
다음이 필요할 때 사용자 정의 도구를 사용하십시오.- 구조화된 입력 수집:
AskUserQuestion의 객관식 형식을 넘어서는 양식, 마법사 또는 다단계 워크플로우를 구축합니다. - 외부 승인 시스템 통합: 기존 티켓팅, 워크플로우 또는 승인 플랫폼에 연결합니다.
- 도메인별 상호 작용 구현: 코드 검토 인터페이스 또는 배포 체크리스트와 같이 애플리케이션의 필요에 맞는 도구를 만듭니다.
canUseTool 콜백을 사용하는 것보다 더 많은 구현 작업이 필요합니다.
관련 리소스
- 권한 구성: 권한 모드 및 규칙 설정
- 훅으로 실행 제어: 에이전트 수명 주기의 주요 지점에서 사용자 정의 코드 실행
- TypeScript SDK 참조: 전체 canUseTool API 문서