1.2 KiB
1.2 KiB
summary, read_when
| summary | read_when | ||
|---|---|---|---|
| RPC adapters for external CLIs (signal-cli, imsg) and gateway patterns |
|
RPC adapters
Clawdbot integrates external CLIs via JSON-RPC. Two patterns are used today.
Pattern A: HTTP daemon (signal-cli)
signal-cliruns as a daemon with JSON-RPC over HTTP.- Event stream is SSE (
/api/v1/events). - Health probe:
/api/v1/check. - Clawdbot owns lifecycle when
signal.autoStart=true.
See docs/signal.md for setup and endpoints.
Pattern B: stdio child process (imsg)
- Clawdbot spawns
imsg rpcas a child process. - JSON-RPC is line-delimited over stdin/stdout (one JSON object per line).
- No TCP port, no daemon required.
Core methods used:
watch.subscribe→ notifications (method: "message")watch.unsubscribesendchats.list(probe/diagnostics)
See docs/imessage.md for setup and addressing (chat_id preferred).
Adapter guidelines
- Gateway owns the process (start/stop tied to provider lifecycle).
- Keep RPC clients resilient: timeouts, restart on exit.
- Prefer stable IDs (e.g.,
chat_id) over display strings.