This is an example of a Rust server that functions as a remote schema for Hasura.
It demonstrates:
- user login + signup
- JWT authorization w/ refresh cookie
- typesafe GraphQL requests
- uuid package integration
You can learn more about this stack from this talk.
- Your Hasura schema must have a table user, with aidcolumn of typeuuid, and also ausernamecolumn of typetext.
- Set an ADMIN_SECRETand aJWT_SECRETon the graphql engine, and share these with the Rust server as environment variables.
- Use graphqurl to generate schema.json
- gq $HASURA_ENDPOINT -H "x-hasura-admin-secret: $ADMIN_SECRET" --introspect --format json > ./graphql/schema.json
- cargo run
| Key | Example | 
|---|---|
| PORT | 8000 | 
| HASURA_ENDPOINT | http://127.0.0.1:8080/v1/graphql | 
| ADMIN_SECRET | foo | 
| JWT_SECRET | {"type":"HS256","key":"3QQ6FD+o0+c7tzQQVfjpMkNDi2yARAAKzQQk8O2IKoxQQ4nF7EdAh8s3TwpHwrdQQ6R"} |