Simplify your stack and build anything. Or everything.
Build tomorrow’s web with a modern solution you truly own.
Code-based nature means you can build on top of it to power anything.
It’s time to take back your content infrastructure.

GraphQL Overview

In addition to its REST and Local APIs, Payload ships with a fully featured and extensible GraphQL API.

By default, the GraphQL API is exposed via /api/graphql, but you can customize this URL via specifying your routes within the main Payload Config.

The labels you provide for your Collections and Globals are used to name the GraphQL types that are created to correspond to your config. Special characters and spaces are removed.

GraphQL Options

At the top of your Payload Config you can define all the options to manage GraphQL.

Option

Description

mutations

Any custom Mutations to be added in addition to what Payload provides. More

queries

Any custom Queries to be added in addition to what Payload provides. More

maxComplexity

A number used to set the maximum allowed complexity allowed by requests More

disablePlaygroundInProduction

A boolean that if false will enable the GraphQL playground, defaults to true. More

disable

A boolean that if true will disable the GraphQL entirely, defaults to false.

validationRules

A function that takes the ExecutionArgs and returns an array of ValidationRules.

Collections

Everything that can be done to a Collection via the REST or Local API can be done with GraphQL (outside of uploading files, which is REST-only). If you have a collection as follows:

1
import type { CollectionConfig } from 'payload'
2
3
export const PublicUser: CollectionConfig = {
4
slug: 'public-users',
5
auth: true, // Auth is enabled
6
fields: [
7
...
8
],
9
}

Payload will automatically open up the following queries:

Query Name

Operation

PublicUser

findByID

PublicUsers

find

countPublicUsers

count

mePublicUser

me auth operation

And the following mutations:

Query Name

Operation

createPublicUser

create

updatePublicUser

update

deletePublicUser

delete

forgotPasswordPublicUser

forgotPassword auth operation

resetPasswordPublicUser

resetPassword auth operation

unlockPublicUser

unlock auth operation

verifyPublicUser

verify auth operation

loginPublicUser

login auth operation

logoutPublicUser

logout auth operation

refreshTokenPublicUser

refresh auth operation

Globals

Globals are also fully supported. For example:

1
import type { GlobalConfig } from 'payload';
2
3
const Header: GlobalConfig = {
4
slug: 'header',
5
fields: [
6
...
7
],
8
}

Payload will open the following query:

Query Name

Operation

Header

findOne

And the following mutation:

Query Name

Operation

updateHeader

update

Preferences

User preferences for the Admin Panel are also available to GraphQL the same way as other collection schemas are generated. To query preferences you must supply an authorization token in the header and only the preferences of that user will be accessible.

Payload will open the following query:

Query Name

Operation

Preference

findOne

And the following mutations:

Query Name

Operation

updatePreference

update

deletePreference

delete

GraphQL Playground

GraphQL Playground is enabled by default for development purposes, but disabled in production. You can enable it in production by passing graphQL.disablePlaygroundInProduction a false setting in the main Payload Config.

You can even log in using the login[collection-singular-label-here] mutation to use the Playground as an authenticated user.

Custom Validation Rules

You can add custom validation rules to your GraphQL API by defining a validationRules function in your Payload Config. This function should return an array of Validation Rules that will be applied to all incoming queries and mutations.

1
import { GraphQL } from '@payloadcms/graphql/types'
2
import { buildConfig } from 'payload'
3
4
export default buildConfig({
5
// ...
6
graphQL: {
7
validationRules: (args) => [
8
NoProductionIntrospection
9
]
10
},
11
// ...
12
})
13
14
const NoProductionIntrospection: GraphQL.ValidationRule = (context) => ({
15
Field(node) {
16
if (process.env.NODE_ENV === 'production') {
17
if (node.name.value === '__schema' || node.name.value === '__type') {
18
context.reportError(
19
new GraphQL.GraphQLError(
20
'GraphQL introspection is not allowed, but the query contained __schema or __type',
21
{ nodes: [node] }
22
)
23
);
24
}
25
}
26
}
27
})

Query complexity limits

Payload comes with a built-in query complexity limiter to prevent bad people from trying to slow down your server by running massive queries. To learn more, click here.

Field complexity

You can define custom complexity for relationship, upload and join type fields. This is useful if you want to assign a higher complexity to a field that is more expensive to resolve. This can help prevent users from running queries that are too complex.

1
const fieldWithComplexity = {
2
name: 'authors',
3
type: 'relationship',
4
relationship: 'authors',
5
graphQL: {
6
complexity: 100,
7
}
8
}
Next

Adding your own Queries and Mutations