Technical reference
مرجع راهاندازی اولیه
این مرجع کامل برای openclaw onboard است.
برای مرور کلی سطح بالا، Onboarding (CLI) را ببینید.
جزئیات جریان (حالت محلی)
Existing config detection
- اگر
~/.openclaw/openclaw.jsonوجود داشته باشد، مقادیر فعلی را نگه دارید، بازبینی و بهروزرسانی، یا بازنشانی پیش از راهاندازی را انتخاب کنید. - اجرای دوباره onboarding هیچچیز را پاک نمیکند مگر اینکه صراحتا Reset
را انتخاب کنید (یا
--resetرا پاس دهید). --resetدر CLI بهطور پیشفرض رویconfig+creds+sessionsاست؛ از--reset-scope fullاستفاده کنید تا workspace هم حذف شود.- اگر config نامعتبر باشد یا کلیدهای قدیمی داشته باشد، wizard متوقف میشود و از شما میخواهد
پیش از ادامه
openclaw doctorرا اجرا کنید. - Reset از
trashاستفاده میکند (هرگزrm) و این دامنهها را ارائه میدهد:- فقط config
- Config + credentials + sessions
- بازنشانی کامل (workspace را هم حذف میکند)
Model/Auth
- کلید API Anthropic: اگر
ANTHROPIC_API_KEYموجود باشد از آن استفاده میکند، یا کلید را درخواست میکند، سپس آن را برای استفاده daemon ذخیره میکند. - کلید API Anthropic: گزینه ترجیحی دستیار Anthropic در onboarding/configure.
- setup-token Anthropic: هنوز در onboarding/configure در دسترس است، هرچند OpenClaw اکنون هنگام امکان، استفاده دوباره از Claude CLI را ترجیح میدهد.
- اشتراک OpenAI Code (Codex) (OAuth): جریان مرورگر؛
code#stateرا جایگذاری کنید.- وقتی مدل تنظیم نشده باشد یا از قبل از خانواده OpenAI باشد،
agents.defaults.modelرا از طریق runtime کدکس رویopenai/gpt-5.5تنظیم میکند.
- وقتی مدل تنظیم نشده باشد یا از قبل از خانواده OpenAI باشد،
- اشتراک OpenAI Code (Codex) (جفتسازی دستگاه): جریان جفتسازی مرورگر با یک کد دستگاه کوتاهعمر.
- وقتی مدل تنظیم نشده باشد یا از قبل از خانواده OpenAI باشد،
agents.defaults.modelرا از طریق runtime کدکس رویopenai/gpt-5.5تنظیم میکند.
- وقتی مدل تنظیم نشده باشد یا از قبل از خانواده OpenAI باشد،
- کلید API OpenAI: اگر
OPENAI_API_KEYموجود باشد از آن استفاده میکند، یا کلید را درخواست میکند، سپس آن را در پروفایلهای auth ذخیره میکند.- وقتی مدل تنظیم نشده باشد،
openai/*باشد، یاopenai-codex/*باشد،agents.defaults.modelرا رویopenai/gpt-5.5تنظیم میکند.
- وقتی مدل تنظیم نشده باشد،
- کلید API xAI (Grok):
XAI_API_KEYرا درخواست میکند و xAI را بهعنوان provider مدل پیکربندی میکند. - OpenCode:
OPENCODE_API_KEY(یاOPENCODE_ZEN_API_KEY، آن را از https://opencode.ai/auth بگیرید) را درخواست میکند و به شما اجازه میدهد catalog Zen یا Go را انتخاب کنید. - Ollama: ابتدا Cloud + Local، Cloud only، یا Local only را ارائه میدهد.
Cloud onlyکلیدOLLAMA_API_KEYرا درخواست میکند و ازhttps://ollama.comاستفاده میکند؛ حالتهای متکی به host، URL پایه Ollama را درخواست میکنند، مدلهای موجود را کشف میکنند، و در صورت نیاز مدل محلی انتخابشده را بهطور خودکار pull میکنند؛Cloud + Localهمچنین بررسی میکند که آیا آن host مربوط به Ollama برای دسترسی cloud وارد حساب شده است یا نه. - جزئیات بیشتر: Ollama
- کلید API: کلید را برای شما ذخیره میکند.
- Vercel AI Gateway (proxy چندمدلی):
AI_GATEWAY_API_KEYرا درخواست میکند. - جزئیات بیشتر: Vercel AI Gateway
- Cloudflare AI Gateway: Account ID، Gateway ID، و
CLOUDFLARE_AI_GATEWAY_API_KEYرا درخواست میکند. - جزئیات بیشتر: Cloudflare AI Gateway
- MiniMax: config بهطور خودکار نوشته میشود؛ پیشفرض میزبانیشده
MiniMax-M2.7است. راهاندازی کلید API ازminimax/...استفاده میکند، و راهاندازی OAuth ازminimax-portal/...استفاده میکند. - جزئیات بیشتر: MiniMax
- StepFun: config برای StepFun استاندارد یا Step Plan روی endpointهای چین یا جهانی بهطور خودکار نوشته میشود.
- استاندارد در حال حاضر شامل
step-3.5-flashاست، و Step Plan همچنین شاملstep-3.5-flash-2603است. - جزئیات بیشتر: StepFun
- Synthetic (سازگار با Anthropic):
SYNTHETIC_API_KEYرا درخواست میکند. - جزئیات بیشتر: Synthetic
- Moonshot (Kimi K2): config بهطور خودکار نوشته میشود.
- Kimi Coding: config بهطور خودکار نوشته میشود.
- جزئیات بیشتر: Moonshot AI (Kimi + Kimi Coding)
- رد کردن: هنوز هیچ auth پیکربندی نشده است.
- یک مدل پیشفرض را از گزینههای شناساییشده انتخاب کنید (یا provider/model را دستی وارد کنید). برای بهترین کیفیت و کاهش ریسک prompt-injection، قویترین مدل نسل جدید موجود در پشته provider خود را انتخاب کنید.
- Onboarding یک بررسی مدل اجرا میکند و اگر مدل پیکربندیشده ناشناخته باشد یا auth نداشته باشد، هشدار میدهد.
- حالت ذخیرهسازی کلید API بهطور پیشفرض مقادیر auth-profile متن ساده است. برای ذخیره refهای متکی به env بهجای آن، از
--secret-input-mode refاستفاده کنید (برای مثالkeyRef: { source: "env", provider: "default", id: "OPENAI_API_KEY" }). - پروفایلهای auth در
~/.openclaw/agents/<agentId>/agent/auth-profiles.jsonقرار دارند (کلیدهای API + OAuth).~/.openclaw/credentials/oauth.jsonفقط برای import قدیمی است. - جزئیات بیشتر: /concepts/oauth
Workspace
- پیشفرض
~/.openclaw/workspace(قابل پیکربندی). - فایلهای workspace لازم برای آیین bootstrap agent را seed میکند.
- چیدمان کامل workspace + راهنمای پشتیبانگیری: Agent workspace
Gateway
- Port، bind، حالت auth، نمایش از طریق Tailscale.
- توصیه auth: حتی برای loopback هم Token را نگه دارید تا clientهای WS محلی ملزم به احراز هویت باشند.
- در حالت token، راهاندازی تعاملی این گزینهها را ارائه میدهد:
- تولید/ذخیره token متن ساده (پیشفرض)
- استفاده از SecretRef (انتخابی)
- Quickstart از SecretRefهای موجود
gateway.auth.tokenدر providerهایenv،file، وexecبرای probe onboarding/dashboard bootstrap استفاده دوباره میکند. - اگر آن SecretRef پیکربندی شده باشد اما قابل resolve نباشد، onboarding بهجای افت بیصدای auth زمان اجرا، زودتر با یک پیام رفع مشکل روشن شکست میخورد.
- در حالت password، راهاندازی تعاملی همچنین ذخیرهسازی متن ساده یا SecretRef را پشتیبانی میکند.
- مسیر SecretRef توکن غیرتعاملی:
--gateway-token-ref-env <ENV_VAR>.- به یک env var غیرخالی در محیط پردازش onboarding نیاز دارد.
- نمیتواند با
--gateway-tokenترکیب شود.
- auth را فقط زمانی غیرفعال کنید که به همه پردازشهای محلی کاملا اعتماد دارید.
- bindهای غیر loopback همچنان به auth نیاز دارند.
Channels
- WhatsApp: ورود اختیاری با QR.
- Telegram: توکن bot.
- Discord: توکن bot.
- Google Chat: JSON حساب service + مخاطب webhook.
- Mattermost (plugin): توکن bot + URL پایه.
- Signal: نصب اختیاری
signal-cli+ config حساب. - iMessage: مسیر CLI
imsg+ دسترسی به Messages DB؛ وقتی Gateway خارج از Mac اجرا میشود از یک wrapper SSH استفاده کنید. - امنیت DM: پیشفرض جفتسازی است. نخستین DM یک کد میفرستد؛ با
openclaw pairing approve <channel> <code>تأیید کنید یا از allowlistها استفاده کنید.
Web search
- یک provider پشتیبانیشده مانند Brave، DuckDuckGo، Exa، Firecrawl، Gemini، Grok، Kimi، MiniMax Search، Ollama Web Search، Perplexity، SearXNG، یا Tavily را انتخاب کنید (یا رد کنید).
- providerهای متکی به API میتوانند از env varها یا config موجود برای راهاندازی سریع استفاده کنند؛ providerهای بدون کلید بهجای آن از پیشنیازهای خاص provider خود استفاده میکنند.
- با
--skip-searchرد کنید. - پیکربندی بعدا:
openclaw configure --section web.
Daemon install
- macOS: LaunchAgent
- به session کاربر واردشده نیاز دارد؛ برای headless، از یک LaunchDaemon سفارشی استفاده کنید (ارائه نشده).
- Linux (و Windows از طریق WSL2): systemd user unit
- Onboarding تلاش میکند lingering را از طریق
loginctl enable-linger <user>فعال کند تا Gateway پس از logout فعال بماند. - ممکن است sudo درخواست کند (
/var/lib/systemd/lingerرا مینویسد)؛ ابتدا بدون sudo تلاش میکند.
- Onboarding تلاش میکند lingering را از طریق
- انتخاب runtime: Node (توصیهشده؛ برای WhatsApp/Telegram الزامی). Bun توصیه نمیشود.
- اگر auth توکنی به token نیاز داشته باشد و
gateway.auth.tokenبا SecretRef مدیریت شود، نصب daemon آن را اعتبارسنجی میکند اما مقدارهای token متن ساده resolveشده را در metadata محیط سرویس supervisor پایدار نمیکند. - اگر auth توکنی به token نیاز داشته باشد و SecretRef توکن پیکربندیشده resolveنشده باشد، نصب daemon با راهنمایی قابل اقدام مسدود میشود.
- اگر هم
gateway.auth.tokenو همgateway.auth.passwordپیکربندی شده باشند وgateway.auth.modeتنظیم نشده باشد، نصب daemon تا زمانی که mode صریحا تنظیم شود مسدود میشود.
Health check
- Gateway را شروع میکند (در صورت نیاز) و
openclaw healthرا اجرا میکند. - نکته:
openclaw status --deepprobe سلامت gateway زنده را به خروجی status اضافه میکند، شامل probeهای channel وقتی پشتیبانی شوند (به gateway قابل دسترسی نیاز دارد).
Skills (recommended)
- Skills موجود را میخواند و نیازمندیها را بررسی میکند.
- به شما اجازه میدهد یک manager برای node انتخاب کنید: npm / pnpm (bun توصیه نمیشود).
- وابستگیهای اختیاری را نصب میکند (برخی در macOS از Homebrew استفاده میکنند).
Finish
- خلاصه + گامهای بعدی، شامل prompt میخواهید agent خود را چطور hatch کنید؟ برای Terminal، Browser، یا بعدا.
حالت غیرتعاملی
برای خودکارسازی یا اسکریپتنویسی onboarding از --non-interactive استفاده کنید:
openclaw onboard --non-interactive \ --mode local \ --auth-choice apiKey \ --anthropic-api-key "$ANTHROPIC_API_KEY" \ --gateway-port 18789 \ --gateway-bind loopback \ --install-daemon \ --daemon-runtime node \ --skip-skillsبرای خلاصه قابل خواندن توسط ماشین، --json را اضافه کنید.
SecretRef توکن Gateway در حالت غیرتعاملی:
export OPENCLAW_GATEWAY_TOKEN="your-token"openclaw onboard --non-interactive \ --mode local \ --auth-choice skip \ --gateway-auth token \ --gateway-token-ref-env OPENCLAW_GATEWAY_TOKEN--gateway-token و --gateway-token-ref-env با یکدیگر ناسازگارند.
نمونههای دستور مخصوص provider در CLI Automation قرار دارند. از این صفحه مرجع برای معنای flagها و ترتیب stepها استفاده کنید.
افزودن agent (غیرتعاملی)
openclaw agents add work \ --workspace ~/.openclaw/workspace-work \ --model openai/gpt-5.5 \ --bind whatsapp:biz \ --non-interactive \ --jsonRPC wizard مربوط به Gateway
Gateway جریان onboarding را از طریق RPC (wizard.start، wizard.next، wizard.cancel، wizard.status) در معرض استفاده قرار میدهد.
Clientها (app macOS، Control UI) میتوانند stepها را بدون پیادهسازی دوباره منطق onboarding نمایش دهند.
راهاندازی Signal (signal-cli)
Onboarding میتواند signal-cli را از releaseهای GitHub نصب کند:
- asset مناسب release را دانلود میکند.
- آن را زیر
~/.openclaw/tools/signal-cli/<version>/ذخیره میکند. channels.signal.cliPathرا در config شما مینویسد.
نکتهها:
- buildهای JVM به Java 21 نیاز دارند.
- وقتی buildهای native موجود باشند، از آنها استفاده میشود.
- Windows از WSL2 استفاده میکند؛ نصب signal-cli جریان Linux را داخل WSL دنبال میکند.
آنچه wizard مینویسد
فیلدهای معمول در ~/.openclaw/openclaw.json:
agents.defaults.workspaceagents.defaults.model/models.providers(اگر Minimax انتخاب شده باشد)tools.profile(مقدار پیشفرض راهاندازی محلی، وقتی تنظیم نشده باشد،"coding"است؛ مقادیر صریح موجود حفظ میشوند)gateway.*(حالت، bind، احراز هویت، tailscale)session.dmScope(جزئیات رفتار: مرجع راهاندازی CLI)channels.telegram.botToken،channels.discord.token،channels.matrix.*،channels.signal.*،channels.imessage.*- فهرستهای مجاز کانالها (Slack/Discord/Matrix/Microsoft Teams) وقتی در طول اعلانها انتخابشان میکنید (نامها در صورت امکان به شناسهها تبدیل میشوند).
skills.install.nodeManagersetup --node-managerمقدارهایnpm،pnpmیاbunرا میپذیرد.- پیکربندی دستی همچنان میتواند با تنظیم مستقیم
skills.install.nodeManagerازyarnاستفاده کند.
wizard.lastRunAtwizard.lastRunVersionwizard.lastRunCommitwizard.lastRunCommandwizard.lastRunMode
openclaw agents add مقدارهای agents.list[] و bindings اختیاری را مینویسد.
اعتبارنامههای WhatsApp زیر ~/.openclaw/credentials/whatsapp/<accountId>/ قرار میگیرند.
نشستها زیر ~/.openclaw/agents/<agentId>/sessions/ ذخیره میشوند.
برخی کانالها بهصورت Plugin ارائه میشوند. وقتی یکی را هنگام راهاندازی انتخاب کنید، فرایند راهاندازی پیش از امکان پیکربندی آن، برای نصب آن (npm یا یک مسیر محلی) از شما درخواست میکند.
مستندات مرتبط
- نمای کلی راهاندازی: راهاندازی (CLI)
- راهاندازی برنامه macOS: راهاندازی
- مرجع پیکربندی: پیکربندی Gateway
- ارائهدهندگان: WhatsApp، Telegram، Discord، Google Chat، Signal، iMessage
- Skills: Skills، پیکربندی Skills