Build or update the BlueBubbles external channel plugin for Clawdbot (extension package, REST send/probe, webhook inbound).
Downloads
2.3k
Stars
0
Versions
1
Updated
2026-02-24
Install
npx clawhub@latest install bluebubbles
Documentation
BlueBubbles plugin
Use this skill when working on the BlueBubbles channel plugin.
Layout
- -Extension package:
extensions/bluebubbles/(entry:index.ts). - -Channel implementation:
extensions/bluebubbles/src/channel.ts. - -Webhook handling:
extensions/bluebubbles/src/monitor.ts(register viaapi.registerHttpHandler). - -REST helpers:
extensions/bluebubbles/src/send.ts+extensions/bluebubbles/src/probe.ts. - -Runtime bridge:
extensions/bluebubbles/src/runtime.ts(set viaapi.runtime). - -Catalog entry for onboarding:
src/channels/plugins/catalog.ts.
Internal helpers (use these, not raw API calls)
- -
probeBlueBubblesinextensions/bluebubbles/src/probe.tsfor health checks. - -
sendMessageBlueBubblesinextensions/bluebubbles/src/send.tsfor text delivery. - -
resolveChatGuidForTargetinextensions/bluebubbles/src/send.tsfor chat lookup. - -
sendBlueBubblesReactioninextensions/bluebubbles/src/reactions.tsfor tapbacks. - -
sendBlueBubblesTyping+markBlueBubblesChatReadinextensions/bluebubbles/src/chat.ts. - -
downloadBlueBubblesAttachmentinextensions/bluebubbles/src/attachments.tsfor inbound media. - -
buildBlueBubblesApiUrl+blueBubblesFetchWithTimeoutinextensions/bluebubbles/src/types.tsfor shared REST plumbing.
Webhooks
- -BlueBubbles posts JSON to the gateway HTTP server.
- -Normalize sender/chat IDs defensively (payloads vary by version).
- -Skip messages marked as from self.
- -Route into core reply pipeline via the plugin runtime (
api.runtime) andclawdbot/plugin-sdkhelpers. - -For attachments/stickers, use
<media:...>placeholders when text is empty and attach media paths viaMediaUrl(s)in the inbound context.
Config (core)
- -
channels.bluebubbles.serverUrl(base URL),channels.bluebubbles.password,channels.bluebubbles.webhookPath. - -Action gating:
channels.bluebubbles.actions.reactions(default true).
Message tool notes
- -Reactions: The
reactaction requires atarget(phone number or chat identifier) in addition tomessageId. Example:action=react target=+15551234567 messageId=ABC123 emoji=❤️
Launch an agent with Bluebubbles on Termo.