--- stage: Ecosystem group: Integrations info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments --- # GraphQL API **(FREE)** > - [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/merge_requests/19008) in GitLab 11.0 [with a flag](../../administration/feature_flags.md) named `graphql`. > - [Enabled](https://gitlab.com/gitlab-org/gitlab-foss/-/merge_requests/30444) in GitLab 12.1. [GraphQL](https://graphql.org/) is a query language for APIs. You can use it to request the exact data you need, and therefore limit the number of requests you need. GraphQL data is arranged in types, so your client can use [client-side GraphQL libraries](https://graphql.org/code/#graphql-clients) to consume the API and avoid manual parsing. There are no fixed endpoints and no data model, so you can add to the API without creating [breaking changes](../../development/contributing/#breaking-changes). This enables us to have a [versionless API](https://graphql.org/learn/best-practices/#versioning). ## Work with GraphQL If you're new to the GitLab GraphQL API, see [Get started with GitLab GraphQL API](getting_started.md). You can view the available resources in the [GraphQL API reference](reference/index.md). The reference is automatically generated from the GitLab GraphQL schema and written to a Markdown file. The GitLab GraphQL API endpoint is located at `/api/graphql`. ### GraphiQL Explore the GraphQL API using the interactive [GraphiQL explorer](https://gitlab.com/-/graphql-explorer), or on your self-managed GitLab instance on `https:///-/graphql-explorer`. For more information, see [GraphiQL](getting_started.md#graphiql). ### View GraphQL examples You can work with sample queries that pull data from public projects on GitLab.com: - [Create an audit report](audit_report.md) - [Identify issue boards](sample_issue_boards.md) - [Query users](users_example.md) - [Use custom emojis](custom_emoji.md) The [get started](getting_started.md) page includes different methods to customize GraphQL queries. ### Update the GraphQL API reference If you change the GraphQL schema, create a merge request to get your changes approved. To generate the required documentation and schema, see [Rake tasks for developers](../../development/rake_tasks.md#update-graphql-documentation-and-schema-definitions). Run the commands using the [GitLab Development Kit](https://gitlab.com/gitlab-org/gitlab-development-kit/). ## Vision We want the GraphQL API to be the **primary** means of interacting programmatically with GitLab. To achieve this, it needs full coverage - anything possible in the REST API should also be possible in the GraphQL API. To help us meet this vision, the frontend should use GraphQL in preference to the REST API for new features. There are no plans to deprecate the REST API. To reduce the technical burden of supporting two APIs in parallel, they should share implementations as much as possible. ## Breaking changes The GitLab GraphQL API is [versionless](https://graphql.org/learn/best-practices/#versioning) and changes are made to the API in a way that maintains backwards-compatibility. Occasionally GitLab needs to change the GraphQL API in a way that is not backwards-compatible. These changes include the removal or renaming of fields, arguments or other parts of the schema. In these situations, GitLab follows a [Deprecation and removal process](#deprecation-and-removal-process) where the deprecated part of the schema is supported for a period of time before being removed. There are some changes which are explicitly [not considered breaking](../../development/contributing/#breaking-changes). Clients should familiarize themselves with the process to avoid breaking changes affecting their integrations. WARNING: While GitLab will make all attempts to follow the [deprecation and removal process](#deprecation-and-removal-process), GitLab may on very rare occasions need to make immediate breaking changes to the GraphQL API to patch critical security or performance concerns and where the deprecation process would be considered to pose significant risk. NOTE: Fields behind a feature flag and disabled by default are exempt from the deprecation process, and can be removed at any time without notice. ### Deprecation and Removal process The deprecation and removal process for the GitLab GraphQL API aligns with the wider GitLab [deprecation process](https://about.gitlab.com/handbook/product/gitlab-the-product/#breaking-changes-deprecations-and-removing-features). Parts of the schema marked for removal from the GitLab GraphQL API are first [deprecated](https://about.gitlab.com/handbook/product/gitlab-the-product/#deprecation) but still available for at least six releases, and then [removed](https://about.gitlab.com/handbook/product/gitlab-the-product/#removal) entirely. Removals occur on `XX.0` major releases. Items are marked as deprecated [in the schema](https://spec.graphql.org/October2021/#sec--deprecated), and are also displayed as deprecated in: - The [GraphQL API reference](reference/index.md). - The [deprecation feature removal schedule](../../update/deprecations.md), which is linked to in release posts. - Introspection queries of the GraphQL API. NOTE: Consumers of the GraphQL API are encouraged to remove the use of deprecated schema in their GraphQL API calls as soon as possible to avoid experiencing breaking changes. If an alternative is provided for the deprecated schema item, then its deprecation message mentions this. **Example:** The following fields could both be removed in `14.0`: | Field deprecated in | Reason | | --- | --- | | `12.7` | As GitLab traditionally has 12 minor releases per major release, the next major release that occurs 6 months after the field was deprecated is `14.0`, rather than `13.0`. | | `13.6` | The removal in `14.0` allows for 6 months of deprecation. | ### List of removed items View the [list of items removed](removed_items.md) in previous releases. ## Available queries The GraphQL API includes the following queries at the root level: 1. `project` : Project information, with many of its associations such as issues and merge requests. 1. `group` : Basic group information and epics **(ULTIMATE)** are currently supported. 1. `user` : Information about a particular user. 1. `namespace` : Within a namespace it is also possible to fetch `projects`. 1. `currentUser`: Information about the currently logged in user. 1. `users`: Information about a collection of users. 1. `metaData`: Metadata about GitLab and the GraphQL API. 1. `snippets`: Snippets visible to the currently logged in user. New associations and root level objects are constantly being added. See the [GraphQL API Reference](reference/index.md) for up-to-date information. Root-level queries are defined in [`app/graphql/types/query_type.rb`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/app/graphql/types/query_type.rb). ### Multiplex queries GitLab supports batching queries into a single request using [apollo-link-batch-http](https://www.apollographql.com/docs/link/links/batch-http/). More information about multiplexed queries is also available for [GraphQL Ruby](https://graphql-ruby.org/queries/multiplex.html), the library GitLab uses on the backend. ## Limits The following limits apply to the GitLab GraphQL API. ### Max page size By default, connections return at most `100` records ("nodes") per page, and this limit applies to most connections in the API. Particular connections may have different max page size limits that are higher or lower. ### Max query complexity The GitLab GraphQL API scores the _complexity_ of a query. Generally, larger queries will have a higher complexity score. This limit is designed to protect the API from performing queries that could negatively impact its overall performance. The complexity of a single query is limited to a maximum of: - `200` for unauthenticated requests. - `250` for authenticated requests. The complexity score of a query and limit for the request [can be queried for](getting_started.md#query-complexity). If a query exceeds the complexity limit an error message response will be returned. In general, each field in a query will add `1` to the complexity score, although this can be higher or lower for particular fields. Sometimes the addition of certain arguments may also increase the complexity of a query. NOTE: The complexity limits may be revised in future, and additionally, the complexity of a query may be altered. ### Request timeout Requests time out at 30 seconds. ### Spam GraphQL mutations can be detected as spam. If this happens, a [GraphQL top-level error](https://spec.graphql.org/June2018/#sec-Errors) is raised. For example: ```json { "errors": [ { "message": "Request denied. Spam detected", "locations": [ { "line": 6, "column": 7 } ], "path": [ "updateSnippet" ], "extensions": { "spam": true } } ], "data": { "updateSnippet": { "snippet": null } } } ``` If mutation is detected as potential spam and a CAPTCHA service is configured: - The `captchaSiteKey` should be used to obtain a CAPTCHA response value using the appropriate CAPTCHA API. Only [Google reCAPTCHA v2](https://developers.google.com/recaptcha/docs/display) is supported. - The request can be resubmitted with the `X-GitLab-Captcha-Response` and `X-GitLab-Spam-Log-Id` headers set. ```json { "errors": [ { "message": "Request denied. Solve CAPTCHA challenge and retry", "locations": [ { "line": 6, "column": 7 } ], "path": [ "updateSnippet" ], "extensions": { "needsCaptchaResponse": true, "captchaSiteKey": "6LeIxAcTAAAAAJcZVRqyHh71UMIEGNQ_MXjiZKhI", "spamLogId": 67 } } ], "data": { "updateSnippet": { "snippet": null, } } } ```