GraphQL
This handler allows you to load remote GraphQL schemas and use them with schema-stitching based on
graphql-tools
.
To get started, install the handler library:
yarn add @graphql-mesh/graphql
Now, you can use it directly in your Mesh config file:
sources:
- name: MyGraphQLApi
handler:
graphql:
endpoint: http://my-service-url:3000/graphql
You can check out our example that uses schema stitching with a PostgreSQL data source. Click here to open the example on GitHub (opens in a new tab)
Headers
Read about configuration and examples
Fetching SDL or introspection from CDN or any other schema registry tool
Let's say the introspection disabled in your production environment of your GraphQL source, and you want to provide your SDL or introspection seperately;
sources:
- name: MyGraphQLApi
handler:
graphql:
endpoint: https://api.github.com/graphql
# You can provide your SDL or introspection seperately
source: https://docs.github.com/public/schema.docs.graphql
operationHeaders:
Authorization: Bearer {env.GITHUB_TOKEN}
In this case, CLI's
build
command won't save the introspection in the artifacts, so your Mesh won't start ifsource
URL is down.
Hive Integration
If you use GraphQL Hive (opens in a new tab) to manage your GraphQL APIs as a schema registry, you can use the following configuration to fetch your schema from Hive:
sources:
- name: MyGraphQLApi
handler:
graphql:
endpoint: https://my-api.com/graphql
source: https://cdn.graphql-hive.com/asce7c12-753d-hive-bee-d7f2c803e232/sdl?ext=.graphql
schemaHeaders:
X-Hive-CDN-Key: 'aabTxbEyC78NvSPQNO+qLrrRnBvODJJ8k4sL/2EtIwc='
Local Schemas
We recommend providing local schema by using the additionalTypeDefs
and additionalResolvers
configuration options.
However, it is also possible to use a local GraphQL Schema instance as a GraphQL Mesh source, as showcased below:
sources:
- name: MyGraphQLApi
handler:
graphql:
source: ./my-local-schema.ts
import { makeExecutableSchema } from '@graphql-tools/schema'
export default makeExecutableSchema({
typeDefs: /* GraphQL */ `
type Query {
foo: String
}
`,
resolvers: {
Query: {
foo: () => 'FOO'
}
}
})
Fetch Strategies and Multiple HTTP endpoints for the same source
If you want to have an advanced fetch strategy for the GraphQL source such as retrying twice or timeout in 30 seconds etc. Also, you can have different HTTP endpoints for a single source, and you can configure Mesh to get a better execution flow.
For example, you can make a request to both endpoints and return the fastest response with race
strategy.
All fetch
strategies can be combined to create the ultimate execution flow:
retry
The retry
mechanism allow you to specify the retry attempts for a single GraphQL endpoint/source.
The retry flow will execute in both conditions: a network error, or due to a runtime error.
sources:
- name: uniswapv2
handler:
graphql:
endpoint: https://api.thegraph.com/subgraphs/name/uniswap/uniswap-v2
retry: 2 # specify here, if you have an unstable/error prone indexer
timeout
The timeout
mechanism allow you to specify the timeout
for a given GraphQL endpoint.
sources:
- name: uniswapv2
handler:
graphql:
endpoint: https://api.thegraph.com/subgraphs/name/uniswap/uniswap-v2
timeout: 5000 # 5 seconds
fallback
The fallback
mechanism allow you to specify use more than one GraphQL endpoint, for the same
source.
This is helpful if you have a fallback endpoint for the same GraphQL API.
sources:
- name: uniswapv2
handler:
graphql:
strategy: fallback
sources:
- endpoint: https://bad-uniswap-v2-api.com
retry: 2
timeout: 5000
- endpoint: https://api.thegraph.com/subgraphs/name/uniswap/uniswap-v2
race
The race
mechanism allow you to specify use more than one GraphQL endpoint, for the same source,
and race on every execution.
If you have different places that service is deployed, this is useful to get the fastest response by racing them.
sources:
- name: uniswapv2
handler:
graphql:
strategy: race
sources:
- endpoint: https://bad-uniswap-v2-api.com
- endpoint: https://api.thegraph.com/subgraphs/name/uniswap/uniswap-v2
Config API Reference
endpoint
(type:String
, required) - A url or file path to your remote GraphQL endpoint. If you provide a path to a code file(js or ts), other options will be ignored and the schema exported from the file will be used directly.schemaHeaders
(type:Any
) - JSON object representing the Headers to add to the runtime of the API calls only for schema introspectionoperationHeaders
(type:JSON
) - JSON object representing the Headers to add to the runtime of the API calls only for operation during runtimeuseGETForQueries
(type:Boolean
) - Use HTTP GET for Query operationsmethod
(type:String (GET | POST)
) - HTTP method used for GraphQL operationscredentials
(type:String (omit | include)
) - Request Credentials if your environment supports it. See more (opens in a new tab)
@default "same-origin"
webSocketImpl
(type:String
) - Path to a custom W3 Compatible WebSocket Implementationsource
(type:String
) - Path to the introspection You can separately give schema introspection or SDLsubscriptionsProtocol
(type:String (SSE | WS | LEGACY_WS)
) - SSE - Server Sent Events WS - New graphql-ws LEGACY_WS - Legacy subscriptions-transport-wssubscriptionsEndpoint
(type:String
) - URL to your endpoint serving all subscription queries for this sourceretry
(type:Int
) - Retry attempts if failstimeout
(type:Int
) - Timeout in millisecondsbatch
(type:Boolean
) - Enable/Disable automatic query batching
or
source
(type:Any
, required) - A file path to your GraphQL Schema If you provide a path to a code file(js or ts), other options will be ignored and the schema exported from the file will be used directly.