Masofaviy OpenClaw (macOS ⇄ masofaviy host)
Ushbu oqim macOS ilovasiga boshqa hostda (desktop/server) ishlayotgan OpenClaw gateway uchun to‘liq masofaviy boshqaruv sifatida ishlash imkonini beradi. Bu ilovaning Remote over SSH (masofadan ishga tushirish) funksiyasidir. Barcha funksiyalar — sog‘liq tekshiruvlari, Voice Wake forwarding va Web Chat — Settings → General dagi bir xil masofaviy SSH konfiguratsiyasidan foydalanadi.Rejimlar
- Local (this Mac): Hammasi noutbukda ishlaydi. SSH ishlatilmaydi.
- Remote over SSH (default): OpenClaw buyruqlari masofaviy hostda bajariladi. Mac ilova
-o BatchModebilan, tanlangan identifikatsiya/kalit va lokal port-forward bilan SSH ulanishini ochadi. - Remote direct (ws/wss): SSH tunneli yo‘q. Mac ilova gateway URL’iga to‘g‘ridan-to‘g‘ri ulanadi (masalan, Tailscale Serve yoki ommaviy HTTPS reverse proxy orqali).
Masofaviy transportlar
Masofaviy rejim ikki xil transportni qo‘llab-quvvatlaydi:- SSH tunnel (standart): Gateway portini localhost’ga yo‘naltirish uchun
ssh -N -L ...dan foydalanadi. Tunnel loopback bo‘lgani uchun gateway node IP’ni127.0.0.1sifatida ko‘radi. - Direct (ws/wss): Gateway URL’iga bevosita ulanadi. Gateway haqiqiy mijoz IP’ni ko‘radi.
Masofaviy hostdagi talablar
- Node + pnpm ni o‘rnating va OpenClaw CLI’ni build/o‘rnating (
pnpm install && pnpm build && pnpm link --global). - Interaktiv bo‘lmagan shelllar uchun
openclawPATH’da ekanini ta’minlang (zarur bo‘lsa/usr/local/binyoki/opt/homebrew/binga symlink qiling). - Kalit autentifikatsiyasi bilan SSH’ni oching. LAN’dan tashqarida barqaror ulanish uchun Tailscale IP’larini tavsiya qilamiz.
macOS ilovasini sozlash
- Sozlamalar → Umumiy bo‘limini oching.
- OpenClaw runs ostida Remote over SSH ni tanlang va quyidagilarni sozlang:
- Transport: SSH tunnel or Direct (ws/wss).
- SSH target:
user@host(optional:port).- Agar gateway bir xil LAN tarmog‘ida bo‘lsa va Bonjour orqali e’lon qilinsa, ushbu maydonni avtomatik to‘ldirish uchun uni aniqlangan ro‘yxatdan tanlang.
- Gateway URL (Direct only):
wss://gateway.example.ts.net(orws://...for local/LAN). - Identity file (kengaytirilgan): kalitingizga yo‘l.
- Project root (kengaytirilgan): buyruqlar uchun ishlatiladigan masofaviy checkout yo‘li.
- CLI path (kengaytirilgan): ishga tushiriladigan
openclawkirish nuqtasi/binar fayliga ixtiyoriy yo‘l (e’lon qilinganda avtomatik to‘ldiriladi).
- Hit Test remote. Success indicates the remote
openclaw status --jsonruns correctly. Failures usually mean PATH/CLI issues; exit 127 means the CLI isn’t found remotely. - Health checks and Web Chat will now run through this SSH tunnel automatically.
Web Chat
- SSH tunnel: Web Chat connects to the gateway over the forwarded WebSocket control port (default 18789).
- Direct (ws/wss): Web Chat connects straight to the configured gateway URL.
- There is no separate WebChat HTTP server anymore.
Permissions
- The remote host needs the same TCC approvals as local (Automation, Accessibility, Screen Recording, Microphone, Speech Recognition, Notifications). Run onboarding on that machine to grant them once.
- Nodes advertise their permission state via
node.list/node.describeso agents know what’s available.
Security notes
- Prefer loopback binds on the remote host and connect via SSH or Tailscale.
- If you bind the Gateway to a non-loopback interface, require token/password auth.
- See Security and Tailscale.
WhatsApp login flow (remote)
- Run
openclaw channels login --verboseon the remote host. Scan the QR with WhatsApp on your phone. - Re-run login on that host if auth expires. Health check will surface link problems.
Troubleshooting
- exit 127 / not found:
openclawisn’t on PATH for non-login shells. Add it to/etc/paths, your shell rc, or symlink into/usr/local/bin//opt/homebrew/bin. - Health probe failed: check SSH reachability, PATH, and that Baileys is logged in (
openclaw status --json). - Web Chat stuck: confirm the gateway is running on the remote host and the forwarded port matches the gateway WS port; the UI requires a healthy WS connection.
- Node IP shows 127.0.0.1: expected with the SSH tunnel. Switch Transport to Direct (ws/wss) if you want the gateway to see the real client IP.
- Voice Wake: trigger phrases are forwarded automatically in remote mode; no separate forwarder is needed.
Notification sounds
Pick sounds per notification from scripts withopenclaw and node.invoke, e.g.: