mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-07 08:13:18 +03:00
6f100e0009
* config options for internal errors for non-admin role, close #4031 More detailed action debug info is added in response 'internal' field * add docs * update CHANGELOG.md * set admin graphql errors option in ci tests, minor changes to docs * fix tests Don't use any auth for sync actions error tests. The request body changes based on auth type in session_variables (x-hasura-auth-mode) * Apply suggestions from code review Co-Authored-By: Marion Schleifer <marion@hasura.io> * use a new sum type to represent the inclusion of internal errors As suggested in review by @0x777 -> Move around few modules in to specific API folder -> Saperate types from Init.hs * fix tests Don't use any auth for sync actions error tests. The request body changes based on auth type in session_variables (x-hasura-auth-mode) * move 'HttpResponse' to 'Hasura.HTTP' module * update change log with breaking change warning * Update CHANGELOG.md Co-authored-by: Marion Schleifer <marion@hasura.io> Co-authored-by: Tirumarai Selvan <tiru@hasura.io>
133 lines
2.7 KiB
ReStructuredText
133 lines
2.7 KiB
ReStructuredText
.. meta::
|
|
:description: Action handlers for Hasura actions
|
|
:keywords: hasura, docs, actions, handlers
|
|
|
|
.. _action_handlers:
|
|
|
|
Action handlers
|
|
===============
|
|
|
|
|
|
.. contents:: Table of contents
|
|
:backlinks: none
|
|
:depth: 1
|
|
:local:
|
|
|
|
Introduction
|
|
------------
|
|
|
|
Actions need to be backed by custom business logic. This business logic can be
|
|
defined in a handler which is an HTTP webhook.
|
|
|
|
|
|
HTTP handler
|
|
------------
|
|
|
|
When the action is executed i.e. when the query or the mutation is called, Hasura makes a ``POST`` request to the
|
|
handler with the action arguments and the session variables.
|
|
|
|
The request payload is of the format:
|
|
|
|
.. code-block:: json
|
|
|
|
{
|
|
"action": {
|
|
"name": "<action-name>"
|
|
},
|
|
"input": {
|
|
"arg1": "<value>",
|
|
"arg2": "<value>"
|
|
},
|
|
"session_variables": {
|
|
"x-hasura-user-id": "<session user id>",
|
|
"x-hasura-role": "<session user role>"
|
|
}
|
|
}
|
|
|
|
|
|
Returning a success response
|
|
----------------------------
|
|
|
|
To return a success response, you must send back a response payload of action's
|
|
response type. The HTTP status code must be ``2xx`` for a successful response.
|
|
|
|
Returning an error response
|
|
---------------------------
|
|
|
|
To return an error response, you must send back an error object.
|
|
An error object looks like:
|
|
|
|
.. code-block:: json
|
|
|
|
{
|
|
"message": "<mandatory error message>",
|
|
"code": "<optional error code>"
|
|
}
|
|
|
|
The HTTP status code must be ``4xx`` for an error response.
|
|
|
|
|
|
Example
|
|
-------
|
|
|
|
For example, consider the following mutation.
|
|
|
|
.. code-block:: graphql
|
|
|
|
extend type Mutation {
|
|
UserLogin (username: String!, email: String!): UserInfo
|
|
}
|
|
|
|
type UserInfo {
|
|
accessToken: String!
|
|
userId: Int!
|
|
}
|
|
|
|
Let's say, the following mutation is executed:
|
|
|
|
.. code-block:: graphql
|
|
|
|
mutation {
|
|
UserLogin (username: "jake", password: "secretpassword") {
|
|
accessToken
|
|
userId
|
|
}
|
|
}
|
|
|
|
|
|
Hasura will call the handler with the following payload:
|
|
|
|
.. code-block:: json
|
|
|
|
{
|
|
"action": "UserLogin",
|
|
"input": {
|
|
"username": "jake",
|
|
"password": "secretpassword"
|
|
},
|
|
"session_variables": {
|
|
"x-hasura-user-id": "423",
|
|
"x-hasura-role": "user"
|
|
}
|
|
}
|
|
|
|
To return a success response, you must send the response of the action's output
|
|
type (in this case, ``UserInfo``) with a status code ``2xx``. So a sample
|
|
response would be:
|
|
|
|
.. code-block:: json
|
|
|
|
{
|
|
"accessToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVC",
|
|
"userId": 4829
|
|
}
|
|
|
|
To throw an error, you must a response payload of the following type while
|
|
setting the status code as ``4xx``.
|
|
|
|
.. code-block:: json
|
|
|
|
{
|
|
"message": "invalid credentials"
|
|
}
|