Onboarding Wizard (CLI)
The onboarding wizard is the recommended way to set up Clawdbot on macOS, Linux, or Windows (via WSL2; strongly recommended). It configures a local Gateway or a remote Gateway connection, plus providers, skills, and workspace defaults in one guided flow. Primary entrypoint:QuickStart vs Advanced
The wizard starts with QuickStart (defaults) vs Advanced (full control). QuickStart keeps the defaults:- Local gateway (loopback)
- Workspace default (or existing workspace)
- Gateway port 18789
- Gateway auth Token (auto‑generated, even on loopback)
- Tailscale exposure Off
- Telegram + WhatsApp DMs default to allowlist (you’ll be prompted for your phone number)
What the wizard does
Local mode (default) walks you through:- Model/auth (OpenAI Code (Codex) subscription OAuth, Anthropic API key (recommended) or
claude setup-token, plus MiniMax/GLM options) - Workspace location + bootstrap files
- Gateway settings (port/bind/auth/tailscale)
- Providers (Telegram, WhatsApp, Discord, Signal)
- Daemon install (LaunchAgent / systemd user unit)
- Health check
- Skills (recommended)
--json does not imply non-interactive mode. Use --non-interactive (and --workspace) for scripts.
Flow details (local)
-
Existing config detection
- If
~/.clawdbot/clawdbot.jsonexists, choose Keep / Modify / Reset. - Reset uses
trash(neverrm) and offers scopes:- Config only
- Config + credentials + sessions
- Full reset (also removes workspace)
- If
-
Model/Auth
- Anthropic API key (recommended): uses
ANTHROPIC_API_KEYif present or prompts for a key, then saves it for daemon use. - Anthropic token (setup-token): run
claude setup-tokenon the gateway host (the wizard can run it for you and reuse the token). - Anthropic OAuth (Claude CLI): on macOS the wizard checks Keychain item “Claude Code-credentials” (choose “Always Allow” so launchd starts don’t block); on Linux/Windows it reuses
~/.claude/.credentials.jsonif present. - Anthropic token (paste setup-token): run
claude setup-tokenin your terminal, then paste the token (you can name it; blank = default). - OpenAI Code (Codex) subscription (Codex CLI): if
~/.codex/auth.jsonexists, the wizard can reuse it. - OpenAI Code (Codex) subscription (OAuth): browser flow; paste the
code#state.- Sets
agents.defaults.modeltoopenai-codex/gpt-5.2when model is unset oropenai/*.
- Sets
- OpenAI API key: uses
OPENAI_API_KEYif present or prompts for a key, then saves it to~/.clawdbot/.envso launchd can read it. - OpenCode Zen (multi-model proxy): prompts for
OPENCODE_API_KEY(orOPENCODE_ZEN_API_KEY, get it at https://opencode.ai/auth). - API key: stores the key for you.
- MiniMax M2.1 (minimax.io): config is auto‑written for the OpenAI-compatible
/v1endpoint. - MiniMax API (platform.minimax.io): config is auto‑written for the Anthropic-compatible
/anthropicendpoint. - MiniMax M2.1 (LM Studio): config is auto‑written for the LM Studio endpoint.
- More detail: MiniMax
- Skip: no auth configured yet.
- Pick a default model from detected options (or enter provider/model manually).
- Wizard runs a model check and warns if the configured model is unknown or missing auth.
- Anthropic API key (recommended): uses
- OAuth credentials live in
~/.clawdbot/credentials/oauth.json; auth profiles live in~/.clawdbot/agents/<agentId>/agent/auth-profiles.json(API keys + OAuth). - More detail: /concepts/oauth
-
Workspace
- Default
~/clawd(configurable). - Seeds the workspace files needed for the agent bootstrap ritual.
- Full workspace layout + backup guide: Agent workspace
- Default
-
Gateway
- Port, bind, auth mode, tailscale exposure.
- Auth recommendation: keep Token even for loopback so local WS clients must authenticate.
- Disable auth only if you fully trust every local process.
- Non‑loopback binds still require auth.
-
Providers
- WhatsApp: optional QR login.
- Telegram: bot token.
- Discord: bot token.
- Signal: optional
signal-cliinstall + account config. - iMessage: local
imsgCLI path + DB access.
- DM security: default is pairing. First DM sends a code; approve via
clawdbot pairing approve <provider> <code>or use allowlists.
-
Daemon install
- macOS: LaunchAgent
- Requires a logged-in user session; for headless, use a custom LaunchDaemon (not shipped).
- Linux (and Windows via WSL2): systemd user unit
- Wizard attempts to enable lingering via
loginctl enable-linger <user>so the Gateway stays up after logout. - May prompt for sudo (writes
/var/lib/systemd/linger); it tries without sudo first.
- Wizard attempts to enable lingering via
- Runtime selection: Node (recommended; required for WhatsApp) or Bun (faster, but incompatible with WhatsApp).
- macOS: LaunchAgent
-
Health check
- Starts the Gateway (if needed) and runs
clawdbot health. - Tip:
clawdbot status --deepadds gateway health probes to status output (requires a reachable gateway).
- Starts the Gateway (if needed) and runs
-
Skills (recommended)
- Reads the available skills and checks requirements.
- Lets you choose a node manager: npm / pnpm / bun.
- Installs optional dependencies (some use Homebrew on macOS).
-
Finish
- Summary + next steps, including iOS/Android/macOS apps for extra features.
- If no GUI is detected, the wizard prints SSH port-forward instructions for the Control UI instead of opening a browser.
- If the Control UI assets are missing, the wizard attempts to build them; fallback is
pnpm ui:build(auto-installs UI deps).
Remote mode
Remote mode configures a local client to connect to a Gateway elsewhere. What you’ll set:- Remote Gateway URL (
ws://...) - Token if the remote Gateway requires auth (recommended)
- No remote installs or daemon changes are performed.
- If the Gateway is loopback‑only, use SSH tunneling or a tailnet.
- Discovery hints:
- macOS: Bonjour (
dns-sd) - Linux: Avahi (
avahi-browse)
- macOS: Bonjour (
Add another agent
Useclawdbot agents add <name> to create a separate agent with its own workspace,
sessions, and auth profiles. Running without --workspace launches the wizard.
What it sets:
agents.list[].nameagents.list[].workspaceagents.list[].agentDir
- Default workspaces follow
~/clawd-<agentId>. - Add
bindingsto route inbound messages (the wizard can do this). - Non-interactive flags:
--model,--agent-dir,--bind,--non-interactive.
Non‑interactive mode
Use--non-interactive to automate or script onboarding:
--json for a machine‑readable summary.
Gemini example:
Gateway wizard RPC
The Gateway exposes the wizard flow over RPC (wizard.start, wizard.next, wizard.cancel, wizard.status).
Clients (macOS app, Control UI) can render steps without re‑implementing onboarding logic.
Signal setup (signal-cli)
The wizard can installsignal-cli from GitHub releases:
- Downloads the appropriate release asset.
- Stores it under
~/.clawdbot/tools/signal-cli/<version>/. - Writes
signal.cliPathto your config.
- JVM builds require Java 21.
- Native builds are used when available.
- Windows uses WSL2; signal-cli install follows the Linux flow inside WSL.
What the wizard writes
Typical fields in~/.clawdbot/clawdbot.json:
agents.defaults.workspaceagents.defaults.model/models.providers(if Minimax chosen)gateway.*(mode, bind, auth, tailscale)telegram.botToken,discord.token,signal.*,imessage.*skills.install.nodeManagerwizard.lastRunAtwizard.lastRunVersionwizard.lastRunCommitwizard.lastRunCommandwizard.lastRunMode
clawdbot agents add writes agents.list[] and optional bindings.
WhatsApp credentials go under ~/.clawdbot/credentials/whatsapp/<accountId>/.
Sessions are stored under ~/.clawdbot/agents/<agentId>/sessions/.
Related docs
- macOS app onboarding: Onboarding
- Config reference: Gateway configuration
- Providers: WhatsApp, Telegram, Discord, Signal, iMessage
- Skills: Skills, Skills config