Gateway-protokoll (WebSocket)
Gateway WS-protokollet är enda styrplan + nodtransport för OpenClaw. Alla klienter (CLI, web UI, macOS app, iOS/Android noder, headless noder) ansluter via WebSocket och deklarerar sin roll + scope vid handskakningstid.Transport
- WebSocket, textramar med JSON-payloads.
- Första ramen måste vara en
connect-begäran.
Handskakning (anslutning)
Gateway → Klient (utmaning före anslutning):hello-ok även:
Nodexempel
Inramning
- Begäran:
{type:"req", id, method, params} - Svar:
{type:"res", id, ok, payload|error} - Händelse:
{type:"event", event, payload, seq?, stateVersion?}
Roller + omfattningar
Roller
operator= kontrollplansklient (CLI/UI/automation).node= kapabilitetsvärd (kamera/skärm/canvas/system.run).
Omfattningar (operatör)
Vanliga omfattningar:operator.readoperator.writeoperator.adminoperator.approvalsoperator.pairing
Kapaciteter/kommandon/behörigheter (nod)
Noder deklarerar kapabilitetsanspråk vid anslutning:caps: övergripande kapabilitetskategorier.commands: tillåtelselista för kommandon som får anropas.permissions: granulära växlar (t.ex.screen.record,camera.capture).
Närvaro
system-presencereturnerar poster nycklade per enhetsidentitet.- Närvaroposter inkluderar
deviceId,rolesochscopesså att UI:er kan visa en enda rad per enhet även när den ansluter som både operatör och nod.
Hjälpmetoder för noder
- Noder kan anropa
skills.binsför att hämta den aktuella listan över skill-exekverbara filer för automatiska tillåtelsekontroller.
Exec-godkännanden
- När en exec-begäran behöver godkännande sänder gatewayn
exec.approval.requested. - Operatörsklienter löser detta genom att anropa
exec.approval.resolve(kräver omfattningenoperator.approvals).
Versionering
PROTOCOL_VERSIONfinns isrc/gateway/protocol/schema.ts.- Klienter skickar
minProtocol+maxProtocol; servern avvisar avvikelser. - Scheman + modeller genereras från TypeBox-definitioner:
pnpm protocol:genpnpm protocol:gen:swiftpnpm protocol:check
Autentisering
- Om
OPENCLAW_GATEWAY_TOKEN(eller--token) är inställd måsteconnect.params.auth.tokenmatcha, annars stängs socketen. - Efter parning utfärdar Gatewayen en enhetskoden som omfattades av anslutningen
roll + omfattning. Det returneras i
hello-ok.auth.deviceTokenoch bör vara ihärdigt av klienten för framtida anslutningar. - Enhetstoken kan roteras/återkallas via
device.token.rotateochdevice.token.revoke(kräver omfattningenoperator.pairing).
Enhetsidentitet + parning
- Noder bör inkludera en stabil enhetsidentitet (
device.id) härledd från ett nyckelparsfingeravtryck. - Gateways utfärdar token per enhet + roll.
- Parningstillstånd krävs för nya enhets-ID:n om inte lokal automatisk godkännande är aktiverat.
- Lokala anslutningar inkluderar loopback och gateway-värdens egen tailnet-adress (så att same-host-tailnet-bindningar fortfarande kan auto-godkännas).
- Alla WS-klienter måste inkludera
device-identitet underconnect(operator + node). Control UI kan utelämna det bara närgateway.controlUi.allowInsecureAuthär aktiverat (ellergateway.controlUi.dangerouslyDisableDeviceAuthför användning med glasbrott). - Icke-lokala anslutningar måste signera den serverlevererade
connect.challenge-noncen.
TLS + pinning
- TLS stöds för WS-anslutningar.
- Klienter kan valfritt nåla gateway-certifikatets fingeravtryck (se konfigen
gateway.tlssamtgateway.remote.tlsFingerprinteller CLI--tls-fingerprint).
Omfattning
Detta protokoll exponerar hela gateway API (status, kanaler, modeller, chatt, agent, sessioner, noder, godkännanden, etc.). Den exakta ytan definieras av scheman TypeBox isrc/gateway/protocol/schema.ts.