Last updated
Last updated
The GraphQL Drupal module lets you query or mutate (update/delete) any content or configuration using the official GraphQL query language. This is an extremely powerful tool which opens the door for Drupal to be used in a multitude of applications.
Anyone who wants to get JSON data out of Drupal.
A few examples of where the GraphQL module could be used:
Decoupled Drupal applications with a javascript front-end (React, Angular, Ember, etc),
Twig Templates (Drupal theming)
Mobile applications that need a persistent data store
IOT data storage
This documentation refers to the 8.x-4.x version of the module which uses a schema first approach, where you will need to specify the schema in a DSL format. The documentation will guide you through the process of doing that. The benefits over the 3.x version is that the end resulting schema is a lot cleaner and includes only what you explicitly include in the schema, and not the whole of Drupal (as it is in the 3.x version of the module).
This trade-off does come with costs mostly around ease of use, where in the 3.x version it is a lot quicker to get up and running, in 4.x you will need to specify more in the schema and in code in order to get more out of the module.
Familiarize yourself with the GraphQL language. The official GraphQL docs are very well written.
Install the module and enable GraphQL.
Login and navigate to /admin/config/graphql
create a new server. You can use the Test schema that comes with the module to try out using GraphQL for the first time before making your own schema. Create the server and specify and endpoint such as /graphql
. After creating the server click on explorer
and this should bring you to the Graphiql explorer.
For a query to work first you need to make an Article node. Create one with the title "Hello GraphQL" and save it.
Read the comments and then enter the following query in the left pane:
Press Ctrl-Space
and you should see something like the following display in the right pane:
Congratulations!! You just figured out how to execute your first GraphQL query. This query is displaying a list of articles.
NOTES:
The GraphiQL explorer, included with the module, is your friend, it’s amazing. You will most likely use the GraphiQL explorer to build and test more complicated queries.
GraphQL is introspective, meaning that the entire schema (data model) is known up front. This is important as it allows tools like GraphiQL to implement autocompletion.
You can use GraphiQL to explore your way through the data and configuration, once you know the basic GraphQL syntax. You can use the tab key in the explorer like you would with autocompletion or intellisense in modern IDEs.