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.
Tying it to together
The only thing left is to understand is how does authentication work? We need to do three things with respect to authentication:
- Pass the JWT token from Auth0 to Hasura while firing the pull & push query
- Pass the JWT token from Auth0 to Hasura while setting up the GraphQL subscription
- Restart the replication process whenever the JWT token changes. Eg: if the user logs out and logs back in
In the previous section we have seen that #2 is taken care of by passing the Authorization
header in the connectionParams
.
Similarly, #1 is taken care of while initializing RxDB:
async setupGraphQLReplication(auth) {const replicationState = this.db.todos.syncGraphQL({url: syncURL,headers: {'Authorization': `Bearer ${auth.idToken}`},push: {batchSize,queryBuilder: pushQueryBuilder},pull: {queryBuilder: pullQueryBuilder(auth.userId)},live: true,/*** Because the websocket is used to inform the client* when something has changed,* we can set the liveIntervall to a high value*/liveInterval: 1000 * 60 * 10, // 10 minutesdeletedFlag: 'deleted'});replicationState.error$.subscribe(err => {console.error('replication error:');console.dir(err);});return replicationState;}
Finally for #3 we add a restart method in the GraphQLReplicator
class:
async restart(auth) {if(this.replicationState) {this.replicationState.cancel()}if(this.subscriptionClient) {this.subscriptionClient.close()}this.replicationState = await this.setupGraphQLReplication(auth)this.subscriptionClient = this.setupGraphQLSubscription(auth, this.replicationState)}
This method is called by the AppWrapper
class whenever there is a change the authentication token.
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"