Add business logic to your GraphQL API with Hasura Actions
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
whoami?
data:image/s3,"s3://crabby-images/83de0/83de057620a9f6467fa5f44066bac9e380b81ccd" alt=""
data:image/s3,"s3://crabby-images/33cc5/33cc5e6734e6f8c96ad61d2847aaf8fabc2ec4d9" alt=""
data:image/s3,"s3://crabby-images/32c4a/32c4a79ebdcaf233e08b8b89ce424f211f01e246" alt=""
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
- What is Hasura?
- What are Actions?
- Machinery behind Actions
- Example use cases
- Demo
Agenda
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
What is Hasura?
data:image/s3,"s3://crabby-images/07d07/07d078a2a2cf3ebad7e328147bdd158dfe39b148" alt=""
Open source • GraphQL engine • On Postgres
Realtime GraphQL Engine
data:image/s3,"s3://crabby-images/75747/757472ce509074b59fe042b93b6a9e5af448c2d1" alt=""
GraphQL Queries Compiler
users {
name
posts {
title
content
tags {
name
}
}
}
SELECT
users.name
posts.title
posts.content
tags.name
FROM
users, posts, tags
WHERE
users.id = posts.author_id,
posts.id = tags.post_id
Authorization
Authentication
data:image/s3,"s3://crabby-images/2135b/2135becf54f6ef8a8c38a865fbb7b6a105abbd38" alt=""
Authentication
data:image/s3,"s3://crabby-images/abf4e/abf4ec0d4557392d43da84271910c729002ea23a" alt=""
Remote Schemas
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
data:image/s3,"s3://crabby-images/5d3c9/5d3c9c9b6d2499adb1799ca910a3ab02f275c35c" alt=""
Event triggers
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
data:image/s3,"s3://crabby-images/ed751/ed751f5ce82431ab34fed16b58099213a92dae76" alt=""
What are Actions?
data:image/s3,"s3://crabby-images/f6830/f6830a13bca4b643e7ad8745b0dff04621a4d6ff" alt=""
How does it work?
mutation createUser(user: {...}) {
...
}
{
"input": {
"user": {...}
},
"session_variables": {...}
}
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
1. GraphQL mutation → Event payload
How does it work?
Async Mode: Event captured → Persisted → Event delivered
2. Delivering event to the webhook
{ ... }
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
Event store
Event store
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
data:image/s3,"s3://crabby-images/399ca/399caa821bc72fba887b46c06ec88e597a68030b" alt=""
How does it work?
2. Delivering event to the webhook
Sync Mode: Event captured → Event delivered
{ ... }
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
data:image/s3,"s3://crabby-images/399ca/399caa821bc72fba887b46c06ec88e597a68030b" alt=""
How does it work?
3. Receiving event response
Async Mode: event is put back the event store
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
data:image/s3,"s3://crabby-images/399ca/399caa821bc72fba887b46c06ec88e597a68030b" alt=""
Event store
{ ... }
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
Event store
Event store
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
data:image/s3,"s3://crabby-images/399ca/399caa821bc72fba887b46c06ec88e597a68030b" alt=""
How does it work?
3. Receiving event response
Sync mode: Hasura keeps the request open till receiving a response from the handler
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
data:image/s3,"s3://crabby-images/399ca/399caa821bc72fba887b46c06ec88e597a68030b" alt=""
{ ... }
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
data:image/s3,"s3://crabby-images/399ca/399caa821bc72fba887b46c06ec88e597a68030b" alt=""
How does it work?
4. Getting results of the event handler
Async mode: Event response → GraphQL subscription
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
subscription {
createUserResult(actionId: "") {
userId
events {
name
date
}
}
}
Event store
Postgres DB
How does it work?
4. Getting results of the event handler
Async mode: Event response → GraphQL mutation
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
mutation {
createUser(user: {...}) {
userId
events {
name
date
}
}
}
Postgres DB
data:image/s3,"s3://crabby-images/399ca/399caa821bc72fba887b46c06ec88e597a68030b" alt=""
data:image/s3,"s3://crabby-images/dea40/dea400739aacfb03d30055d548ceae07cc148680" alt=""
Add business logic to your GraphQL API with Hasura Actions
By Aleksandra Sikora
Add business logic to your GraphQL API with Hasura Actions
- 1,590