Subscriptions
#
Recommended background reading#
Subscriptions in RelaySubscriptions use a different network configuration than queries and mutations. They use websocket to send and receive data from the server. We will need to configure the Relay environment by providing a subscriptionFunction
when creating the Relay network. Relay will call this function every time we want to create a new subscription. We will also need to pick a subscription client. In this example we will be using subscription-transport-ws. Those are the minimal required bindings for our example to work, but they are tied to rescript-relay itself, and would need to be adjusted in order to be used for other purposes.
The following code is a Reason version of the example from the official Relay documentation:
Subscriptions in RescriptRelay are defined using the %relay()
extension node. The following example shows how to define and start a subscription with RescriptRelay.
Lets imagine we have the following schema:
Then in your Ticket.re
module we can subscribe to changes to the ticket status. Fragments in relay automatically subscribe to updates for the fragment data, see Relay docs. So when we receive an event that the ticket status updated the fragments referencing the data will receive an update and re-render the new state.
A note on naming: Due to the rules of Relay, a subscription must be named
<ModuleName><optionally_anything_here>Subscription
, where module name here means file name, not ReScript module name. So for a fileTicket.res
, all subscriptions in that file must start withTicket
regardless of whether they're defined in nested modules or not. All subscription names must also end withSubscription
.
Using VSCode? Our dedicated VSCode extension lets you codegen new subscriptions easily, including boilerplate for components, via the command
> Add subscription
.
See the examples folder for a working subscription sample.
#
API Reference%relay()
with a subscription in it is expanded to a module containing the following functions:
subscribe
#
Name | Type | Required | Notes |
---|---|---|---|
environment | Environment.t | Yes | Instantiated relay environment |
variables | abstract type | Yes | Variables derived from the GraphQL operation |
onCompleted | option(unit => unit) | No | A callback function executed when the subscription is closed by the peer without error |
onError | option(Js.Exn.t => unit) | No | A callback function executed when Relay or the server encounters an error processing the subscription |
onNext | option(C.response => unit) | No | A callback function executed each time a response is received from the server, with the raw GraphQL response payload. C.response is the response data requested in the graphql query. |
updater | option((RecordSourceSelectorProxy.t, C.response) => unit) | No | An optional function that can supply custom logic for updating the in-memory Relay store based on the server response |
subscribe
uses Relay'srequestSubscription
under the hood, which is documented here