This course is no longer maintained and may be out-of-date. While it remains available for reference, its content may not reflect the latest updates, best practices, or supported features.
Subscription
When we had initially set up Apollo with HttpLink. It supports queries and mutations but not subscriptions. So we have to install more dependencies to set up subscriptions.
React Apollo Subscriptions Setup
+ $ npm install subscriptions-transport-ws --save
Now we need to update our ApolloClient
instance to point to the subscription server.
Open src/components/App.res
and update the createApolloClient
:
let createApolloClient = authToken => {let headers = {"Authorization": `Bearer ${authToken}`,}let httpLink = ApolloClient.Link.HttpLink.make(~uri=_ => "https://hasura.io/learn/graphql",~headers=Obj.magic(headers),(),)+ let wsLink = {+ open ApolloClient.Link.WebSocketLink+ make(+ ~uri="wss://hasura.io/learn/graphql",+ ~options=ClientOptions.make(+ ~connectionParams=ConnectionParams(Obj.magic({"headers": headers})),+ ~reconnect=true,+ (),+ ),+ (),+ )+ }++ let terminatingLink = ApolloClient.Link.split(~test=({query}) => {+ let definition = ApolloClient.Utilities.getOperationDefinition(query)+ switch definition {+ | Some({kind, operation}) => kind === "OperationDefinition" && operation === "subscription"+ | None => false+ }+ }, ~whenTrue=wsLink, ~whenFalse=httpLink)let client = {open ApolloClientmake(~cache=Cache.InMemoryCache.make(),~connectToDevTools=true,~defaultOptions=DefaultOptions.make(~mutate=DefaultMutateOptions.make(~awaitRefetchQueries=true, ()),(),),- ~link=httpLink,+ ~link=terminatingLink,(),)}client}
We configured split link to choose WebSocketLink
for subscription queries and HttpLink
for queries and mutations.
Did you find this page helpful?
Start with GraphQL on Hasura for Free
Build apps and APIs 10x faster
Built-in authorization and caching
8x more performant than hand-rolled APIs
data:image/s3,"s3://crabby-images/d807b/d807b10f22067a93d38cb31c49e9b6df16526408" alt="Promo"
data:image/s3,"s3://crabby-images/868ff/868ffb1210a1adc758a09817d07c9681a5c10cc9" alt="footer illustration"