docs/announcements/bluebubbles-imessage.md
OpenClaw no longer ships the BlueBubbles channel. iMessage support now runs through the bundled imessage plugin, which starts imsg locally or through an SSH wrapper and talks JSON-RPC over stdin/stdout.
If your config still contains channels.bluebubbles, migrate it to channels.imessage. The legacy /channels/bluebubbles docs URL redirects to Coming from BlueBubbles, which has the full config translation table and cutover checklist.
imsg on the Mac where Messages.app is signed in.imsg surfaces and macOS permissions.imsg launch with the private API bridge available.channels.imessage.cliPath to an SSH wrapper that runs imsg on the signed-in Mac.Install and verify imsg on the Messages Mac:
brew install steipete/tap/imsg
imsg --version
imsg chats --limit 3
imsg rpc --help
Grant Full Disk Access and Automation permissions to the process context that runs imsg and OpenClaw.
Translate the old config:
{
channels: {
imessage: {
enabled: true,
cliPath: "/opt/homebrew/bin/imsg",
dmPolicy: "pairing",
allowFrom: ["+15555550123"],
groupPolicy: "allowlist",
groupAllowFrom: ["+15555550123"],
groups: {
"*": { requireMention: true },
},
includeAttachments: true,
},
},
}
Restart the gateway and verify:
openclaw channels status --probe
Test DMs, groups, attachments, and any private API actions you depend on before deleting your old BlueBubbles server.
channels.bluebubbles.serverUrl and channels.bluebubbles.password have no iMessage equivalent.channels.bluebubbles.allowFrom, groupAllowFrom, groups, includeAttachments, attachment roots, media size limits, chunking, and action toggles have iMessage equivalents.channels.imessage.includeAttachments is still off by default. Set it explicitly if you expect inbound photos, voice memos, videos, or files to reach the agent.groupPolicy: "allowlist", copy the old groups block, including any "*" wildcard entry. Group sender allowlists and the group registry are separate gates.channel: "bluebubbles" must be changed to channel: "imessage".