TypeBox como fonte da verdade do protocolo
Última atualização: 2026-01-10 TypeBox é uma biblioteca de schemas com foco em TypeScript. Nós a usamos para definir o protocolo WebSocket do Gateway (handshake, request/response, eventos do servidor). Esses schemas orientam validação em runtime, exportação para JSON Schema e codegen Swift para o app macOS. Uma única fonte da verdade; todo o resto é gerado. Se você quiser o contexto de protocolo em nível mais alto, comece por Gateway architecture.Modelo mental (30 segundos)
Cada mensagem WS do Gateway é um de três frames:- Request:
{ type: "req", id, method, params } - Response:
{ type: "res", id, ok, payload | error } - Event:
{ type: "event", event, payload, seq?, stateVersion? }
connect. Depois disso, 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 | Observações |
|---|---|---|
| Core | connect, health, status | connect deve vir primeiro |
| Messaging | send, agent, agent.wait, system-event, logs.tail | efeitos colaterais exigem idempotencyKey |
| Chat | chat.history, chat.send, chat.abort | WebChat usa estes |
| Sessions | sessions.list, sessions.patch, sessions.delete | administração de sessão |
| Automation | wake, cron.list, cron.run, cron.runs | controle de wake + cron |
| Nodes | node.list, node.invoke, node.pair.* | Gateway WS + ações de node |
| Events | tick, presence, agent, chat, health, shutdown | push do servidor |
src/gateway/server-methods-list.ts (listGatewayMethods, GATEWAY_EVENTS).
Onde ficam os schemas
- Fonte:
src/gateway/protocol/schema.ts - Validadores de runtime (AJV):
src/gateway/protocol/index.ts - Registro anunciado de recursos/descoberta:
src/gateway/server-methods-list.ts - Handshake do servidor + despacho de método:
src/gateway/server.impl.ts - Cliente node:
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 foi commitada
Como os schemas são usados em runtime
- Lado do servidor: todo frame de entrada é validado com AJV. O handshake só
aceita um request
connectcujos params correspondam aConnectParams. - Lado do cliente: o cliente JS valida frames de evento e resposta antes de usá-los.
- Descoberta de recursos: o Gateway envia uma lista conservadora de
features.methodsefeatures.eventsemhello-oka partir delistGatewayMethods()eGATEWAY_EVENTS. - Essa lista de descoberta não é um dump gerado de todos os helpers chamáveis em
coreGatewayHandlers; alguns RPCs helper são implementados emsrc/gateway/server-methods/*.tssem serem enumerados na lista de recursos anunciada.
Exemplos de frame
Connect (primeira mensagem):Cliente mínimo (Node.js)
Menor fluxo útil: connect + health.Exemplo prático: adicionar um método de ponta a ponta
Exemplo: adicionar um novo requestsystem.echo que retorna { ok: true, text }.
- Schema (fonte da verdade)
src/gateway/protocol/schema.ts:
ProtocolSchemas e exporte os tipos:
- Validação
src/gateway/protocol/index.ts, exporte um validador AJV:
- Comportamento do servidor
src/gateway/server-methods/system.ts:
src/gateway/server-methods.ts (que já faz merge de systemHandlers),
depois adicione "system.echo" à entrada de listGatewayMethods em
src/gateway/server-methods-list.ts.
Se o método puder ser chamado por clientes operadores ou node, também classifique-o em
src/gateway/method-scopes.ts para que a imposição de escopo e a divulgação de recursos
em hello-ok permaneçam alinhadas.
- Regenerar
- Testes + documentação
src/gateway/server.*.test.ts e registre 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 antigos.
Padrões e convenções de schema
- A maioria dos objetos usa
additionalProperties: falsepara payloads estritos. NonEmptyStringé o padrão para IDs e nomes de método/evento.- O
GatewayFramede nível superior usa um discriminador emtype. - Métodos com efeitos colaterais normalmente exigem um
idempotencyKeyem params (exemplo:send,poll,agent,chat.send). agentaceitainternalEventsopcionais para contexto de orquestração gerado em runtime (por exemplo, transferência de conclusão de tarefa de subagente/cron); trate isso como superfície de API interna.
JSON de schema ativo
O JSON Schema gerado fica no repositório emdist/protocol.schema.json. O
arquivo bruto publicado normalmente está disponível em:
Quando você altera schemas
- Atualize os schemas TypeBox.
- Registre o método/evento em
src/gateway/server-methods-list.ts. - Atualize
src/gateway/method-scopes.tsquando o novo RPC precisar de classificação de escopo de operador ou node. - Execute
pnpm protocol:check. - Faça commit do schema regenerado + modelos Swift.