Remove Indexing Latency from your App using Relay Websockets
Our goal at Relay is to make multichain payments feel instant. Even when transactions confirm quickly onchain, API polling latency can degrade user experience. Connecting your app to Relay Websockets means your users get streamed updates of the status of their Relays for a speedier experience.
The Websocket Service is available for anyone with strict rate limits. For customers with an API key it can be used for authentication for higher rate limits, the service is available at the following URL wss://ws.relay.linkTo connect using an API key, provide your API key as a query param in the connection url:
Copy
Ask AI
const wss = new ws(`wss://ws.relay.link?apiKey=${YOUR_API_KEY}`);
Authentication is generally not required in client-side applications.
The websocket server needs to restart to deploy updatesThe websocket server uses a rolling restart mechanism to deploy new changes. This will disconnect you and require you to reconnect to the websocket server. There is no downtime, as you are only disconnected once the new server is up and running. Please make sure to include logic in your implementation to handle these restarts, and reconnect accordingly.
Before sending any messages over the Websocket, wait for a ready message back from the server. The message looks like:
Copy
Ask AI
{ "type": "connection", // The type of operation "status": "ready", // The status of the operation "data": { "id": "9nqpzwmwh86" // Your socket id for debugging purposes }}