Onboarding Reference
This is the full reference forpllan onboard.
For a high-level overview, see Onboarding (CLI).
Flow details (local mode)
Existing config detection
- If
~/.pllan/pllan.jsonexists, choose Keep / Modify / Reset. - Re-running onboarding does not wipe anything unless you explicitly choose Reset
(or pass
--reset). - CLI
--resetdefaults toconfig+creds+sessions; use--reset-scope fullto also remove workspace. - If the config is invalid or contains legacy keys, the wizard stops and asks
you to run
pllan doctorbefore continuing. - Reset uses
trash(neverrm) and offers scopes:- Config only
- Config + credentials + sessions
- Full reset (also removes workspace)
Model/Auth
- Anthropic API key: uses
ANTHROPIC_API_KEYif present or prompts for a key, then saves it for daemon use. - Anthropic OAuth (Claude Code CLI): on macOS onboarding 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, onboarding 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 stores it in auth profiles. - xAI (Grok) API key: prompts for
XAI_API_KEYand configures xAI as a model provider. - OpenCode: prompts for
OPENCODE_API_KEY(orOPENCODE_ZEN_API_KEY, get it at https://opencode.ai/auth) and lets you pick the Zen or Go catalog. - Ollama: prompts for the Ollama base URL, offers Cloud + Local or Local mode, discovers available models, and auto-pulls the selected local model when needed.
- More detail: Ollama
- 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: config is auto-written; hosted default is
MiniMax-M2.7andMiniMax-M2.5stays available. - 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). For best quality and lower prompt-injection risk, choose the strongest latest-generation model available in your provider stack.
- Onboarding runs a model check and warns if the configured model is unknown or missing auth.
- API key storage mode defaults to plaintext auth-profile values. Use
--secret-input-mode refto store env-backed refs instead (for examplekeyRef: { source: "env", provider: "default", id: "OPENAI_API_KEY" }). - OAuth credentials live in
~/.pllan/credentials/oauth.json; auth profiles live in~/.pllan/agents/<agentId>/agent/auth-profiles.json(API keys + OAuth). - More detail: /concepts/oauth
Headless/server tip: complete OAuth on a machine with a browser, then copy
~/.pllan/credentials/oauth.json (or $PLLAN_STATE_DIR/credentials/oauth.json) to the
gateway host.Workspace
- Default
~/.pllan/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.
- In token mode, interactive setup offers:
- Generate/store plaintext token (default)
- Use SecretRef (opt-in)
- Quickstart reuses existing
gateway.auth.tokenSecretRefs acrossenv,file, andexecproviders for onboarding probe/dashboard bootstrap. - If that SecretRef is configured but cannot be resolved, onboarding fails early with a clear fix message instead of silently degrading runtime auth.
- In password mode, interactive setup also supports plaintext or SecretRef storage.
- Non-interactive token SecretRef path:
--gateway-token-ref-env <ENV_VAR>.- Requires a non-empty env var in the onboarding process environment.
- Cannot be combined with
--gateway-token.
- 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
pllan pairing approve <channel> <code>or use allowlists.
Web search
- Pick a provider: Perplexity, Brave, Gemini, Grok, or Kimi (or skip).
- Paste your API key (QuickStart auto-detects keys from env vars or existing config).
- Skip with
--skip-search. - Configure later:
pllan configure --section web.
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
- Onboarding 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.
- Onboarding attempts to enable lingering via
- Runtime selection: Node (recommended; required for WhatsApp/Telegram). Bun is not recommended.
- If token auth requires a token and
gateway.auth.tokenis SecretRef-managed, daemon install validates it but does not persist resolved plaintext token values into supervisor service environment metadata. - If token auth requires a token and the configured token SecretRef is unresolved, daemon install is blocked with actionable guidance.
- If both
gateway.auth.tokenandgateway.auth.passwordare configured andgateway.auth.modeis unset, daemon install is blocked until mode is set explicitly.
Health check
- Starts the Gateway (if needed) and runs
pllan health. - Tip:
pllan 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).
If no GUI is detected, onboarding prints SSH port-forward instructions for the Control UI instead of opening a browser.
If the Control UI assets are missing, onboarding attempts to build them; fallback is
pnpm ui:build (auto-installs UI deps).Non-interactive mode
Use--non-interactive to automate or script onboarding:
--json for a machine‑readable summary.
Gateway token SecretRef in non-interactive mode:
--gateway-token and --gateway-token-ref-env are mutually exclusive.
--json does not imply non-interactive mode. Use --non-interactive (and --workspace) for scripts.Add agent (non-interactive)
Gateway wizard RPC
The Gateway exposes the onboarding 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)
Onboarding can installsignal-cli from GitHub releases:
- Downloads the appropriate release asset.
- Stores it under
~/.pllan/tools/signal-cli/<version>/. - Writes
channels.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~/.pllan/pllan.json:
agents.defaults.workspaceagents.defaults.model/models.providers(if Minimax chosen)tools.profile(local onboarding defaults to"coding"when unset; existing explicit values are preserved)gateway.*(mode, bind, auth, tailscale)session.dmScope(behavior details: CLI Setup Reference)channels.telegram.botToken,channels.discord.token,channels.signal.*,channels.imessage.*- Channel allowlists (Slack/Discord/Matrix/Microsoft Teams) when you opt in during the prompts (names resolve to IDs when possible).
skills.install.nodeManagerwizard.lastRunAtwizard.lastRunVersionwizard.lastRunCommitwizard.lastRunCommandwizard.lastRunMode
pllan agents add writes agents.list[] and optional bindings.
WhatsApp credentials go under ~/.pllan/credentials/whatsapp/<accountId>/.
Sessions are stored under ~/.pllan/agents/<agentId>/sessions/.
Some channels are delivered as plugins. When you pick one during setup, onboarding
will prompt to install it (npm or a local path) before it can be configured.
Related docs
- Onboarding overview: Onboarding (CLI)
- macOS app onboarding: Onboarding
- Config reference: Gateway configuration
- Providers: WhatsApp, Telegram, Discord, Google Chat, Signal, BlueBubbles (iMessage), iMessage (legacy)
- Skills: Skills, Skills config