OpenClaw kan Tailscale Serve (tailnet) of Funnel (publiek) automatisch configureren voor het Gateway-dashboard en de WebSocket-poort. Hierdoor blijft de Gateway gebonden aan loopback terwijl Tailscale HTTPS, routering en (voor Serve) identiteitsheaders levert.Documentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Modi
serve: alleen-tailnet Serve viatailscale serve. De gateway blijft op127.0.0.1.funnel: publieke HTTPS viatailscale funnel. OpenClaw vereist een gedeeld wachtwoord.off: standaard (geen Tailscale-automatisering).
off betekent dat OpenClaw Serve of Funnel niet beheert; het betekent niet dat de
lokale Tailscale-daemon is gestopt of is uitgelogd.
Authenticatie
Stelgateway.auth.mode in om de handshake te beheren:
none(alleen private ingress)token(standaard wanneerOPENCLAW_GATEWAY_TOKENis ingesteld)password(gedeeld geheim viaOPENCLAW_GATEWAY_PASSWORDof configuratie)trusted-proxy(identiteitsbewuste reverse proxy; zie Authenticatie via vertrouwde proxy)
tailscale.mode = "serve" en gateway.auth.allowTailscale true is,
kan authenticatie voor de Control UI/WebSocket Tailscale-identiteitsheaders
(tailscale-user-login) gebruiken zonder een token/wachtwoord op te geven. OpenClaw verifieert
de identiteit door het x-forwarded-for-adres op te lossen via de lokale Tailscale-
daemon (tailscale whois) en het te vergelijken met de header voordat deze wordt geaccepteerd.
OpenClaw behandelt een aanvraag alleen als Serve wanneer deze vanaf loopback binnenkomt met
Tailscale’s x-forwarded-for, x-forwarded-proto en x-forwarded-host-
headers.
Voor Control UI-operatorsessies die browserapparaatidentiteit bevatten, slaat dit
geverifieerde Serve-pad ook de retourstap voor apparaatkoppeling over. Het omzeilt
browserapparaatidentiteit niet: clients zonder apparaat worden nog steeds geweigerd, en node-rol-
of niet-Control UI-WebSocket-verbindingen volgen nog steeds de normale koppelings- en
authenticatiecontroles.
HTTP API-eindpunten (bijvoorbeeld /v1/*, /tools/invoke en /api/channels/*)
gebruiken geen authenticatie via Tailscale-identiteitsheaders. Ze volgen nog steeds de
normale HTTP-authenticatiemodus van de gateway: standaard authenticatie met gedeeld geheim,
of een bewust geconfigureerde trusted-proxy- / private-ingress-none-opzet.
Deze tokenloze stroom gaat ervan uit dat de gatewayhost wordt vertrouwd. Als niet-vertrouwde lokale code
op dezelfde host kan worden uitgevoerd, schakel dan gateway.auth.allowTailscale uit en vereis
in plaats daarvan token-/wachtwoordauthenticatie.
Om expliciete referenties met gedeeld geheim te vereisen, stel gateway.auth.allowTailscale: false
in en gebruik gateway.auth.mode: "token" of "password".
Configuratievoorbeelden
Alleen-tailnet (Serve)
https://<magicdns>/ (of je geconfigureerde gateway.controlUi.basePath)
Alleen-tailnet (binden aan Tailnet-IP)
Gebruik dit wanneer je wilt dat de Gateway rechtstreeks luistert op het Tailnet-IP (geen Serve/Funnel).- Control UI:
http://<tailscale-ip>:18789/ - WebSocket:
ws://<tailscale-ip>:18789
Loopback (
http://127.0.0.1:18789) werkt niet in deze modus.Publiek internet (Funnel + gedeeld wachtwoord)
OPENCLAW_GATEWAY_PASSWORD boven het vastleggen van een wachtwoord op schijf.
CLI-voorbeelden
Opmerkingen
- Tailscale Serve/Funnel vereist dat de
tailscaleCLI is geïnstalleerd en ingelogd. tailscale.mode: "funnel"weigert te starten tenzij de authenticatiemoduspasswordis, om publieke blootstelling te voorkomen.- Stel
gateway.tailscale.resetOnExitin als je wilt dat OpenClaw de configuratie vantailscale serveoftailscale funnelongedaan maakt bij afsluiten. - Stel
gateway.tailscale.preserveFunnel: truein om een extern geconfigureerdetailscale funnel-route actief te houden tijdens gateway-herstarts. Wanneer dit is ingeschakeld en de gateway draait inmode: "serve", controleert OpenClawtailscale funnel statusvoordat Serve opnieuw wordt toegepast en slaat dit over wanneer een Funnel-route de gatewaypoort al afdekt. Het door OpenClaw beheerde beleid voor Funnel met alleen wachtwoord blijft ongewijzigd. gateway.bind: "tailnet"is een directe Tailnet-binding (geen HTTPS, geen Serve/Funnel).gateway.bind: "auto"geeft de voorkeur aan loopback; gebruiktailnetals je alleen-tailnet wilt.- Serve/Funnel stellen alleen de Gateway Control UI + WS bloot. Nodes maken verbinding via hetzelfde Gateway WS-eindpunt, dus Serve kan werken voor nodetoegang.
Browserbesturing (externe Gateway + lokale browser)
Als je de Gateway op de ene machine draait maar een browser op een andere machine wilt aansturen, draai dan een nodehost op de browsermachine en houd beide op dezelfde tailnet. De Gateway proxyt browseracties naar de node; er is geen aparte controleserver of Serve-URL nodig. Vermijd Funnel voor browserbesturing; behandel nodekoppeling zoals operatortoegang.Tailscale-vereisten + limieten
- Serve vereist dat HTTPS is ingeschakeld voor je tailnet; de CLI vraagt erom als dit ontbreekt.
- Serve injecteert Tailscale-identiteitsheaders; Funnel doet dat niet.
- Funnel vereist Tailscale v1.38.3+, MagicDNS, ingeschakelde HTTPS en een funnel-nodeattribuut.
- Funnel ondersteunt alleen poorten
443,8443en10000via TLS. - Funnel op macOS vereist de opensourcevariant van de Tailscale-app.
Meer informatie
- Overzicht van Tailscale Serve: https://tailscale.com/kb/1312/serve
tailscale serve-opdracht: https://tailscale.com/kb/1242/tailscale-serve- Overzicht van Tailscale Funnel: https://tailscale.com/kb/1223/tailscale-funnel
tailscale funnel-opdracht: https://tailscale.com/kb/1311/tailscale-funnel