WebSockets
You can use WebSockets for all or some of the communication with your server, see wsLink for how to set it up on the client.
The document here outlines the specific details of using WebSockets. For general usage of subscriptions, see our subscriptions guide.
Creating a WebSocket-server
bash
bash
server/wsServer.tsts
server/wsServer.tsts
Setting TRPCClient to use WebSockets
You can use Links to route queries and/or mutations to HTTP transport and subscriptions over WebSockets.
client.tstsx
client.tstsx
Authentication / connection params
If you're doing a web application, you can ignore this section as the cookies are sent as part of the request.
In order to authenticate with WebSockets, you can define connectionParams to createWSClient. This will be sent as the first message when the client establishes a WebSocket connection.
server/context.tstsCreateWSSContextFnOptions } from '@trpc/server/adapters/ws';export constcreateContext = async (opts :CreateWSSContextFnOptions ) => {consttoken =opts .info .connectionParams ?.token ;// [... authenticate]return {};};export typeContext =Awaited <ReturnType <typeofcreateContext >>;
server/context.tstsCreateWSSContextFnOptions } from '@trpc/server/adapters/ws';export constcreateContext = async (opts :CreateWSSContextFnOptions ) => {consttoken =opts .info .connectionParams ?.token ;// [... authenticate]return {};};export typeContext =Awaited <ReturnType <typeofcreateContext >>;
client/trpc.tsts
client/trpc.tsts
Automatic tracking of id using tracked() (recommended)
If you yield an event using our tracked()-helper and include an id, the client will automatically reconnect when it gets disconnected and send the last known ID when reconnecting as part of the lastEventId-input.
You can send an initial lastEventId when initializing the subscription and it will be automatically updated as the browser receives data.
If you're fetching data based on the lastEventId, and capturing all events is critical, you may want to use ReadableStream's or a similar pattern as an intermediary as is done in our full-stack SSE example to prevent newly emitted events being ignored while yield'ing the original batch based on lastEventId.
ts
ts
WebSockets RPC Specification
You can read more details by drilling into the TypeScript definitions:
query / mutation
Request
ts
ts
Response
... below, or an error.
ts
ts
subscription / subscription.stop
Start a subscription
ts
ts
To cancel a subscription, call subscription.stop
ts
ts
Subscription response shape
... below, or an error.
ts
ts
Connection params
If the connection is initialized with ?connectionParams=1, the first message has to be connection params.
ts
ts
Errors
See https://www.jsonrpc.org/specification#error_object or Error Formatting.
Notifications from Server to Client
{ id: null, type: 'reconnect' }
Tells clients to reconnect before shutting down the server. Invoked by wssHandler.broadcastReconnectNotification().