Skip to main contentPresence
Clawdbot “presence” is a lightweight, best‑effort view of:
- the Gateway itself, and
- clients connected to the Gateway (mac app, WebChat, CLI, etc.)
Presence is used primarily to render the macOS app’s Instances tab and to
provide quick operator visibility.
Presence fields (what shows up)
Presence entries are structured objects with fields like:
instanceId (optional but strongly recommended): stable client identity
host: human‑friendly host name
ip: best‑effort IP address
version: client version string
deviceFamily / modelIdentifier: hardware hints
mode: gateway, app, webchat, cli, node, …
lastInputSeconds: “seconds since last user input” (if known)
reason: self, connect, node-connected, periodic, …
ts: last update timestamp (ms since epoch)
Producers (where presence comes from)
Presence entries are produced by multiple sources and merged.
1) Gateway self entry
The Gateway always seeds a “self” entry at startup so UIs show the gateway host
even before any clients connect.
2) WebSocket connect
Every WS client begins with a connect request. On successful handshake the
Gateway upserts a presence entry for that connection.
Why one‑off CLI commands don’t show up
The CLI often connects for short, one‑off commands. To avoid spamming the
Instances list, client.mode === "cli" is not turned into a presence entry.
3) system-event beacons
Clients can send richer periodic beacons via the system-event method. The mac
app uses this to report host name, IP, and lastInputSeconds.
4) Node bridge beacons
When a node bridge connection authenticates, the Gateway emits a presence entry
for that node and refreshes it periodically so it doesn’t expire.
Merge + dedupe rules (why instanceId matters)
Presence entries are stored in a single in‑memory map:
- Entries are keyed by a presence key.
- The best key is a stable
instanceId that survives restarts.
- Keys are case‑insensitive.
If a client reconnects without a stable instanceId, it may show up as a
duplicate row.
TTL and bounded size
Presence is intentionally ephemeral:
- TTL: entries older than 5 minutes are pruned
- Max entries: 200 (oldest dropped first)
This keeps the list fresh and avoids unbounded memory growth.
Remote/tunnel caveat (loopback IPs)
When a client connects over an SSH tunnel / local port forward, the Gateway may
see the remote address as 127.0.0.1. To avoid overwriting a good client‑reported
IP, loopback remote addresses are ignored.
Consumers
macOS Instances tab
The macOS app renders the output of system-presence and applies a small status
indicator (Active/Idle/Stale) based on the age of the last update.
Debugging tips
- To see the raw list, call
system-presence against the Gateway.
- If you see duplicates:
- confirm clients send a stable
instanceId in the handshake
- confirm periodic beacons use the same
instanceId
- check whether the connection‑derived entry is missing
instanceId (duplicates are expected)