Authentication
Access Vertex's authenticated streams.
Rate limits
A single wallet address can be authenticated by up to 5 websocket connections, regardless of the originating IP address. Connections exceeding these limits will be automatically disconnected.
See rate limits for more details.
Request
To access streams that require authentication, submit a request with the method
field set to authenticate
.
Request Parameters
Parameter | Type | Required | Description |
---|---|---|---|
method | string | Yes |
|
id | number | Yes | Can be set to any positive integer. Can be used to identify the websocket request / response. |
tx | object | Yes |
|
tx.sender | string | Yes | A hex string representing a |
tx.expiration | string | Yes | Represents the expiration time in milliseconds since the Unix epoch. |
signature | string | Yes | Hex string representing hash of the signed |
Notes:
Although sender specifies a specific subaccount, authentication applies to the entire wallet address, enabling access to authenticated streams for different subaccounts under that address.
Once authenticated, the authentication status of that websocket connection cannot be changed and stays for the duration of the connection.
Signing
See more details and examples in our signing page.
The typed data struct that needs to be signed is:
sender
: A hex string representing a bytes32
of a specific subaccount. The signature must be signed by the wallet address specified by sender.
expiration
: Represents the expiration time in milliseconds since the Unix epoch. Requests will be denied if the expiration is either smaller than the current time or more than 100 seconds ahead of it.
Notes:
Should use the endpoint address as
verifyingContract
.For signing, you should always use the data type specified in the typed data struct which might be different from the type sent in the request e.g:
expiration
should be anuint64
for Signing but should be sent as astring
in the final payload.
Response
Last updated