# Onboarding Wizard Reference
This is the full reference for the opensoul onboard CLI wizard. For a high-level overview, see Onboarding Wizard.
# Flow details (local mode)
# Existing config detection
- If
~/.opensoul/opensoul.jsonexists, choose Keep / Modify / Reset. - Re-running the wizard does not wipe anything unless you explicitly choose Reset (or pass
--reset). - If the config is invalid or contains legacy keys, the wizard stops and asks you to run
opensoul doctorbefore continuing. - Reset uses
trash(neverrm) and offers scopes:- Config only
- Config + credentials + sessions
- Full reset (also removes workspace)
# Model/Auth
- Anthropic API key (recommended): uses
ANTHROPIC_API_KEYif present or prompts for a key, then saves it for daemon use. - Anthropic OAuth (Claude Code 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-tokenon any machine, 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~/.opensoul/.envso launchd can read it. - xAI (Grok) API key: prompts for
XAI_API_KEYand configures xAI as a model provider. - 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.
- Vercel AI Gateway (multi-model proxy): prompts for
AI_GATEWAY_API_KEY. - More detail: Vercel AI Gateway
- Cloudflare AI Gateway: prompts for Account ID, Gateway ID, and
CLOUDFLARE_AI_GATEWAY_API_KEY. - More detail: Cloudflare AI Gateway
- MiniMax M2.1: config is auto-written.
- More detail: MiniMax
- Synthetic (Anthropic-compatible): prompts for
SYNTHETIC_API_KEY. - More detail: Synthetic
- Moonshot (Kimi K2): config is auto-written.
- Kimi Coding: config is auto-written.
- More detail: Moonshot AI (Kimi + Kimi Coding)
- 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.
- OAuth credentials live in
~/.opensoul/credentials/oauth.json; auth profiles live in~/.opensoul/agents/<agentId>/agent/auth-profiles.json(API keys + OAuth). - More detail: /concepts/oauth
Note: Headless/server tip: complete OAuth on a machine with a browser, then copy
~/.opensoul/credentials/oauth.json(or$OPENSOUL_STATE_DIR/credentials/oauth.json) to the gateway host.
# Workspace
- Default
~/.opensoul/workspace(configurable). - Seeds the workspace files needed for the agent bootstrap ritual.
- Full workspace layout + backup guide: Agent workspace
# 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.
# Channels
- WhatsApp: optional QR login.
- Telegram: bot token.
- Discord: bot token.
- Google Chat: service account JSON + webhook audience.
- Mattermost (plugin): bot token + base URL.
- Signal: optional
signal-cliinstall + account config. - BlueBubbles: recommended for iMessage; server URL + password + webhook.
- iMessage: legacy
imsgCLI path + DB access. - DM security: default is pairing. First DM sends a code; approve via
opensoul pairing approve <channel> <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/Telegram). Bun is not recommended.
# Health check
- Starts the Gateway (if needed) and runs
opensoul health. - Tip:
opensoul status --deepadds gateway health probes to status output (requires a reachable gateway).
# Skills (recommended)
- Reads the available skills and checks requirements.
- Lets you choose a node manager: npm / pnpm (bun not recommended).
- Installs optional dependencies (some use Homebrew on macOS).