BlueBubbles (macOS REST)
상태: HTTP를 통해 BlueBubbles macOS 서버와 통신하는 번들 plugin입니다. 기존 imsg 채널보다 API가 더 풍부하고 설정이 더 쉬우므로 iMessage 통합에 권장됩니다.번들 plugin
현재 OpenClaw 릴리스에는 BlueBubbles가 번들로 포함되어 있으므로, 일반적인 패키지 빌드에서는 별도의openclaw plugins install 단계가 필요하지 않습니다.
개요
- BlueBubbles helper 앱(bluebubbles.app)을 통해 macOS에서 실행됩니다.
- 권장/테스트 환경: macOS Sequoia (15). macOS Tahoe (26)에서도 작동하지만, 현재 Tahoe에서는 편집 기능이 깨져 있으며 그룹 아이콘 업데이트는 성공으로 표시되더라도 동기화되지 않을 수 있습니다.
- OpenClaw는 REST API(
GET /api/v1/ping,POST /message/text,POST /chat/:id/*)를 통해 통신합니다. - 수신 메시지는 웹훅으로 도착하며, 발신 답장, 타이핑 표시기, 읽음 확인, 탭백은 REST 호출로 처리됩니다.
- 첨부파일과 스티커는 수신 미디어로 수집되며(가능한 경우 에이전트에 표시됨).
- 페어링/허용 목록은 다른 채널과 동일한 방식으로 작동하며(
/channels/pairing등),channels.bluebubbles.allowFrom+ 페어링 코드를 사용합니다. - 반응은 Slack/Telegram과 마찬가지로 시스템 이벤트로 표시되므로, 에이전트는 답장 전에 이를 “언급”할 수 있습니다.
- 고급 기능: 편집, 전송 취소, 답장 스레딩, 메시지 효과, 그룹 관리.
빠른 시작
- Mac에 BlueBubbles 서버를 설치합니다(bluebubbles.app/install의 안내를 따르세요).
- BlueBubbles 설정에서 웹 API를 활성화하고 비밀번호를 설정합니다.
-
openclaw onboard를 실행하고 BlueBubbles를 선택하거나, 수동으로 구성합니다: -
BlueBubbles 웹훅이 게이트웨이를 가리키도록 설정합니다(예:
https://your-gateway-host:3000/bluebubbles-webhook?password=<password>). - 게이트웨이를 시작하면 웹훅 핸들러를 등록하고 페어링을 시작합니다.
- 항상 웹훅 비밀번호를 설정하세요.
- 웹훅 인증은 항상 필요합니다. OpenClaw는 루프백/프록시 토폴로지와 관계없이
channels.bluebubbles.password와 일치하는 비밀번호/guid를 포함하지 않는 BlueBubbles 웹훅 요청을 거부합니다(예:?password=<password>또는x-password). - 비밀번호 인증은 전체 웹훅 본문을 읽거나 파싱하기 전에 검사됩니다.
Messages.app 활성 상태 유지하기(VM / 헤드리스 설정)
일부 macOS VM / 상시 실행 설정에서는 Messages.app이 “유휴” 상태가 되어(앱을 열거나 포그라운드로 가져올 때까지 수신 이벤트가 중지됨) 문제가 생길 수 있습니다. 간단한 해결 방법은 AppleScript + LaunchAgent를 사용해 5분마다 Messages를 건드리는 것입니다.1) AppleScript 저장
다음 경로에 저장하세요:~/Scripts/poke-messages.scpt
2) LaunchAgent 설치
다음 경로에 저장하세요:~/Library/LaunchAgents/com.user.poke-messages.plist
- 이는 300초마다 그리고 로그인 시 실행됩니다.
- 첫 실행 시 macOS Automation 프롬프트(
osascript→ Messages)가 나타날 수 있습니다. LaunchAgent를 실행하는 동일한 사용자 세션에서 이를 승인하세요.
온보딩
BlueBubbles는 대화형 온보딩에서 사용할 수 있습니다:- Server URL (필수): BlueBubbles 서버 주소(예:
http://192.168.1.100:1234) - Password (필수): BlueBubbles Server 설정의 API 비밀번호
- Webhook path (선택 사항): 기본값은
/bluebubbles-webhook - DM policy: pairing, allowlist, open, 또는 disabled
- Allow list: 전화번호, 이메일 또는 채팅 대상
접근 제어(DM + 그룹)
DM:- 기본값:
channels.bluebubbles.dmPolicy = "pairing". - 알 수 없는 발신자에게는 페어링 코드가 전송되며, 승인될 때까지 메시지는 무시됩니다(코드는 1시간 후 만료).
- 다음으로 승인:
openclaw pairing list bluebubblesopenclaw pairing approve bluebubbles <CODE>
- 페어링이 기본 토큰 교환 방식입니다. 자세한 내용: 페어링
channels.bluebubbles.groupPolicy = open | allowlist | disabled(기본값:allowlist).channels.bluebubbles.groupAllowFrom은allowlist가 설정된 경우 그룹에서 누가 트리거할 수 있는지 제어합니다.
연락처 이름 보강(macOS, 선택 사항)
BlueBubbles 그룹 웹훅은 종종 원시 참가자 주소만 포함합니다. 대신GroupMembers 컨텍스트에 로컬 연락처 이름이 표시되도록 하려면 macOS에서 로컬 연락처 보강을 선택적으로 활성화할 수 있습니다:
channels.bluebubbles.enrichGroupParticipantsFromContacts = true는 조회를 활성화합니다. 기본값:false.- 조회는 그룹 접근, 명령 권한 부여, 멘션 게이팅이 모두 메시지 통과를 허용한 후에만 실행됩니다.
- 이름이 없는 전화 참가자만 보강됩니다.
- 로컬 일치 항목을 찾지 못하면 원시 전화번호가 대체값으로 유지됩니다.
멘션 게이팅(그룹)
BlueBubbles는 그룹 채팅에서 멘션 게이팅을 지원하며, iMessage/WhatsApp 동작과 일치합니다:- 멘션 감지에는
agents.list[].groupChat.mentionPatterns(또는messages.groupChat.mentionPatterns)를 사용합니다. - 그룹에 대해
requireMention이 활성화되면, 에이전트는 멘션되었을 때만 응답합니다. - 권한 있는 발신자의 제어 명령은 멘션 게이팅을 우회합니다.
명령 게이팅
- 제어 명령(예:
/config,/model)에는 권한 부여가 필요합니다. - 명령 권한 부여를 결정하는 데
allowFrom과groupAllowFrom을 사용합니다. - 권한 있는 발신자는 그룹에서 멘션 없이도 제어 명령을 실행할 수 있습니다.
ACP 대화 바인딩
BlueBubbles 채팅은 전송 계층을 변경하지 않고도 영속적인 ACP 워크스페이스로 전환할 수 있습니다. 빠른 운영자 흐름:- DM 또는 허용된 그룹 채팅 안에서
/acp spawn codex --bind here를 실행합니다. - 이후 같은 BlueBubbles 대화의 메시지는 생성된 ACP 세션으로 라우팅됩니다.
/new와/reset은 같은 바인딩된 ACP 세션을 그 자리에서 재설정합니다./acp close는 ACP 세션을 닫고 바인딩을 제거합니다.
bindings[] 항목에서 type: "acp" 및 match.channel: "bluebubbles"를 통해 지원됩니다.
match.peer.id는 지원되는 모든 BlueBubbles 대상 형식을 사용할 수 있습니다:
+15555550123또는user@example.com같은 정규화된 DM 핸들chat_id:<id>chat_guid:<guid>chat_identifier:<identifier>
chat_id:* 또는 chat_identifier:*를 권장합니다.
예시:
타이핑 + 읽음 확인
- 타이핑 표시기: 응답 생성 전과 생성 중에 자동으로 전송됩니다.
- 읽음 확인:
channels.bluebubbles.sendReadReceipts로 제어됩니다(기본값:true). - 타이핑 표시기: OpenClaw는 타이핑 시작 이벤트를 전송하며, BlueBubbles는 전송 또는 타임아웃 시 자동으로 타이핑을 해제합니다(DELETE를 통한 수동 중지는 신뢰할 수 없음).
고급 작업
BlueBubbles는 구성에서 활성화하면 고급 메시지 작업을 지원합니다:- react: 탭백 반응 추가/제거 (
messageId,emoji,remove) - edit: 보낸 메시지 편집 (
messageId,text) - unsend: 메시지 전송 취소 (
messageId) - reply: 특정 메시지에 답장 (
messageId,text,to) - sendWithEffect: iMessage 효과와 함께 전송 (
text,to,effectId) - renameGroup: 그룹 채팅 이름 변경 (
chatGuid,displayName) - setGroupIcon: 그룹 채팅의 아이콘/사진 설정 (
chatGuid,media) — macOS 26 Tahoe에서 불안정(API가 성공을 반환해도 아이콘이 동기화되지 않을 수 있음). - addParticipant: 그룹에 사용자 추가 (
chatGuid,address) - removeParticipant: 그룹에서 사용자 제거 (
chatGuid,address) - leaveGroup: 그룹 채팅 나가기 (
chatGuid) - upload-file: 미디어/파일 전송 (
to,buffer,filename,asVoice)- 음성 메모: MP3 또는 CAF 오디오와 함께
asVoice: true를 설정하면 iMessage 음성 메시지로 전송됩니다. BlueBubbles는 음성 메모 전송 시 MP3 → CAF로 변환합니다.
- 음성 메모: MP3 또는 CAF 오디오와 함께
- 레거시 별칭:
sendAttachment도 계속 작동하지만, 정식 작업 이름은upload-file입니다.
메시지 ID(짧은 형식 vs 전체 형식)
OpenClaw는 토큰 절약을 위해 짧은 메시지 ID(예:1, 2)를 표시할 수 있습니다.
MessageSid/ReplyToId는 짧은 ID일 수 있습니다.MessageSidFull/ReplyToIdFull에는 provider의 전체 ID가 들어 있습니다.- 짧은 ID는 메모리 내 값이며, 재시작 또는 캐시 제거 시 만료될 수 있습니다.
- 작업은 짧은
messageId와 전체messageId를 모두 허용하지만, 더 이상 사용할 수 없는 짧은 ID는 오류가 발생합니다.
- 템플릿:
{{MessageSidFull}},{{ReplyToIdFull}} - 컨텍스트: 수신 페이로드의
MessageSidFull/ReplyToIdFull
블록 스트리밍
응답을 단일 메시지로 보낼지 블록 단위로 스트리밍할지 제어합니다:미디어 + 제한
- 수신 첨부파일은 다운로드되어 미디어 캐시에 저장됩니다.
- 수신 및 발신 미디어의 용량 제한은
channels.bluebubbles.mediaMaxMb로 제어합니다(기본값: 8 MB). - 발신 텍스트는
channels.bluebubbles.textChunkLimit까지 청크로 분할됩니다(기본값: 4000자).
구성 참조
전체 구성: 구성 Provider 옵션:channels.bluebubbles.enabled: 채널 활성화/비활성화.channels.bluebubbles.serverUrl: BlueBubbles REST API 기본 URL.channels.bluebubbles.password: API 비밀번호.channels.bluebubbles.webhookPath: 웹훅 엔드포인트 경로(기본값:/bluebubbles-webhook).channels.bluebubbles.dmPolicy:pairing | allowlist | open | disabled(기본값:pairing).channels.bluebubbles.allowFrom: DM 허용 목록(핸들, 이메일, E.164 번호,chat_id:*,chat_guid:*).channels.bluebubbles.groupPolicy:open | allowlist | disabled(기본값:allowlist).channels.bluebubbles.groupAllowFrom: 그룹 발신자 허용 목록.channels.bluebubbles.enrichGroupParticipantsFromContacts: macOS에서 게이팅 통과 후 이름 없는 그룹 참가자를 로컬 연락처로부터 선택적으로 보강합니다. 기본값:false.channels.bluebubbles.groups: 그룹별 구성(requireMention등).channels.bluebubbles.sendReadReceipts: 읽음 확인 전송(기본값:true).channels.bluebubbles.blockStreaming: 블록 스트리밍 활성화(기본값:false; 스트리밍 답장에 필요).channels.bluebubbles.textChunkLimit: 발신 청크 크기(문자 수, 기본값: 4000).channels.bluebubbles.chunkMode:length(기본값)는textChunkLimit를 초과할 때만 분할합니다.newline은 길이 기준 분할 전에 빈 줄(문단 경계)에서 분할합니다.channels.bluebubbles.mediaMaxMb: 수신/발신 미디어 용량 제한(MB, 기본값: 8).channels.bluebubbles.mediaLocalRoots: 발신 로컬 미디어 경로에 허용되는 절대 로컬 디렉터리의 명시적 허용 목록. 이를 구성하지 않으면 로컬 경로 전송은 기본적으로 거부됩니다. 계정별 재정의:channels.bluebubbles.accounts.<accountId>.mediaLocalRoots.channels.bluebubbles.historyLimit: 컨텍스트용 최대 그룹 메시지 수(0이면 비활성화).channels.bluebubbles.dmHistoryLimit: DM 기록 제한.channels.bluebubbles.actions: 특정 작업 활성화/비활성화.channels.bluebubbles.accounts: 다중 계정 구성.
agents.list[].groupChat.mentionPatterns(또는messages.groupChat.mentionPatterns).messages.responsePrefix.
주소 지정 / 전달 대상
안정적인 라우팅에는chat_guid를 권장합니다:
chat_guid:iMessage;-;+15555550123(그룹에 권장)chat_id:123chat_identifier:...- 직접 핸들:
+15555550123,user@example.com- 직접 핸들에 기존 DM 채팅이 없으면 OpenClaw가
POST /api/v1/chat/new를 통해 새로 생성합니다. 이 기능을 사용하려면 BlueBubbles Private API가 활성화되어 있어야 합니다.
- 직접 핸들에 기존 DM 채팅이 없으면 OpenClaw가
보안
- 웹훅 요청은
guid/password쿼리 매개변수 또는 헤더를channels.bluebubbles.password와 비교하여 인증됩니다. - API 비밀번호와 웹훅 엔드포인트는 비밀로 유지하세요(자격 증명처럼 취급하세요).
- BlueBubbles 웹훅 인증에는 localhost 우회가 없습니다. 웹훅 트래픽을 프록시하는 경우 요청 전 구간에 걸쳐 BlueBubbles 비밀번호를 유지하세요. 여기서
gateway.trustedProxies는channels.bluebubbles.password를 대체하지 않습니다. 게이트웨이 보안을 참조하세요. - LAN 외부에 노출하는 경우 BlueBubbles 서버에서 HTTPS + 방화벽 규칙을 활성화하세요.
문제 해결
- 타이핑/읽음 이벤트가 더 이상 작동하지 않으면 BlueBubbles 웹훅 로그를 확인하고 게이트웨이 경로가
channels.bluebubbles.webhookPath와 일치하는지 검증하세요. - 페어링 코드는 1시간 후 만료됩니다.
openclaw pairing list bluebubbles및openclaw pairing approve bluebubbles <code>를 사용하세요. - 반응 기능에는 BlueBubbles private API(
POST /api/v1/message/react)가 필요합니다. 서버 버전이 이를 노출하는지 확인하세요. - 편집/전송 취소는 macOS 13+ 및 호환되는 BlueBubbles 서버 버전이 필요합니다. macOS 26(Tahoe)에서는 private API 변경으로 인해 현재 편집 기능이 깨져 있습니다.
- 그룹 아이콘 업데이트는 macOS 26(Tahoe)에서 불안정할 수 있습니다. API는 성공을 반환해도 새 아이콘이 동기화되지 않을 수 있습니다.
- OpenClaw는 BlueBubbles 서버의 macOS 버전을 기준으로 알려진 문제 있는 작업을 자동으로 숨깁니다. macOS 26(Tahoe)에서 여전히 편집이 표시되면
channels.bluebubbles.actions.edit=false로 수동 비활성화하세요. - 상태/헬스 정보는
openclaw status --all또는openclaw status --deep를 사용하세요.