graphql-mcp-server
Provides tools for interacting with any GraphQL API, automatically generating tools for queries and mutations based on schema introspection.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@graphql-mcp-serverfetch the latest 5 posts"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
GraphQL MCP Server
A Model Context Protocol (MCP) server that dynamically generates tools for any GraphQL API by introspecting its schema.
Features
Automatic tool generation from GraphQL schema introspection
Support for all GraphQL queries and mutations
Type-safe variable handling
Automatic query generation with smart field selection
Error handling and validation
Function exposure control via exposed.yaml
Bearer token authentication support
Function Exposure Control
The server automatically manages which GraphQL functions are exposed as MCP tools through an exposed.yaml file:
How it works
First run: Server discovers all GraphQL queries and mutations, creates
exposed.yamlwith all functions set totrueSubsequent runs: Only functions marked as
trueinexposed.yamlare registered as MCP toolsDynamic updates: New functions are automatically added to the file with default
truevalueCleanup: Functions that no longer exist in the schema are removed from the file
exposed.yaml format
exposed:
queries:
getUser: true
listPosts: false
searchContent: true
mutations:
createUser: true
deleteUser: false
updatePost: trueManaging exposed functions
Set a function to
falseto disable it (won't be registered as MCP tool)Set a function to
trueto enable it (will be registered as MCP tool)The file is automatically updated when the schema changes
Installation
npm installConfiguration
GraphQL Endpoint
Set the GraphQL endpoint URL via environment variable or command line argument:
# Via environment variable
export GRAPHQL_URL="https://api.example.com/graphql"
# Via command line argument
node src/index.js --graphql-url "https://api.example.com/graphql"GraphQL API Authentication
For GraphQL APIs requiring Bearer token authentication:
# Via environment variable
export GRAPHQL_TOKEN="your-bearer-token"
# Via command line argument
node src/index.js --token "your-bearer-token"
# Both URL and token as arguments
node src/index.js --graphql-url "https://api.example.com/graphql" --token "your-bearer-token"Usage
Running the server
STDIO Transport (default)
npm start
# or
node src/index.jsHTTP Transport
npm run start:http
# or
node src/index.js --transport http
# Custom port
node src/index.js --transport http --port 8080Development mode
# STDIO transport
npm run dev
# HTTP transport
npm run dev:httpCommand Line Options
node src/index.js [options]
Options:
-t, --transport <type> Transport type: stdio or http (default: stdio)
-p, --port <number> HTTP port (default: 3000)
-u, --graphql-url <url> GraphQL endpoint URL
-T, --token <token> Bearer token for authentication
-q, --query-prefix <str> Prefix for query tools (default: none)
-m, --mutation-prefix <str> Prefix for mutation tools (default: none)
-h, --help Show help messageIntegration with Claude Desktop
STDIO Transport
Add to your Claude Desktop configuration:
{
"mcpServers": {
"graphql": {
"command": "node",
"args": ["/path/to/graphql-mcp-server/src/index.js"],
"env": {
"GRAPHQL_URL": "https://api.example.com/graphql",
"GRAPHQL_TOKEN": "your-bearer-token"
}
}
}
}Alternative using command line arguments:
{
"mcpServers": {
"graphql": {
"command": "node",
"args": [
"/path/to/graphql-mcp-server/src/index.js",
"--graphql-url", "https://api.example.com/graphql",
"--token", "your-bearer-token"
]
}
}
}HTTP Transport
For HTTP transport, start the server separately:
# Start the server with environment variables
GRAPHQL_URL="https://api.example.com/graphql" GRAPHQL_TOKEN="your-bearer-token" node src/index.js --transport http --port 3000
# Or using command line arguments
node src/index.js --transport http --port 3000 --graphql-url "https://api.example.com/graphql" --token "your-bearer-token"Then configure your MCP client to connect to the HTTP endpoint at http://localhost:3000/mcp.
MCP Server Authentication (HTTP Transport)
When using HTTP transport, you can secure the MCP server with bearer token authentication:
# Set AUTH_TOKEN environment variable
export AUTH_TOKEN="your-mcp-secret-token"
node src/index.js --transport http
# Or in docker-compose.yml
environment:
- AUTH_TOKEN=your-mcp-secret-tokenWhen AUTH_TOKEN is set, clients can authenticate using either:
Authorization header (recommended):
Authorization: Bearer your-mcp-secret-tokenURL query parameter:
http://localhost:3000/mcp?token=your-mcp-secret-token
Authentication behavior:
If
AUTH_TOKENis set, all requests must provide valid authenticationRequests without valid tokens receive 401 Unauthorized
If
AUTH_TOKENis not set, the server allows open access (no authentication required)The server checks the Authorization header first, then falls back to the URL parameter
HTTP API Endpoints
When running with HTTP transport:
POST /mcp - Main MCP protocol endpoint
GET /mcp - Returns method not allowed (405)
Example HTTP Usage
# Without authentication (when AUTH_TOKEN is not set)
curl -X POST http://localhost:3000/mcp \
-H "Content-Type: application/json" \
-d '{"jsonrpc": "2.0", "id": 1, "method": "tools/list"}'
# With authentication using header (when AUTH_TOKEN is set)
curl -X POST http://localhost:3000/mcp \
-H "Content-Type: application/json" \
-H "Authorization: Bearer your-mcp-secret-token" \
-d '{"jsonrpc": "2.0", "id": 1, "method": "tools/list"}'
# With authentication using URL parameter (when AUTH_TOKEN is set)
curl -X POST "http://localhost:3000/mcp?token=your-mcp-secret-token" \
-H "Content-Type: application/json" \
-d '{"jsonrpc": "2.0", "id": 1, "method": "tools/list"}'
# Call a GraphQL query tool
curl -X POST http://localhost:3000/mcp \
-H "Content-Type: application/json" \
-d '{
"jsonrpc": "2.0",
"id": 1,
"method": "tools/call",
"params": {
"name": "query_getUser",
"arguments": {
"variables": {
"id": "123"
}
}
}
}'How it works
On startup, the server connects to the specified GraphQL endpoint (with optional Bearer token authentication)
It loads the
exposed.yamlconfiguration file (creates it if it doesn't exist)It performs an introspection query to fetch the complete schema
For each query and mutation in the schema, it checks if the function is enabled in
exposed.yamlOnly enabled functions are registered as MCP tools with prefixes:
query_for queries andmutation_for mutationsNew functions discovered in the schema are automatically added to
exposed.yamlas enabledWhen a tool is called, it constructs the appropriate GraphQL query/mutation and executes it
Results are returned as formatted JSON
Tool naming convention
Queries:
query_<fieldName>(e.g.,query_getUser,query_listPosts)Mutations:
mutation_<fieldName>(e.g.,mutation_createUser,mutation_updatePost)
Environment Variables
Variable | Description | Required |
| GraphQL endpoint URL | Yes (if not provided via |
| Bearer token for GraphQL API authentication | No |
| Bearer token for MCP server authentication (HTTP transport only) | No |
Files
File | Description |
| Configuration file controlling which GraphQL functions are exposed as MCP tools |
Transport Protocols
The server supports two transport protocols:
STDIO Transport
Default transport for MCP
Uses standard input/output for communication
Suitable for direct integration with MCP clients
Lower overhead, faster communication
HTTP Transport
StreamableHTTP transport using MCP SDK
JSON-RPC over HTTP
Express.js server for HTTP handling
Suitable for web applications and remote access
Standard MCP protocol compliance
Example
For a GraphQL schema with:
type Query {
getUser(id: ID!): User
listPosts(limit: Int): [Post]
}
type Mutation {
createUser(input: CreateUserInput!): User
}The MCP server will generate tools:
query_getUser- with requiredidparameterquery_listPosts- with optionallimitparametermutation_createUser- with requiredinputparameter
License
MIT
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/vogler75/graphql-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server