2020-01-14 15:57:45 +03:00
|
|
|
.. meta::
|
|
|
|
:description: Hasura GraphQL API reference
|
|
|
|
:keywords: hasura, docs, GraphQL API, reference
|
|
|
|
|
2020-03-11 22:42:36 +03:00
|
|
|
.. _api_reference_graphql:
|
|
|
|
|
2019-04-30 11:34:08 +03:00
|
|
|
GraphQL API Reference
|
|
|
|
=====================
|
|
|
|
|
|
|
|
.. contents:: Table of contents
|
|
|
|
:backlinks: none
|
|
|
|
:depth: 1
|
|
|
|
:local:
|
|
|
|
|
2020-08-25 14:53:25 +03:00
|
|
|
Introduction
|
|
|
|
------------
|
|
|
|
|
2019-04-30 11:34:08 +03:00
|
|
|
All GraphQL requests for queries, subscriptions and mutations are made to the GraphQL API.
|
|
|
|
|
|
|
|
Endpoint
|
|
|
|
--------
|
|
|
|
|
2019-09-11 10:17:14 +03:00
|
|
|
All requests are ``POST`` requests to the ``/v1/graphql`` (or ``/v1alpha1/graphql``) endpoint.
|
2019-05-10 09:05:11 +03:00
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
2019-09-11 10:17:14 +03:00
|
|
|
The ``/v1/graphql`` endpoint returns HTTP 200 status codes for all responses.
|
|
|
|
This is a **breaking** change from the ``/v1alpha1/graphql`` behaviour, where
|
2019-05-10 09:05:11 +03:00
|
|
|
request errors and internal errors were responded with 4xx and 5xx status
|
|
|
|
codes.
|
2019-04-30 11:34:08 +03:00
|
|
|
|
|
|
|
Request types
|
|
|
|
-------------
|
|
|
|
|
|
|
|
The following types of requests can be made using the GraphQL API:
|
|
|
|
|
2020-03-11 22:42:36 +03:00
|
|
|
- :ref:`Query / Subscription <graphql_api_query>`
|
|
|
|
- :ref:`Mutation <graphql_api_mutation>`
|
2019-04-30 11:34:08 +03:00
|
|
|
|
2020-06-24 20:30:08 +03:00
|
|
|
Batching requests
|
|
|
|
-----------------
|
2019-12-20 19:04:02 +03:00
|
|
|
|
2020-06-24 20:30:08 +03:00
|
|
|
The GraphQL API provides support for batched requests (which can be a combination of queries and mutations).
|
2019-12-20 19:04:02 +03:00
|
|
|
The endpoint will accept an array of operations in place of a single operation, and return an array of corresponding
|
|
|
|
responses.
|
|
|
|
|
|
|
|
**Example:** using a client which supports batching (such as Apollo Client), we can send two
|
|
|
|
query operations in one request:
|
|
|
|
|
|
|
|
.. graphiql::
|
|
|
|
:view_only:
|
|
|
|
:query:
|
|
|
|
query first {
|
|
|
|
author(where: {id: {_eq: 1}}) {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
}
|
|
|
|
}
|
|
|
|
query second {
|
|
|
|
author(where: {id: {_eq: 2}}) {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
}
|
|
|
|
}
|
|
|
|
:response:
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"data": {
|
|
|
|
"author": [
|
|
|
|
{
|
|
|
|
"id": 1,
|
|
|
|
"name": "Justin"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"data": {
|
|
|
|
"author": [
|
|
|
|
{
|
|
|
|
"id": 2,
|
|
|
|
"name": "Beltran"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
|
2019-04-30 11:34:08 +03:00
|
|
|
.. toctree::
|
|
|
|
:maxdepth: 1
|
|
|
|
:hidden:
|
|
|
|
|
|
|
|
Query / Subscription <query>
|
|
|
|
Mutation <mutation>
|