Masofaviy kirish (SSH, tunnellar va tailnetlar)
Ushbu repo “SSH orqali masofaviy ulanish”ni qo‘llab-quvvatlaydi — bunda bitta Gateway (master) ajratilgan xostda (desktop/server) ishga tushiriladi va mijozlar unga ulanadi.- Operatorlar (siz / macOS ilovasi) uchun: SSH tunnellash — universal zaxira usul.
- Tugunlar (iOS/Android va kelajakdagi qurilmalar) uchun: Gateway WebSocket’ga ulanadi (zaruratga ko‘ra LAN/tailnet yoki SSH tunneli orqali).
Asosiy g‘oya
- Gateway WebSocket sozlangan portingizda (standart bo‘yicha 18789) loopback’ga bog‘lanadi.
- Masofadan foydalanish uchun siz ushbu loopback portni SSH orqali forward qilasiz (yoki tailnet/VPN ishlatib, kamroq tunnellaysiz).
Keng tarqalgan VPN/tailnet sozlamalari (agent qayerda joylashadi)
Think of the Gateway host as “where the agent lives.” It owns sessions, auth profiles, channels, and state. Your laptop/desktop (and nodes) connect to that host.1. Always-on Gateway in your tailnet (VPS or home server)
Run the Gateway on a persistent host and reach it via Tailscale or SSH.- Best UX: keep
gateway.bind: "loopback"and use Tailscale Serve for the Control UI. - Fallback: keep loopback + SSH tunnel from any machine that needs access.
- Examples: exe.dev (easy VM) or Hetzner (production VPS).
2. Home desktop runs the Gateway, laptop is remote control
The laptop does not run the agent. It connects remotely:- Use the macOS app’s Remote over SSH mode (Settings → General → “OpenClaw runs”).
- The app opens and manages the tunnel, so WebChat + health checks “just work.”
3. Laptop runs the Gateway, remote access from other machines
Keep the Gateway local but expose it safely:- SSH tunnel to the laptop from other machines, or
- Tailscale Serve the Control UI and keep the Gateway loopback-only.
Command flow (what runs where)
One gateway service owns state + channels. Nodes are peripherals. Flow example (Telegram → node):- Telegram message arrives at the Gateway.
- Gateway runs the agent and decides whether to call a node tool.
- Gateway calls the node over the Gateway WebSocket (
node.*RPC). - Node returns the result; Gateway replies back out to Telegram.
- Nodes do not run the gateway service. Only one gateway should run per host unless you intentionally run isolated profiles (see Multiple gateways).
- macOS app “node mode” is just a node client over the Gateway WebSocket.
SSH tunnel (CLI + tools)
Create a local tunnel to the remote Gateway WS:openclaw healthandopenclaw status --deepnow reach the remote gateway viaws://127.0.0.1:18789.openclaw gateway {status,health,send,agent,call}can also target the forwarded URL via--urlwhen needed.
18789 with your configured gateway.port (or --port/OPENCLAW_GATEWAY_PORT).
Note: when you pass --url, the CLI does not fall back to config or environment credentials.
Include --token or --password explicitly. Missing explicit credentials is an error.
CLI remote defaults
You can persist a remote target so CLI commands use it by default:ws://127.0.0.1:18789 holatida qoldiring va avval SSH tunnelini oching.
SSH orqali Chat UI
WebChat endi alohida HTTP portdan foydalanmaydi. SwiftUI chat UI to‘g‘ridan-to‘g‘ri Gateway WebSocket’iga ulanadi.- SSH orqali
18789ni forward qiling (yuqoriga qarang), so‘ng klientlarniws://127.0.0.1:18789ga ulang. - macOS’da tunnelni avtomatik boshqaradigan ilovaning “Remote over SSH” rejimini afzal ko‘ring.
macOS ilovasi “Remote over SSH”
macOS menyu panelidagi ilova bir xil sozlamani boshidan oxirigacha boshqarishi mumkin (masofaviy holat tekshiruvlari, WebChat va Voice Wake forwarding). Runbook: macOS remote access.Xavfsizlik qoidalari (remote/VPN)
Qisqa versiya: Gateway’ni loopback-only holatda saqlang, agar bind kerakligiga ishonchingiz komil bo‘lmasa.- Loopback + SSH/Tailscale Serve eng xavfsiz standartdir (ommaviy ochilishsiz).
- Non-loopback bindlar (
lan/tailnet/custom, yoki loopback mavjud bo‘lmagandaauto) auth tokenlar/parollardan foydalanishi shart. gateway.remote.tokenfaqat masofaviy CLI chaqiriqlari uchun — u lokal auth’ni yoqmaydi.gateway.remote.tlsFingerprintwss://ishlatilganda masofaviy TLS sertifikatini pin qiladi.- Tailscale Serve
gateway.auth.allowTailscale: truebo‘lganda identifikatsiya sarlavhalari orqali autentifikatsiya qilishi mumkin. Agar tokenlar/parollarni xohlasangiz, unifalsega o‘rnating. - Brauzer boshqaruvini operator kirishi kabi ko‘ring: faqat tailnet + ongli node juftlash.