TypeBox como fonte de verdade do protocolo
Última atualização: 2026-01-10 TypeBox é uma biblioteca de esquemas orientada a TypeScript. Nós a usamos para definir o protocolo WebSocket do Gateway (handshake, request/response, eventos do servidor). Esses esquemas conduzem a validação em runtime, a exportação para JSON Schema e o codegen Swift para o app macOS. Uma única fonte de verdade; todo o resto é gerado. Se você quiser o contexto de protocolo em nível mais alto, comece por Arquitetura do Gateway.Modelo mental (30 segundos)
Toda mensagem WS do Gateway é um de três frames:- Requisição:
{ type: "req", id, method, params } - Resposta:
{ type: "res", id, ok, payload | error } - Evento:
{ type: "event", event, payload, seq?, stateVersion? }
connect. Depois disso, os clientes podem chamar
métodos (por exemplo, health, send, chat.send) e assinar eventos (por exemplo,
presence, tick, agent).
Fluxo de conexão (mínimo):
| Categoria | Exemplos | Notas |
|---|---|---|
| Núcleo | connect, health, status | connect deve ser o primeiro |
| Mensagens | send, poll, agent, agent.wait | efeitos colaterais exigem idempotencyKey |
| Chat | chat.history, chat.send, chat.abort, chat.inject | O WebChat usa estes |
| Sessions | sessions.list, sessions.patch, sessions.delete | administração de sessão |
| Nodes | node.list, node.invoke, node.pair.* | WS do Gateway + ações de nó |
| Events | tick, presence, agent, chat, health, shutdown | push do servidor |
src/gateway/server.ts (METHODS, EVENTS).
Onde os esquemas ficam
- Fonte:
src/gateway/protocol/schema.ts - Validadores em runtime (AJV):
src/gateway/protocol/index.ts - Handshake do servidor + despacho de métodos:
src/gateway/server.ts - Cliente de nó:
src/gateway/client.ts - JSON Schema gerado:
dist/protocol.schema.json - Modelos Swift gerados:
apps/macos/Sources/OpenClawProtocol/GatewayModels.swift
Pipeline atual
pnpm protocol:gen- grava JSON Schema (draft‑07) em
dist/protocol.schema.json
- grava JSON Schema (draft‑07) em
pnpm protocol:gen:swift- gera modelos Swift do gateway
pnpm protocol:check- executa ambos os geradores e verifica se a saída está commitada
Como os esquemas são usados em runtime
- Lado do servidor: todo frame de entrada é validado com AJV. O handshake só
aceita uma request
connectcujos params correspondem aConnectParams. - Lado do cliente: o cliente JS valida frames de evento e de resposta antes de usá-los.
- Superfície de métodos: o Gateway anuncia os
methodseeventssuportados emhello-ok.
Frames de exemplo
Conectar (primeira mensagem):Cliente mínimo (Node.js)
Fluxo útil mínimo: conectar + health.Exemplo trabalhado: adicionar um método de ponta a ponta
Exemplo: adicionar uma nova requestsystem.echo que retorna { ok: true, text }.
- Esquema (fonte de verdade)
src/gateway/protocol/schema.ts:
ProtocolSchemas e exportar tipos:
- Validação
src/gateway/protocol/index.ts, exportar um validador AJV:
- Comportamento do servidor
src/gateway/server-methods/system.ts:
src/gateway/server-methods.ts (já faz merge de systemHandlers),
depois adicionar "system.echo" a METHODS em src/gateway/server.ts.
- Regenerar
- Testes + docs
src/gateway/server.*.test.ts e anotar o método na documentação.
Comportamento do codegen Swift
O gerador Swift emite:- Enum
GatewayFramecom casosreq,res,eventeunknown - Structs/enums de payload fortemente tipados
- Valores
ErrorCodeeGATEWAY_PROTOCOL_VERSION
Versionamento + compatibilidade
PROTOCOL_VERSIONfica emsrc/gateway/protocol/schema.ts.- Clientes enviam
minProtocol+maxProtocol; o servidor rejeita incompatibilidades. - Os modelos Swift mantêm tipos de frame desconhecidos para evitar quebrar clientes mais antigos.
Padrões e convenções de esquema
- A maioria dos objetos usa
additionalProperties: falsepara payloads estritos. NonEmptyStringé o padrão para IDs e nomes de métodos/eventos.- O
GatewayFramede nível superior usa um discriminador emtype. - Métodos com efeitos colaterais geralmente exigem um
idempotencyKeynos params (exemplo:send,poll,agent,chat.send).
JSON do esquema ao vivo
O JSON Schema gerado está no repositório emdist/protocol.schema.json. O
arquivo bruto publicado normalmente está disponível em:
Quando você muda esquemas
- Atualize os esquemas TypeBox.
- Execute
pnpm protocol:check. - Faça commit do esquema regenerado + modelos Swift.