23 KiB
summary, read_when
| summary | read_when | ||
|---|---|---|---|
| Clawdbot CLI reference for `clawdbot` commands, subcommands, and options |
|
CLI reference
This page describes the current CLI behavior. If commands change, update this doc.
Global flags
--dev: isolate state under~/.clawdbot-devand shift default ports.--profile <name>: isolate state under~/.clawdbot-<name>.--no-color: disable ANSI colors.--update: shorthand forclawdbot update(source installs only).-V,--version,-v: print version and exit.
Output styling
- ANSI colors and progress indicators only render in TTY sessions.
- OSC-8 hyperlinks render as clickable links in supported terminals; otherwise we fall back to plain URLs.
--json(and--plainwhere supported) disables styling for clean output.--no-colordisables ANSI styling;NO_COLOR=1is also respected.- Long-running commands show a progress indicator (OSC 9;4 when supported).
Color palette
Clawdbot uses a lobster palette for CLI output.
accent(#FF5A2D): headings, provider labels, primary highlights.accentBright(#FF7A3D): command names, emphasis.accentDim(#D14A22): secondary highlight text.info(#FF8A5B): informational values.success(#2FBF71): success states.warn(#FFB020): warnings, fallbacks, attention.error(#E23D2D): errors, failures.muted(#8B7F77): de-emphasis, metadata.
Palette source of truth: src/terminal/palette.ts (aka “lobster seam”).
Command tree
clawdbot [--dev] [--profile <name>] <command>
setup
onboard
configure (alias: config)
doctor
reset
uninstall
update
channels
list
status
logs
add
remove
login
logout
skills
list
info
check
plugins
list
info
install
enable
disable
doctor
memory
status
index
search
message
agent
agents
list
add
delete
status
health
sessions
gateway
call
health
status
discover
daemon
status
install
uninstall
start
stop
restart
logs
models
list
status
set
set-image
aliases list|add|remove
fallbacks list|add|remove|clear
image-fallbacks list|add|remove|clear
scan
auth add|setup-token|paste-token
auth order get|set|clear
sandbox
list
recreate
explain
wake
cron
status
list
add
edit
rm
enable
disable
runs
run
nodes
status
describe
list
pending
approve
reject
rename
invoke
run
notify
camera list|snap|clip
canvas snapshot|present|hide|navigate|eval
canvas a2ui push|reset
screen record
location get
browser
status
start
stop
reset-profile
tabs
open
focus
close
profiles
create-profile
delete-profile
screenshot
snapshot
navigate
resize
click
type
press
hover
drag
select
upload
fill
dialog
wait
evaluate
console
pdf
hooks
gmail setup|run
pairing
list
approve
docs
dns
setup
tui
Note: plugins can add additional top-level commands (for example clawdbot voicecall).
Plugins
Manage extensions and their config:
clawdbot plugins list— discover plugins (use--jsonfor machine output).clawdbot plugins info <id>— show details for a plugin.clawdbot plugins install <path|.tgz|npm-spec>— install a plugin (or add a plugin path toplugins.load.paths).clawdbot plugins enable <id>/disable <id>— toggleplugins.entries.<id>.enabled.clawdbot plugins doctor— report plugin load errors.
Most plugin changes require a gateway restart. See /plugin.
Memory
Vector search over MEMORY.md + memory/*.md:
clawdbot memory status— show index stats.clawdbot memory index— reindex memory files.clawdbot memory search "<query>"— semantic search over memory.
Chat slash commands
Chat messages support /... commands (text and native). See /tools/slash-commands.
Highlights:
/statusfor quick diagnostics./configfor persisted config changes./debugfor runtime-only config overrides (memory, not disk; requirescommands.debug: true).
Setup + onboarding
setup
Initialize config + workspace.
Options:
--workspace <dir>: agent workspace path (default~/clawd).--wizard: run the onboarding wizard.--non-interactive: run wizard without prompts.--mode <local|remote>: wizard mode.--remote-url <url>: remote Gateway URL.--remote-token <token>: remote Gateway token.
Wizard auto-runs when any wizard flags are present (--non-interactive, --mode, --remote-url, --remote-token).
onboard
Interactive wizard to set up gateway, workspace, and skills.
Options:
--workspace <dir>--reset(reset config + credentials + sessions + workspace before wizard)--non-interactive--mode <local|remote>--flow <quickstart|advanced>--auth-choice <setup-token|claude-cli|token|openai-codex|openai-api-key|openrouter-api-key|moonshot-api-key|codex-cli|antigravity|gemini-api-key|zai-api-key|apiKey|minimax-api|opencode-zen|skip>--token-provider <id>(non-interactive; used with--auth-choice token)--token <token>(non-interactive; used with--auth-choice token)--token-profile-id <id>(non-interactive; default:<provider>:manual)--token-expires-in <duration>(non-interactive; e.g.365d,12h)--anthropic-api-key <key>--openai-api-key <key>--openrouter-api-key <key>--moonshot-api-key <key>--gemini-api-key <key>--zai-api-key <key>--minimax-api-key <key>--opencode-zen-api-key <key>--gateway-port <port>--gateway-bind <loopback|lan|tailnet|auto>--gateway-auth <off|token|password>--gateway-token <token>--gateway-password <password>--remote-url <url>--remote-token <token>--tailscale <off|serve|funnel>--tailscale-reset-on-exit--install-daemon--no-install-daemon(alias:--skip-daemon)--daemon-runtime <node|bun>--skip-channels--skip-skills--skip-health--skip-ui--node-manager <npm|pnpm|bun>(pnpm recommended; bun not recommended for Gateway runtime)--json
configure / config
Interactive configuration wizard (models, channels, skills, gateway).
doctor
Health checks + quick fixes (config + gateway + legacy services).
Options:
--no-workspace-suggestions: disable workspace memory hints.--yes: accept defaults without prompting (headless).--non-interactive: skip prompts; apply safe migrations only.--deep: scan system services for extra gateway installs.
Channel helpers
channels
Manage chat channel accounts (WhatsApp/Telegram/Discord/Slack/Signal/iMessage/MS Teams).
Subcommands:
channels list: show configured channels and auth profiles (Claude Code + Codex CLI OAuth sync included).channels status: check gateway reachability and channel health (--proberuns extra checks; useclawdbot healthorclawdbot status --deepfor gateway health probes).- Tip:
channels statusprints warnings with suggested fixes when it can detect common misconfigurations (then points you toclawdbot doctor). channels logs: show recent channel logs from the gateway log file.channels add: wizard-style setup when no flags are passed; flags switch to non-interactive mode.channels remove: disable by default; pass--deleteto remove config entries without prompts.channels login: interactive channel login (WhatsApp Web only).channels logout: log out of a channel session (if supported).
Common options:
--channel <name>:whatsapp|telegram|discord|slack|signal|imessage|msteams--account <id>: channel account id (defaultdefault)--name <label>: display name for the account
channels login options:
--channel <channel>(defaultwhatsapp; supportswhatsapp/web)--account <id>--verbose
channels logout options:
--channel <channel>(defaultwhatsapp)--account <id>
channels list options:
--no-usage: skip model provider usage/quota snapshots (OAuth/API-backed only).--json: output JSON (includes usage unless--no-usageis set).
channels logs options:
--channel <name|all>(defaultall)--lines <n>(default200)--json
OAuth sync sources:
- Claude Code →
anthropic:claude-cli- macOS: Keychain item "Claude Code-credentials" (choose "Always Allow" to avoid launchd prompts)
- Linux/Windows:
~/.claude/.credentials.json
~/.codex/auth.json→openai-codex:codex-cli
More detail: /concepts/oauth
Examples:
clawdbot channels add --channel telegram --account alerts --name "Alerts Bot" --token $TELEGRAM_BOT_TOKEN
clawdbot channels add --channel discord --account work --name "Work Bot" --token $DISCORD_BOT_TOKEN
clawdbot channels remove --channel discord --account work --delete
clawdbot channels status --probe
clawdbot status --deep
skills
List and inspect available skills plus readiness info.
Subcommands:
skills list: list skills (default when no subcommand).skills info <name>: show details for one skill.skills check: summary of ready vs missing requirements.
Options:
--eligible: show only ready skills.--json: output JSON (no styling).-v,--verbose: include missing requirements detail.
Tip: use npx clawdhub to search, install, and sync skills.
pairing
Approve DM pairing requests across channels.
Subcommands:
pairing list <channel> [--json]pairing approve <channel> <code> [--notify]
hooks gmail
Gmail Pub/Sub hook setup + runner. See /automation/gmail-pubsub.
Subcommands:
hooks gmail setup(requires--account <email>; supports--project,--topic,--subscription,--label,--hook-url,--hook-token,--push-token,--bind,--port,--path,--include-body,--max-bytes,--renew-minutes,--tailscale,--tailscale-path,--tailscale-target,--push-endpoint,--json)hooks gmail run(runtime overrides for the same flags)
dns setup
Wide-area discovery DNS helper (CoreDNS + Tailscale). See /gateway/discovery.
Options:
--apply: install/update CoreDNS config (requires sudo; macOS only).
Messaging + agent
message
Unified outbound messaging + channel actions.
See: /cli/message
Subcommands:
message send|poll|react|reactions|read|edit|delete|pin|unpin|pins|permissions|search|timeout|kick|banmessage thread <create|list|reply>message emoji <list|upload>message sticker <send|upload>message role <info|add|remove>message channel <info|list>message member infomessage voice statusmessage event <list|create>
Examples:
clawdbot message send --to +15555550123 --message "Hi"clawdbot message poll --channel discord --to channel:123 --poll-question "Snack?" --poll-option Pizza --poll-option Sushi
agent
Run one agent turn via the Gateway (or --local embedded).
Required:
--message <text>
Options:
--to <dest>(for session key and optional delivery)--session-id <id>--thinking <off|minimal|low|medium|high|xhigh>(GPT-5.2 + Codex models only)--verbose <on|off>--channel <whatsapp|telegram|discord|slack|signal|imessage>--local--deliver--json--timeout <seconds>
agents
Manage isolated agents (workspaces + auth + routing).
agents list
List configured agents.
Options:
--json--bindings
agents add [name]
Add a new isolated agent. Runs the guided wizard unless flags (or --non-interactive) are passed; --workspace is required in non-interactive mode.
Options:
--workspace <dir>--model <id>--agent-dir <dir>--bind <channel[:accountId]>(repeatable)--non-interactive--json
Binding specs use channel[:accountId]. When accountId is omitted for WhatsApp, the default account id is used.
agents delete <id>
Delete an agent and prune its workspace + state.
Options:
--force--json
status
Show linked session health and recent recipients.
Options:
--json--all(full diagnosis; read-only, pasteable)--deep(probe channels)--usage(show model provider usage/quota)--timeout <ms>--verbose--debug(alias for--verbose)
Usage tracking
Clawdbot can surface provider usage/quota when OAuth/API creds are available.
Surfaces:
/status(alias:/usage; adds a short usage line when available)clawdbot status --usage(prints full provider breakdown)- macOS menu bar (Usage section under Context)
Notes:
- Data comes directly from provider usage endpoints (no estimates).
- Providers: Anthropic, GitHub Copilot, Gemini CLI, Antigravity, OpenAI Codex OAuth, plus z.ai when an API key is configured.
- If no matching credentials exist, usage is hidden.
- Details: see Usage tracking.
health
Fetch health from the running Gateway.
Options:
--json--timeout <ms>--verbose
sessions
List stored conversation sessions.
Options:
--json--verbose--store <path>--active <minutes>
Reset / Uninstall
reset
Reset local config/state (keeps the CLI installed).
Options:
--scope <config|config+creds+sessions|full>--yes--non-interactive--dry-run
Notes:
--non-interactiverequires--scopeand--yes.
uninstall
Uninstall the gateway service + local data (CLI remains).
Options:
--service--state--workspace--app--all--yes--non-interactive--dry-run
Notes:
--non-interactiverequires--yesand explicit scopes (or--all).
Gateway
gateway
Run the WebSocket Gateway.
Options:
--port <port>--bind <loopback|tailnet|lan|auto>--token <token>--auth <token|password>--password <password>--tailscale <off|serve|funnel>--tailscale-reset-on-exit--allow-unconfigured--dev--reset(reset dev config + credentials + sessions + workspace)--force(kill existing listener on port)--verbose--claude-cli-logs--ws-log <auto|full|compact>--compact(alias for--ws-log compact)--raw-stream--raw-stream-path <path>
daemon
Manage the Gateway service (launchd/systemd/schtasks).
Subcommands:
daemon status(probes the Gateway RPC by default)daemon install(service install)daemon uninstalldaemon startdaemon stopdaemon restart
Notes:
daemon statusprobes the Gateway RPC by default using the daemon’s resolved port/config (override with--url/--token/--password).daemon statussupports--no-probe,--deep, and--jsonfor scripting.daemon statusalso surfaces legacy or extra gateway services when it can detect them (--deepadds system-level scans). Profile-named Clawdbot services are treated as first-class and aren't flagged as "extra".daemon statusprints which config path the CLI uses vs which config the daemon likely uses (service env), plus the resolved probe target URL.daemon installdefaults to Node runtime; bun is not recommended (WhatsApp/Telegram bugs).daemon installoptions:--port,--runtime,--token,--force.
logs
Tail Gateway file logs via RPC.
Notes:
- TTY sessions render a colorized, structured view; non-TTY falls back to plain text.
--jsonemits line-delimited JSON (one log event per line).
Examples:
clawdbot logs --follow
clawdbot logs --limit 200
clawdbot logs --plain
clawdbot logs --json
clawdbot logs --no-color
gateway <subcommand>
Gateway RPC helpers (use --url, --token, --password, --timeout, --expect-final for each).
Subcommands:
gateway call <method> [--params <json>]gateway healthgateway statusgateway discover
Common RPCs:
config.apply(validate + write config + restart + wake)update.run(run update + restart + wake)
Models
See /concepts/models for fallback behavior and scanning strategy.
Preferred Anthropic auth (CLI token, not API key):
claude setup-token
clawdbot models status
models (root)
clawdbot models is an alias for models status.
Root options:
--status-json(alias formodels status --json)--status-plain(alias formodels status --plain)
models list
Options:
--all--local--provider <name>--json--plain
models status
Options:
--json--plain--check(exit 1=expired/missing, 2=expiring)
Always includes the auth overview and OAuth expiry status for profiles in the auth store.
models set <model>
Set agents.defaults.model.primary.
models set-image <model>
Set agents.defaults.imageModel.primary.
models aliases list|add|remove
Options:
list:--json,--plainadd <alias> <model>remove <alias>
models fallbacks list|add|remove|clear
Options:
list:--json,--plainadd <model>remove <model>clear
models image-fallbacks list|add|remove|clear
Options:
list:--json,--plainadd <model>remove <model>clear
models scan
Options:
--min-params <b>--max-age-days <days>--provider <name>--max-candidates <n>--timeout <ms>--concurrency <n>--no-probe--yes--no-input--set-default--set-image--json
models auth add|setup-token|paste-token
Options:
add: interactive auth helpersetup-token:--provider <name>(defaultanthropic),--yespaste-token:--provider <name>,--profile-id <id>,--expires-in <duration>
models auth order get|set|clear
Options:
get:--provider <name>,--agent <id>,--jsonset:--provider <name>,--agent <id>,<profileIds...>clear:--provider <name>,--agent <id>
Cron + wake
wake
Enqueue a system event and optionally trigger a heartbeat (Gateway RPC).
Required:
--text <text>
Options:
--mode <now|next-heartbeat>--json--url,--token,--timeout,--expect-final
cron
Manage scheduled jobs (Gateway RPC). See /automation/cron-jobs.
Subcommands:
cron status [--json]cron list [--all] [--json](table output by default; use--jsonfor raw)cron add(alias:create; requires--nameand exactly one of--at|--every|--cron, and exactly one payload of--system-event|--message)cron edit <id>(patch fields)cron rm <id>(aliases:remove,delete)cron enable <id>cron disable <id>cron runs --id <id> [--limit <n>]cron run <id> [--force]
All cron commands accept --url, --token, --timeout, --expect-final.
Nodes
nodes talks to the Gateway and targets paired nodes. See /nodes.
Common options:
--url,--token,--timeout,--json
Subcommands:
nodes statusnodes describe --node <id|name|ip>nodes listnodes pendingnodes approve <requestId>nodes reject <requestId>nodes rename --node <id|name|ip> --name <displayName>nodes invoke --node <id|name|ip> --command <command> [--params <json>] [--invoke-timeout <ms>] [--idempotency-key <key>]nodes run --node <id|name|ip> [--cwd <path>] [--env KEY=VAL] [--command-timeout <ms>] [--needs-screen-recording] [--invoke-timeout <ms>] <command...>(mac only)nodes notify --node <id|name|ip> [--title <text>] [--body <text>] [--sound <name>] [--priority <passive|active|timeSensitive>] [--delivery <system|overlay|auto>] [--invoke-timeout <ms>](mac only)
Camera:
nodes camera list --node <id|name|ip>nodes camera snap --node <id|name|ip> [--facing front|back|both] [--device-id <id>] [--max-width <px>] [--quality <0-1>] [--delay-ms <ms>] [--invoke-timeout <ms>]nodes camera clip --node <id|name|ip> [--facing front|back] [--device-id <id>] [--duration <ms|10s|1m>] [--no-audio] [--invoke-timeout <ms>]
Canvas + screen:
nodes canvas snapshot --node <id|name|ip> [--format png|jpg|jpeg] [--max-width <px>] [--quality <0-1>] [--invoke-timeout <ms>]nodes canvas present --node <id|name|ip> [--target <urlOrPath>] [--x <px>] [--y <px>] [--width <px>] [--height <px>] [--invoke-timeout <ms>]nodes canvas hide --node <id|name|ip> [--invoke-timeout <ms>]nodes canvas navigate <url> --node <id|name|ip> [--invoke-timeout <ms>]nodes canvas eval [<js>] --node <id|name|ip> [--js <code>] [--invoke-timeout <ms>]nodes canvas a2ui push --node <id|name|ip> (--jsonl <path> | --text <text>) [--invoke-timeout <ms>]nodes canvas a2ui reset --node <id|name|ip> [--invoke-timeout <ms>]nodes screen record --node <id|name|ip> [--screen <index>] [--duration <ms|10s>] [--fps <n>] [--no-audio] [--out <path>] [--invoke-timeout <ms>]
Location:
nodes location get --node <id|name|ip> [--max-age <ms>] [--accuracy <coarse|balanced|precise>] [--location-timeout <ms>] [--invoke-timeout <ms>]
Browser
Browser control CLI (dedicated Chrome/Chromium). See /tools/browser.
Common options:
--url <controlUrl>--browser-profile <name>--json
Manage:
browser statusbrowser startbrowser stopbrowser reset-profilebrowser tabsbrowser open <url>browser focus <targetId>browser close [targetId]browser profilesbrowser create-profile --name <name> [--color <hex>] [--cdp-url <url>]browser delete-profile --name <name>
Inspect:
browser screenshot [targetId] [--full-page] [--ref <ref>] [--element <selector>] [--type png|jpeg]browser snapshot [--format aria|ai] [--target-id <id>] [--limit <n>] [--interactive] [--compact] [--depth <n>] [--selector <sel>] [--out <path>]
Actions:
browser navigate <url> [--target-id <id>]browser resize <width> <height> [--target-id <id>]browser click <ref> [--double] [--button <left|right|middle>] [--modifiers <csv>] [--target-id <id>]browser type <ref> <text> [--submit] [--slowly] [--target-id <id>]browser press <key> [--target-id <id>]browser hover <ref> [--target-id <id>]browser drag <startRef> <endRef> [--target-id <id>]browser select <ref> <values...> [--target-id <id>]browser upload <paths...> [--ref <ref>] [--input-ref <ref>] [--element <selector>] [--target-id <id>] [--timeout-ms <ms>]browser fill [--fields <json>] [--fields-file <path>] [--target-id <id>]browser dialog --accept|--dismiss [--prompt <text>] [--target-id <id>] [--timeout-ms <ms>]browser wait [--time <ms>] [--text <value>] [--text-gone <value>] [--target-id <id>]browser evaluate --fn <code> [--ref <ref>] [--target-id <id>]browser console [--level <error|warn|info>] [--target-id <id>]browser pdf [--target-id <id>]
Docs search
docs [query...]
Search the live docs index.
TUI
tui
Open the terminal UI connected to the Gateway.
Options:
--url <url>--token <token>--password <password>--session <key>--deliver--thinking <level>--message <text>--timeout-ms <ms>(defaults toagents.defaults.timeoutSeconds)--history-limit <n>