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.
Trigger replication on changes
By default RxDB will periodically sync from the remote GraphQL source. This time interval for the sync to be triggered can be set by using the liveInterval
parameter. In this example we have set it to 10 minutes. However, we can also use a GraphQL subscription so that Hasura notifies us as soon as there is a change and trigger replication manually. This is done by the setupGraphQLSubscription
method of the GraphQLReplicator
class.
setupGraphQLSubscription(auth, replicationState) {// Change this url to point to your hasura graphql urlconst endpointURL = 'wss://my-hasura-instance.hasura.app/v1/graphql';const wsClient = new SubscriptionClient(endpointURL, {reconnect: true,connectionParams: {headers: {'Authorization': `Bearer ${auth.idToken}`}},timeout: 1000 * 60,onConnect: () => {console.log('SubscriptionClient.onConnect()');},connectionCallback: () => {console.log('SubscriptionClient.connectionCallback:');},reconnectionAttempts: 10000,inactivityTimeout: 10 * 1000,lazy: true});const query = `subscription onTodoChanged {todos {iddeletedisCompletedtext}}`;const ret = wsClient.request({ query });ret.subscribe({next(data) {console.log('subscription emitted => trigger run');console.dir(data);replicationState.run();},error(error) {console.log('got error:');console.dir(error);}});return wsClient}
The above code uses Apollo subscription client to subscribe to changes on the todos
table from hasura. It then triggers replication whenever new data is received.
Build apps and APIs 10x faster
Built-in authorization and caching
8x more performant than hand-rolled APIs
data:image/s3,"s3://crabby-images/49b3a/49b3af45556b1ba68768b9908c2a4b1c69e0956c" alt="Promo"
data:image/s3,"s3://crabby-images/868ff/868ffb1210a1adc758a09817d07c9681a5c10cc9" alt="footer illustration"