TypeBox to biblioteka schematów zorientowana na TypeScript. Używamy jej do definiowania protokołu WebSocket Gateway (handshake, żądanie/odpowiedź, zdarzenia serwera). Te schematy napędzają walidację w czasie działania, eksport JSON Schema i generowanie kodu Swift dla aplikacji macOS. Jedno źródło prawdy; cała reszta jest generowana. Jeśli chcesz poznać kontekst protokołu na wyższym poziomie, zacznij od architektury Gateway.Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Model myślowy (30 sekund)
Każda wiadomość Gateway WS jest jedną z trzech ramek:- Żądanie:
{ type: "req", id, method, params } - Odpowiedź:
{ type: "res", id, ok, payload | error } - Zdarzenie:
{ type: "event", event, payload, seq?, stateVersion? }
connect. Następnie klienci mogą wywoływać
metody (np. health, send, chat.send) i subskrybować zdarzenia (np.
presence, tick, agent).
Przepływ połączenia (minimalny):
| Kategoria | Przykłady | Uwagi |
|---|---|---|
| Rdzeń | connect, health, status | connect musi być pierwsze |
| Wiadomości | send, agent, agent.wait, system-event, logs.tail | skutki uboczne wymagają idempotencyKey |
| Czat | chat.history, chat.send, chat.abort | WebChat ich używa |
| Sesje | sessions.list, sessions.patch, sessions.delete | administracja sesjami |
| Automatyzacja | wake, cron.list, cron.run, cron.runs | sterowanie wybudzaniem i cronem |
| Węzły | node.list, node.invoke, node.pair.* | Gateway WS + działania Node |
| Zdarzenia | tick, presence, agent, chat, health, shutdown | wypychanie z serwera |
src/gateway/server-methods-list.ts (listGatewayMethods, GATEWAY_EVENTS).
Gdzie znajdują się schematy
- Źródło:
src/gateway/protocol/schema.ts - Walidatory w czasie działania (AJV):
src/gateway/protocol/index.ts - Reklamowany rejestr funkcji/wykrywania:
src/gateway/server-methods-list.ts - Handshake serwera + dispatch metod:
src/gateway/server.impl.ts - Klient Node:
src/gateway/client.ts - Wygenerowany JSON Schema:
dist/protocol.schema.json - Wygenerowane modele Swift:
apps/macos/Sources/OpenClawProtocol/GatewayModels.swift
Obecny pipeline
pnpm protocol:gen- zapisuje JSON Schema (draft-07) do
dist/protocol.schema.json
- zapisuje JSON Schema (draft-07) do
pnpm protocol:gen:swift- generuje modele Gateway w Swift
pnpm protocol:check- uruchamia oba generatory i sprawdza, czy wynik jest skomitowany
Jak schematy są używane w czasie działania
- Po stronie serwera: każda przychodząca ramka jest walidowana za pomocą AJV. Handshake akceptuje tylko
żądanie
connect, którego parametry pasują doConnectParams. - Po stronie klienta: klient JS waliduje ramki zdarzeń i odpowiedzi przed ich użyciem.
- Wykrywanie funkcji: Gateway wysyła konserwatywną listę
features.methodsifeatures.eventswhello-okzlistGatewayMethods()orazGATEWAY_EVENTS. - Ta lista wykrywania nie jest wygenerowanym zrzutem każdego możliwego do wywołania helpera w
coreGatewayHandlers; niektóre pomocnicze RPC są zaimplementowane wsrc/gateway/server-methods/*.ts, ale nie są wyliczone na reklamowanej liście funkcji.
Przykładowe ramki
Connect (pierwsza wiadomość):Minimalny klient (Node.js)
Najmniejszy użyteczny przepływ: połączenie + health.Przykład krok po kroku: dodanie metody od początku do końca
Przykład: dodaj nowe żądaniesystem.echo, które zwraca { ok: true, text }.
- Schemat (źródło prawdy)
src/gateway/protocol/schema.ts:
ProtocolSchemas i wyeksportuj typy:
- Walidacja
src/gateway/protocol/index.ts wyeksportuj walidator AJV:
- Zachowanie serwera
src/gateway/server-methods/system.ts:
src/gateway/server-methods.ts (już scala systemHandlers),
a następnie dodaj "system.echo" do wejścia listGatewayMethods w
src/gateway/server-methods-list.ts.
Jeśli metoda może być wywoływana przez klientów operatora lub Node, sklasyfikuj ją także w
src/gateway/method-scopes.ts, aby egzekwowanie zakresów i reklamowanie funkcji
w hello-ok pozostały spójne.
- Wygeneruj ponownie
- Testy + dokumentacja
src/gateway/server.*.test.ts i opisz metodę w dokumentacji.
Zachowanie generowania kodu Swift
Generator Swift emituje:- enum
GatewayFramez przypadkamireq,res,eventiunknown - silnie typowane struktury/enumy payloadów
- wartości
ErrorCode,GATEWAY_PROTOCOL_VERSIONiGATEWAY_MIN_PROTOCOL_VERSION
Wersjonowanie + zgodność
PROTOCOL_VERSIONznajduje się wsrc/gateway/protocol/version.ts.- Klienci wysyłają
minProtocol+maxProtocol; serwer odrzuca zakresy, które nie obejmują jego obecnego protokołu. - Modele Swift zachowują nieznane typy ramek, aby nie psuć starszych klientów.
Wzorce i konwencje schematów
- Większość obiektów używa
additionalProperties: falsedla ścisłych payloadów. NonEmptyStringjest wartością domyślną dla identyfikatorów oraz nazw metod/zdarzeń.- Najwyższego poziomu
GatewayFrameużywa dyskryminatora natype. - Metody ze skutkami ubocznymi zwykle wymagają
idempotencyKeyw parametrach (przykład:send,poll,agent,chat.send). agentakceptuje opcjonalneinternalEventsdla generowanego w czasie działania kontekstu orkiestracji (na przykład przekazanie po ukończeniu zadania subagenta/cronu); traktuj to jako wewnętrzną powierzchnię API.
JSON schematu na żywo
Wygenerowany JSON Schema znajduje się w repozytorium poddist/protocol.schema.json. Opublikowany surowy plik jest zwykle dostępny pod adresem:
Gdy zmieniasz schematy
- Zaktualizuj schematy TypeBox.
- Zarejestruj metodę/zdarzenie w
src/gateway/server-methods-list.ts. - Zaktualizuj
src/gateway/method-scopes.ts, gdy nowe RPC wymaga klasyfikacji zakresu operatora lub Node. - Uruchom
pnpm protocol:check. - Skomituj wygenerowany ponownie schemat + modele Swift.