2025-12-19 00:29:42 +01:00
---
2025-12-20 02:08:04 +00:00
summary: "Nodes: pairing, capabilities, permissions, and CLI helpers for canvas/camera/screen/system"
2025-12-19 00:29:42 +01:00
read_when:
- Pairing iOS/Android nodes to a gateway
- Using node canvas/camera for agent context
- Adding new node commands or CLI helpers
---
# Nodes
2025-12-20 02:08:04 +00:00
A **node** is a companion device (iOS/Android today) that connects to the Gateway over the **Bridge** and exposes a command surface (e.g. `canvas.*` , `camera.*` , `system.*` ) via `node.invoke` .
2025-12-19 00:29:42 +01:00
2026-01-04 14:32:47 +00:00
macOS can also run in **node mode** : the menubar app connects to the Gateway’ s bridge and exposes its local canvas/camera commands as a node (so `clawdbot nodes …` works against this Mac).
2025-12-19 01:48:19 +01:00
2025-12-19 00:29:42 +01:00
## Pairing + status
2026-01-06 18:59:06 +01:00
Pairing is gateway-owned and approval-based. See [`docs/gateway/pairing.md` ](https://docs.clawd.bot/gateway/pairing ) for the full flow.
2025-12-19 00:29:42 +01:00
Quick CLI:
```bash
2026-01-04 14:32:47 +00:00
clawdbot nodes pending
clawdbot nodes approve < requestId >
clawdbot nodes reject < requestId >
clawdbot nodes status
clawdbot nodes describe --node < idOrNameOrIp >
clawdbot nodes rename --node < idOrNameOrIp > --name "Kitchen iPad"
2025-12-19 00:29:42 +01:00
```
2025-12-27 01:36:24 +01:00
Notes:
- `nodes rename` stores a display name override in the gateway pairing store.
2025-12-19 00:29:42 +01:00
## Invoking commands
Low-level (raw RPC):
```bash
2026-01-04 14:32:47 +00:00
clawdbot nodes invoke --node < idOrNameOrIp > --command canvas.eval --params '{"javaScript":"location.href"}'
2025-12-19 00:29:42 +01:00
```
Higher-level helpers exist for the common “give the agent a MEDIA attachment” workflows.
## Screenshots (canvas snapshots)
If the node is showing the Canvas (WebView), `canvas.snapshot` returns `{ format, base64 }` .
CLI helper (writes to a temp file and prints `MEDIA:<path>` ):
```bash
2026-01-04 14:32:47 +00:00
clawdbot nodes canvas snapshot --node < idOrNameOrIp > --format png
clawdbot nodes canvas snapshot --node < idOrNameOrIp > --format jpg --max-width 1200 --quality 0.9
2025-12-19 00:29:42 +01:00
```
2025-12-19 02:56:48 +01:00
Simple shortcut (auto-picks a single connected node if possible):
```bash
2026-01-04 14:32:47 +00:00
clawdbot canvas snapshot --format png
clawdbot canvas snapshot --format jpg --max-width 1200 --quality 0.9
2025-12-19 02:56:48 +01:00
```
2025-12-19 00:29:42 +01:00
## Photos + videos (node camera)
Photos (`jpg` ):
```bash
2026-01-04 14:32:47 +00:00
clawdbot nodes camera snap --node < idOrNameOrIp > # default: both facings (2 MEDIA lines)
clawdbot nodes camera snap --node < idOrNameOrIp > --facing front
2025-12-19 00:29:42 +01:00
```
Video clips (`mp4` ):
```bash
2026-01-04 14:32:47 +00:00
clawdbot nodes camera clip --node < idOrNameOrIp > --duration 10s
clawdbot nodes camera clip --node < idOrNameOrIp > --duration 3000 --no-audio
2025-12-19 00:29:42 +01:00
```
Notes:
- The node must be **foregrounded** for `canvas.*` and `camera.*` (background calls return `NODE_BACKGROUND_UNAVAILABLE` ).
- Clip duration is clamped (currently `<= 60s` ) to avoid oversized base64 payloads.
- Android will prompt for `CAMERA` /`RECORD_AUDIO` permissions when possible; denied permissions fail with `*_PERMISSION_REQUIRED` .
2025-12-19 02:56:48 +01:00
## Screen recordings (nodes)
2025-12-19 02:33:43 +01:00
2025-12-19 02:56:48 +01:00
Nodes expose `screen.record` (mp4). Example:
2025-12-19 02:33:43 +01:00
```bash
2026-01-04 14:32:47 +00:00
clawdbot nodes screen record --node < idOrNameOrIp > --duration 10s --fps 10
clawdbot nodes screen record --node < idOrNameOrIp > --duration 10s --fps 10 --no-audio
2025-12-19 02:33:43 +01:00
```
2025-12-19 02:56:48 +01:00
Notes:
- `screen.record` requires the node app to be foregrounded.
- Android will show the system screen-capture prompt before recording.
- Screen recordings are clamped to `<= 60s` .
2025-12-19 03:16:25 +01:00
- `--no-audio` disables microphone capture (supported on iOS/Android; macOS uses system capture audio).
2025-12-19 02:56:48 +01:00
2026-01-04 00:54:44 +01:00
## Location (nodes)
Nodes expose `location.get` when Location is enabled in settings.
CLI helper:
```bash
2026-01-04 14:32:47 +00:00
clawdbot nodes location get --node < idOrNameOrIp >
clawdbot nodes location get --node < idOrNameOrIp > --accuracy precise --max-age 15000 --location-timeout 10000
2026-01-04 00:54:44 +01:00
```
Notes:
- Location is **off by default** .
- “Always” requires system permission; background fetch is best-effort.
- The response includes lat/lon, accuracy (meters), and timestamp.
2026-01-04 13:27:30 +01:00
## SMS (Android nodes)
Android nodes can expose `sms.send` when the user grants **SMS** permission and the device supports telephony.
Low-level invoke:
```bash
2026-01-04 14:32:47 +00:00
clawdbot nodes invoke --node < idOrNameOrIp > --command sms.send --params '{"to":"+15555550123","message":"Hello from Clawdbot"}'
2026-01-04 13:27:30 +01:00
```
Notes:
- The permission prompt must be accepted on the Android device before the capability is advertised.
- Wi-Fi-only devices without telephony will not advertise `sms.send` .
2025-12-20 02:08:04 +00:00
## System commands (mac node)
The macOS node exposes `system.run` and `system.notify` .
Examples:
```bash
2026-01-04 14:32:47 +00:00
clawdbot nodes run --node < idOrNameOrIp > -- echo "Hello from mac node"
clawdbot nodes notify --node < idOrNameOrIp > --title "Ping" --body "Gateway ready"
2025-12-20 02:08:04 +00:00
```
Notes:
- `system.run` returns stdout/stderr/exit code in the payload.
- `system.notify` respects notification permission state on the macOS app.
## Permissions map
Nodes may include a `permissions` map in `node.list` / `node.describe` , keyed by permission name (e.g. `screenRecording` , `accessibility` ) with boolean values (`true` = granted).
2025-12-19 02:33:43 +01:00
## Mac node mode
2026-01-04 14:32:47 +00:00
- The macOS menubar app connects to the Gateway bridge as a node (so `clawdbot nodes …` works against this Mac).
2025-12-19 02:33:43 +01:00
- In remote mode, the app opens an SSH tunnel for the bridge port and connects to `localhost` .
2025-12-19 00:29:42 +01:00
## Where to look in code
- CLI wiring: `src/cli/nodes-cli.ts`
- Canvas snapshot decoding/temp paths: `src/cli/nodes-canvas.ts`
- Duration parsing for CLI: `src/cli/parse-duration.ts`
- iOS node commands: `apps/ios/Sources/Model/NodeAppModel.swift`
2026-01-04 14:32:47 +00:00
- Android node commands: `apps/android/app/src/main/java/com/clawdbot/android/node/*`