OpenClaw은 그룹 채팅을 여러 표면에서 일관되게 처리합니다: Discord, iMessage, Matrix, Microsoft Teams, Signal, Slack, Telegram, WhatsApp, Zalo.Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
초보자 소개(2분)
OpenClaw은 사용자의 자체 메시징 계정에 “상주”합니다. 별도의 WhatsApp 봇 사용자는 없습니다. 사용자가 그룹에 있으면 OpenClaw은 해당 그룹을 볼 수 있고 그곳에서 응답할 수 있습니다. 기본 동작:- 그룹은 제한됩니다(
groupPolicy: "allowlist"). - 멘션 게이팅을 명시적으로 비활성화하지 않는 한, 응답에는 멘션이 필요합니다.
- 그룹/채널의 일반 최종 응답은 기본적으로 비공개입니다. 표시되는 방 출력은
message도구를 사용합니다.
요약
- DM 액세스는
*.allowFrom으로 제어됩니다. - 그룹 액세스는
*.groupPolicy+ 허용 목록(*.groups,*.groupAllowFrom)으로 제어됩니다. - 응답 트리거는 멘션 게이팅(
requireMention,/activation)으로 제어됩니다.
표시되는 응답
그룹/채널 방의 경우 OpenClaw은 기본적으로messages.groupChat.visibleReplies: "message_tool"을 사용합니다.
openclaw doctor --fix는 이를 생략한 구성된 채널 설정에 이 기본값을 씁니다.
즉, 에이전트는 여전히 턴을 처리하고 메모리/세션 상태를 업데이트할 수 있지만, 일반 최종 답변은 방에 자동으로 다시 게시되지 않습니다. 표시되게 말하려면 에이전트가 message(action=send)를 사용합니다.
이 기본값은 도구를 안정적으로 호출하는 모델/런타임에 의존합니다. 로그에
어시스턴트 텍스트가 표시되지만 didSendViaMessagingTool: false이면, 모델이
메시지 도구를 호출하는 대신 비공개로 응답한 것입니다. 이는
Discord/Slack/Telegram 전송 실패가 아닙니다. 그룹/채널 세션에는
도구 호출이 안정적인 모델을 사용하거나, 레거시의 표시되는
최종 응답을 복원하려면
messages.groupChat.visibleReplies: "automatic"을 설정하세요.
활성 도구 정책에서 메시지 도구를 사용할 수 없는 경우, OpenClaw은 응답을 조용히 억제하지 않고
자동 표시 응답으로 폴백합니다.
openclaw doctor는 이 불일치에 대해 경고합니다.
직접 채팅 및 기타 모든 소스 턴에는 동일한 도구 전용 표시 응답 동작을 전역으로 적용하려면 messages.visibleReplies: "message_tool"을 사용하세요. 하네스도 이를 설정되지 않은 기본값으로 선택할 수 있습니다. Codex 하네스는 Codex 모드 직접 채팅에 대해 이렇게 합니다. messages.groupChat.visibleReplies는 그룹/채널 방에 대한 더 구체적인 재정의로 유지됩니다.
이는 대부분의 대기 모드 턴에서 모델이 NO_REPLY로 답하도록 강제하던 이전 패턴을 대체합니다. 도구 전용 모드에서 표시되는 동작을 하지 않는다는 것은 단순히 메시지 도구를 호출하지 않는다는 뜻입니다.
에이전트가 도구 전용 모드에서 작업하는 동안에도 입력 표시기는 계속 전송됩니다. 이러한 턴에서는 에이전트가 메시지 도구를 호출할지 결정하기 전에 일반 어시스턴트 메시지 텍스트가 전혀 없을 수 있으므로 기본 그룹 입력 모드는 “message”에서 “instant”로 업그레이드됩니다. 명시적인 입력 모드 설정은 여전히 우선합니다.
그룹/채널 방에 대해 레거시 자동 최종 응답을 복원하려면:
messages 설정을 핫 리로드합니다. 배포에서 파일 감시 또는 설정 리로드가 비활성화된 경우에만
다시 시작하세요.
모든 소스 채팅에서 표시되는 출력을 메시지 도구를 통해서만 내보내도록 요구하려면:
visibleReplies: "message_tool"을 우회하며, 채널 네이티브 명령 UI가 기대하는 응답을 받을 수 있도록 항상 표시되게 답합니다. 이는 검증된 네이티브 명령 턴에만 적용됩니다. 텍스트로 입력된 /... 명령과 일반 채팅 턴은 여전히 구성된 그룹 기본값을 따릅니다.
컨텍스트 가시성 및 허용 목록
그룹 안전에는 두 가지 서로 다른 제어가 관련됩니다.- 트리거 권한 부여: 누가 에이전트를 트리거할 수 있는지(
groupPolicy,groups,groupAllowFrom, 채널별 허용 목록). - 컨텍스트 가시성: 어떤 보조 컨텍스트가 모델에 주입되는지(답장 텍스트, 인용, 스레드 기록, 전달된 메타데이터).
현재 동작은 채널별로 다릅니다
현재 동작은 채널별로 다릅니다
- 일부 채널은 이미 특정 경로에서 보조 컨텍스트에 대해 발신자 기반 필터링을 적용합니다(예: Slack 스레드 시딩, Matrix 답장/스레드 조회).
- 다른 채널은 여전히 인용/답장/전달 컨텍스트를 받은 그대로 전달합니다.
강화 방향(계획됨)
강화 방향(계획됨)
contextVisibility: "all"(기본값)은 현재의 받은 그대로 동작을 유지합니다.contextVisibility: "allowlist"는 보조 컨텍스트를 허용 목록에 있는 발신자로 필터링합니다.contextVisibility: "allowlist_quote"는allowlist에 명시적인 인용/답장 예외 하나를 더한 것입니다.
| 목표 | 설정할 항목 |
|---|---|
| 모든 그룹을 허용하되 @멘션에만 응답 | groups: { "*": { requireMention: true } } |
| 모든 그룹 응답 비활성화 | groupPolicy: "disabled" |
| 특정 그룹만 | groups: { "<group-id>": { ... } } ("*" 키 없음) |
| 그룹에서 사용자만 트리거 가능 | groupPolicy: "allowlist", groupAllowFrom: ["+1555..."] |
| 채널 간에 신뢰할 수 있는 발신자 집합 하나 재사용 | groupAllowFrom: ["accessGroup:operators"] |
세션 키
- 그룹 세션은
agent:<agentId>:<channel>:group:<id>세션 키를 사용합니다(방/채널은agent:<agentId>:<channel>:channel:<id>사용). - Telegram 포럼 주제는 각 주제에 자체 세션이 있도록 그룹 ID에
:topic:<threadId>를 추가합니다. - 직접 채팅은 기본 세션(또는 구성된 경우 발신자별 세션)을 사용합니다.
- 그룹 세션에서는 Heartbeat를 건너뜁니다.
패턴: 개인 DM + 공개 그룹(단일 에이전트)
예. “개인” 트래픽이 DM이고 “공개” 트래픽이 그룹이라면 잘 작동합니다. 이유: 단일 에이전트 모드에서 DM은 일반적으로 기본 세션 키(agent:main:main)에 도착하는 반면, 그룹은 항상 비기본 세션 키(agent:main:<channel>:group:<id>)를 사용합니다. mode: "non-main"으로 샌드박싱을 활성화하면, 해당 그룹 세션은 구성된 샌드박스 백엔드에서 실행되고 기본 DM 세션은 호스트에 유지됩니다. 백엔드를 선택하지 않으면 Docker가 기본 백엔드입니다.
이를 통해 하나의 에이전트 “두뇌”(공유 워크스페이스 + 메모리)를 사용하면서 두 가지 실행 태세를 가질 수 있습니다.
- DM: 전체 도구(호스트)
- 그룹: 샌드박스 + 제한된 도구
진정으로 분리된 워크스페이스/페르소나(“개인”과 “공개”가 절대 섞이면 안 됨)가 필요하다면 두 번째 에이전트 + 바인딩을 사용하세요. Multi-Agent Routing을 참조하세요.
- 호스트의 DM, 샌드박스된 그룹
- 그룹은 허용 목록에 있는 폴더만 봅니다
- 설정 키와 기본값: Gateway 설정
- 도구가 차단된 이유 디버깅: 샌드박스 vs 도구 정책 vs 상승 권한
- 바인드 마운트 세부 정보: 샌드박싱
표시 레이블
- UI 레이블은 사용 가능한 경우
displayName을 사용하며,<channel>:<token>형식입니다. #room은 방/채널용으로 예약되어 있습니다. 그룹 채팅은g-<slug>를 사용합니다(소문자, 공백 ->-,#@+._-유지).
그룹 정책
채널별로 그룹/방 메시지가 처리되는 방식을 제어합니다.| 정책 | 동작 |
|---|---|
"open" | 그룹이 허용 목록을 우회합니다. 멘션 게이팅은 계속 적용됩니다. |
"disabled" | 모든 그룹 메시지를 완전히 차단합니다. |
"allowlist" | 구성된 허용 목록과 일치하는 그룹/방만 허용합니다. |
채널별 참고 사항
채널별 참고 사항
groupPolicy는 멘션 게이팅(@mentions 필요)과 별개입니다.- WhatsApp/Telegram/Signal/iMessage/Microsoft Teams/Zalo:
groupAllowFrom을 사용하세요(대체: 명시적allowFrom). - Signal:
groupAllowFrom은 수신 Signal 그룹 ID 또는 발신자 전화번호/UUID와 일치할 수 있습니다. - DM 페어링 승인(
*-allowFrom저장소 항목)은 DM 접근에만 적용됩니다. 그룹 발신자 권한 부여는 그룹 허용 목록에 명시적으로 유지됩니다. - Discord: 허용 목록은
channels.discord.guilds.<id>.channels를 사용합니다. - Slack: 허용 목록은
channels.slack.channels를 사용합니다. - Matrix: 허용 목록은
channels.matrix.groups를 사용합니다. 방 ID 또는 별칭을 권장합니다. 참여한 방 이름 조회는 최선 노력 방식이며, 확인되지 않은 이름은 런타임에 무시됩니다. 발신자를 제한하려면channels.matrix.groupAllowFrom을 사용하세요. 방별users허용 목록도 지원됩니다. - 그룹 DM은 별도로 제어됩니다(
channels.discord.dm.*,channels.slack.dm.*). - Telegram 허용 목록은 사용자 ID(
"123456789","telegram:123456789","tg:123456789") 또는 사용자 이름("@alice"또는"alice")과 일치할 수 있습니다. 접두사는 대소문자를 구분하지 않습니다. - 기본값은
groupPolicy: "allowlist"입니다. 그룹 허용 목록이 비어 있으면 그룹 메시지가 차단됩니다. - 런타임 안전성: 제공자 블록이 완전히 누락된 경우(
channels.<provider>없음), 그룹 정책은channels.defaults.groupPolicy를 상속하는 대신 실패 시 닫힘 모드(일반적으로allowlist)로 대체됩니다.
멘션 게이팅(기본값)
그룹 메시지는 그룹별로 재정의하지 않는 한 멘션이 필요합니다. 기본값은*.groups."*" 아래의 각 하위 시스템별로 있습니다.
채널이 답장 메타데이터를 지원하는 경우 봇 메시지에 답장하면 암시적 멘션으로 간주됩니다. 인용 메타데이터를 노출하는 채널에서는 봇 메시지를 인용하는 것도 암시적 멘션으로 간주될 수 있습니다. 현재 기본 제공 사례에는 Telegram, WhatsApp, Slack, Discord, Microsoft Teams, ZaloUser가 포함됩니다.
멘션 게이팅 참고 사항
멘션 게이팅 참고 사항
mentionPatterns는 대소문자를 구분하지 않는 안전한 정규식 패턴입니다. 잘못된 패턴과 안전하지 않은 중첩 반복 형태는 무시됩니다.- 명시적 멘션을 제공하는 표면은 계속 통과합니다. 패턴은 대체 수단입니다.
- 에이전트별 재정의:
agents.list[].groupChat.mentionPatterns(여러 에이전트가 그룹을 공유할 때 유용). - 멘션 게이팅은 멘션 감지가 가능한 경우에만 적용됩니다(네이티브 멘션 또는
mentionPatterns가 구성된 경우). - 그룹이나 발신자를 허용 목록에 추가해도 멘션 게이팅이 비활성화되지 않습니다. 모든 메시지가 트리거되어야 하는 경우 해당 그룹의
requireMention을false로 설정하세요. - 그룹 채팅 프롬프트 컨텍스트는 매 턴마다 해석된 무음 답장 지침을 전달합니다. 작업 영역 파일은
NO_REPLY메커니즘을 중복해서는 안 됩니다. - 무음 답장이 허용된 그룹은 깨끗한 빈 모델 턴이나 추론만 있는 모델 턴을
NO_REPLY와 동등한 무음으로 처리합니다. 직접 채팅은 직접 무음 답장이 명시적으로 허용된 경우에만 동일하게 동작합니다. 그렇지 않으면 빈 답장은 실패한 에이전트 턴으로 남습니다. - Discord 기본값은
channels.discord.guilds."*"에 있습니다(길드/채널별 재정의 가능). - 그룹 기록 컨텍스트는 채널 전반에서 일관되게 래핑됩니다. 멘션 게이팅된 그룹은 보류 중인 건너뛴 메시지를 유지합니다. 항상 켜진 그룹도 채널이 지원하는 경우 최근 처리된 방 메시지를 유지할 수 있습니다. 전역 기본값에는
messages.groupChat.historyLimit를 사용하고, 재정의에는channels.<channel>.historyLimit(또는channels.<channel>.accounts.*.historyLimit)를 사용하세요. 비활성화하려면0으로 설정하세요.
그룹/채널 도구 제한(선택 사항)
일부 채널 구성은 특정 그룹/방/채널 내부에서 사용할 수 있는 도구를 제한하는 기능을 지원합니다.tools: 전체 그룹에 대한 도구를 허용/거부합니다.toolsBySender: 그룹 내 발신자별 재정의입니다. 명시적 키 접두사를 사용하세요:channel:<channelId>:<senderId>,id:<senderId>,e164:<phone>,username:<handle>,name:<displayName>, 그리고"*"와일드카드. 채널 ID는 표준 OpenClaw 채널 ID를 사용합니다.teams같은 별칭은msteams로 정규화됩니다. 레거시 무접두사 키는 여전히 허용되며id:로만 일치합니다.
예시(Telegram):
그룹/채널 도구 제한은 전역/에이전트 도구 정책에 추가로 적용됩니다(거부가 여전히 우선). 일부 채널은 방/채널에 다른 중첩 구조를 사용합니다(예: Discord
guilds.*.channels.*, Slack channels.*, Microsoft Teams teams.*.channels.*).그룹 허용 목록
channels.whatsapp.groups, channels.telegram.groups 또는 channels.imessage.groups가 구성된 경우, 키는 그룹 허용 목록으로 동작합니다. 기본 멘션 동작을 설정하면서 모든 그룹을 허용하려면 "*"를 사용하세요.
일반적인 의도(복사/붙여넣기):
- 모든 그룹 답장 비활성화
- 특정 그룹만 허용(WhatsApp)
- 모든 그룹을 허용하되 멘션 요구
- 소유자 전용 트리거(WhatsApp)
활성화(소유자 전용)
그룹 소유자는 그룹별 활성화를 전환할 수 있습니다./activation mention/activation always
channels.whatsapp.allowFrom으로 결정됩니다(설정되지 않은 경우 봇의 자체 E.164). 명령을 독립된 메시지로 보내세요. 다른 표면은 현재 /activation을 무시합니다.
컨텍스트 필드
그룹 수신 페이로드는 다음을 설정합니다.ChatType=groupGroupSubject(알려진 경우)GroupMembers(알려진 경우)WasMentioned(멘션 게이팅 결과)- Telegram 포럼 주제에는
MessageThreadId와IsForum도 포함됩니다.
\n 시퀀스를 입력하지 않도록 상기시킵니다. 채널에서 가져온 그룹 이름과 참가자 레이블은 인라인 시스템 지침이 아니라 신뢰할 수 없는 펜스 처리된 메타데이터로 렌더링됩니다.
iMessage 세부 사항
- 라우팅하거나 허용 목록에 추가할 때
chat_id:<id>를 권장합니다. - 채팅 목록 보기:
imsg chats --limit 20. - 그룹 답장은 항상 같은
chat_id로 돌아갑니다.