If you haven’t already, follow the first part of instructions here.
This example trigger updates (executes a mutation) when an event occurs on another table, written in NodeJS.
Table name: note
Columns:
id Integer auto-increment
note Text
Primary key: id
Table name: note_revision
Columns:
id Integer auto-increment
note Text
note_id Integer
update_at Timestamp, default: now()
Primary key: id
Execute now
in this directory with an env var required for the code to execute
a mutation:
now -e HGE_ENDPOINT=https://my-app.herokuapp.com/v1/graphql
HGE_ENDPOINT
is the Hasura GraphQL Engine endpoint.
Once the deployment is done, you’ll get an endpoint like
https://zeit-mutation-hhasdewasd.now.sh
. Not this down as NOW_URL
.
Note: Now.sh deployments are immutable, i.e. each time you deploy the code, a new URL will be provisioned. You can alias the deployment to keep a constant URL.
Goto Hasura console, Events
tab and create a new trigger:
Trigger name: note_revision_trigger
Schema/Table: public/note
Operations: Update
Webhook URL: NOW_URL
Replace NOW_URL
with the URL noted earlier.
Goto Data
tab on Hasura console, browse to note
table and to the Browse rows
tab. Edit an existing note and check if the note_revision
entry has been
created. Also, checkout the trigger request and response.
Trigger payload (request):
{
"event": {
"op": "UPDATE",
"data": {
"old": {
"note": "note1",
"id": 1
},
"new": {
"note": "note1 updated",
"id": 1
}
}
},
"created_at": "2018-10-02T06:38:22.67311Z",
"id": "f57a1c79-72ba-4c19-8791-37d1b9616bcf",
"trigger": {
"name": "note_revision_trigger",
"id": "5d85cbd1-c134-45ce-810c-7ecd3b4fc1ee"
},
"table": {
"schema": "public",
"name": "note"
}
}
Webhook response:
{
"result": {
"data": {
"insert_note_revision": {
"returning": [
{
"__typename": "note_revision",
"id": 1
}
],
"affected_rows": 1,
"__typename": "note_revision_mutation_response"
}
}
}
}