mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-03 13:21:01 +03:00
fa90e9d004
GitOrigin-RevId: 4627c876b2771c84602f4bfaa1ab0646b2650f12
218 lines
5.2 KiB
ReStructuredText
218 lines
5.2 KiB
ReStructuredText
.. meta::
|
|
:description: Manage scheduled triggers with the Hasura metadata API
|
|
:keywords: hasura, docs, metadata API, API reference, scheduled trigger
|
|
|
|
Metadata API Reference: Scheduled Triggers (v2.0 and above)
|
|
===========================================================
|
|
|
|
.. contents:: Table of contents
|
|
:backlinks: none
|
|
:depth: 1
|
|
:local:
|
|
|
|
Introduction
|
|
------------
|
|
|
|
Scheduled triggers are used to invoke webhooks based on a timestamp or cron.
|
|
|
|
.. admonition:: Supported from
|
|
|
|
The metadata API is supported for versions ``v2.0.0`` and above and replaces the older
|
|
:ref:`schema/metadata API <schema_metadata_apis>`.
|
|
|
|
.. _metadata_create_cron_trigger:
|
|
|
|
create_cron_trigger
|
|
-------------------
|
|
|
|
``create_cron_trigger`` is used to create a new cron trigger.
|
|
|
|
.. code-block:: http
|
|
|
|
POST /v1/metadata HTTP/1.1
|
|
Content-Type: application/json
|
|
X-Hasura-Role: admin
|
|
|
|
{
|
|
"type" : "create_cron_trigger",
|
|
"args" : {
|
|
"name": "sample_cron",
|
|
"webhook": "https://httpbin.org/post",
|
|
"schedule": "* * * * *",
|
|
"payload": {
|
|
"key1": "value1",
|
|
"key2": "value2"
|
|
},
|
|
"include_in_metadata":false,
|
|
"comment":"sample_cron commment"
|
|
}
|
|
}
|
|
|
|
.. _metadata_create_cron_trigger_syntax:
|
|
|
|
Args syntax
|
|
^^^^^^^^^^^
|
|
|
|
.. list-table::
|
|
:header-rows: 1
|
|
|
|
* - Key
|
|
- Required
|
|
- Schema
|
|
- Description
|
|
* - name
|
|
- true
|
|
- :ref:`TriggerName <TriggerName>`
|
|
- Name of the cron trigger
|
|
* - webhook
|
|
- true
|
|
- :ref:`WebhookURL <WebhookURL>`
|
|
- URL of the webhook
|
|
* - schedule
|
|
- true
|
|
- Cron Expression
|
|
- Cron expression at which the trigger should be invoked.
|
|
* - payload
|
|
- false
|
|
- JSON
|
|
- Any JSON payload which will be sent when the webhook is invoked.
|
|
* - headers
|
|
- false
|
|
- [ :ref:`HeaderFromValue <HeaderFromValue>` | :ref:`HeaderFromEnv <HeaderFromEnv>` ]
|
|
- List of headers to be sent with the webhook
|
|
* - retry_conf
|
|
- false
|
|
- :ref:`RetryConfST`
|
|
- Retry configuration if scheduled invocation delivery fails
|
|
* - include_in_metadata
|
|
- true
|
|
- Boolean
|
|
- Flag to indicate whether a trigger should be included in the metadata. When a cron
|
|
trigger is included in the metadata, the user will be able to export it when the
|
|
metadata of the graphql-engine is exported.
|
|
* - comment
|
|
- false
|
|
- Text
|
|
- Custom comment.
|
|
* - replace
|
|
- false
|
|
- Bool
|
|
- When replace is set to ``true``, the cron trigger will be updated(if exists) and when it's ``false`` or the
|
|
field is omitted, then a new cron trigger will be created.
|
|
|
|
.. admonition:: Supported from
|
|
|
|
Scheduled triggers are supported from versions ``v1.3.0`` and above.
|
|
|
|
.. _metadata_delete_cron_trigger:
|
|
|
|
delete_cron_trigger
|
|
-------------------
|
|
|
|
``delete_cron_trigger`` is used to delete an existing cron trigger. The scheduled events associated with the cron trigger will also be deleted.
|
|
|
|
|
|
.. code-block:: http
|
|
|
|
POST /v1/metadata HTTP/1.1
|
|
Content-Type: application/json
|
|
X-Hasura-Role: admin
|
|
|
|
{
|
|
"type" : "delete_cron_trigger",
|
|
"args" : {
|
|
"name": "sample_cron"
|
|
}
|
|
}
|
|
|
|
.. _metadata_delete_cron_trigger_syntax:
|
|
|
|
Args syntax
|
|
^^^^^^^^^^^
|
|
|
|
.. list-table::
|
|
:header-rows: 1
|
|
|
|
* - Key
|
|
- Required
|
|
- Schema
|
|
- Description
|
|
* - name
|
|
- true
|
|
- :ref:`TriggerName <TriggerName>`
|
|
- Name of the cron trigger
|
|
|
|
.. admonition:: Supported from
|
|
|
|
Scheduled triggers are supported from versions ``v1.3.0`` and above.
|
|
|
|
.. _metadata_create_scheduled_event:
|
|
|
|
create_scheduled_event
|
|
----------------------
|
|
|
|
``create_scheduled_event`` is used to create a scheduled event.
|
|
|
|
.. code-block:: http
|
|
|
|
POST /v1/metadata HTTP/1.1
|
|
Content-Type: application/json
|
|
X-Hasura-Role: admin
|
|
|
|
{
|
|
"type" : "create_scheduled_event",
|
|
"args" : {
|
|
"webhook": "https://httpbin.org/post",
|
|
"schedule_at": "2019-09-09T22:00:00Z",
|
|
"payload": {
|
|
"key1": "value1",
|
|
"key2": "value2"
|
|
},
|
|
"headers" : [{
|
|
"name":"header-key",
|
|
"value":"header-value"
|
|
}],
|
|
"comment":"sample scheduled event comment"
|
|
}
|
|
}
|
|
|
|
.. _metadata_create_scheduled_event_syntax:
|
|
|
|
Args syntax
|
|
^^^^^^^^^^^
|
|
|
|
.. list-table::
|
|
:header-rows: 1
|
|
|
|
* - Key
|
|
- Required
|
|
- Schema
|
|
- Description
|
|
* - webhook
|
|
- true
|
|
- :ref:`WebhookURL <WebhookURL>`
|
|
- URL of the webhook
|
|
* - schedule_at
|
|
- true
|
|
- Timestamp (ISO8601 format)
|
|
- The time at which the invocation should be invoked.
|
|
* - payload
|
|
- false
|
|
- JSON
|
|
- Any JSON payload which will be sent when the webhook is invoked.
|
|
* - headers
|
|
- false
|
|
- [ :ref:`HeaderFromValue <HeaderFromValue>` | :ref:`HeaderFromEnv <HeaderFromEnv>` ]
|
|
- List of headers to be sent with the webhook
|
|
* - retry_conf
|
|
- false
|
|
- :ref:`RetryConfST`
|
|
- Retry configuration if scheduled event delivery fails
|
|
* - comment
|
|
- false
|
|
- Text
|
|
- Custom comment.
|
|
|
|
.. admonition:: Supported from
|
|
|
|
Scheduled triggers are supported from versions ``v1.3.0`` and above. |