zenhub-mcp
Provides full access to the ZenHub GraphQL API. Enables project management operations like creating issues, epics, workspaces, and sprints through natural language.
README
ZenHub MCP Server
An MCP (Model Context Protocol) server that provides full access to the ZenHub GraphQL API.
Features
- Full GraphQL Access: Execute any GraphQL query against the ZenHub API
- Common Operations: Built-in tools for frequent tasks like creating issues, epics, workspaces, and sprints
- Secure Authentication: API key-based authentication for all requests
- Error Handling: Comprehensive error handling and validation
Installation
For Development
npm install
npm run build
Setup API Key
-
Get your ZenHub API key from ZenHub Settings
-
Set the environment variable:
export ZENHUB_API_KEY=your_api_key_here
Or create a .env file (copy from .env.example):
cp .env.example .env
# Edit .env and add your API key
For Claude Desktop
- Build the server:
npm install
npm run build
- Add to your Claude Desktop config (
~/Library/Application Support/Claude/claude_desktop_config.jsonon macOS):
{
"mcpServers": {
"zenhub": {
"command": "npx",
"args": ["zenhub-mcp-server"],
"env": {
"ZENHUB_API_KEY": "your_api_key_here"
}
}
}
}
For Cursor
- Build the server:
npm install
npm run build
- In Cursor, go to Settings > MCP Servers and add:
{
"name": "zenhub",
"command": "node",
"args": ["/path/to/zenhub-mcp/dist/index.js"],
"env": {
"ZENHUB_API_KEY": "zh_",
"GITHUB_PAT": "github_pat_"
}
}
Or use the development server:
{
"name": "zenhub-dev",
"command": "npm",
"args": ["run", "dev"],
"cwd": "/path/to/zenhub-mcp",
"env": {
"ZENHUB_API_KEY": "your_api_key_here"
}
}
Tools
The server provides 54 tools across 10 categories, implementing the most commonly used ZenHub operations:
No API key required in tool calls - Set ZENHUB_API_KEY environment variable once and use all tools!
Query Tools (7 tools)
zenhub_query
Execute any GraphQL query against the ZenHub API.
query(required): GraphQL query stringvariables(optional): Variables for the query
zenhub_search_issues
Search for issues in a pipeline.
pipeline_id(required): Pipeline ID to search inquery(optional): Search query for titlefilters(optional): Object with filters for labels and assignees
zenhub_search_issues_in_repository
Search and filter issues inside repository.
repository_id(required): Repository ID to search inquery(optional): Search queryfilters(optional): Filter options
zenhub_get_workspace_issues
Get all issues in a workspace (paginated).
workspace_id(required): Workspace IDafter(optional): Cursor for pagination
zenhub_get_viewer
Get current ZenHub user information.
zenhub_get_issue_by_info
Lookup an issue by repository and issue number.
repository_gh_id(required): GitHub repository IDissue_number(required): Issue number
zenhub_get_repositories
Lookup repositories by their GitHub IDs.
repository_gh_ids(required): Array of GitHub repository IDs
Issue Management (13 tools)
zenhub_create_issue
Create a new GitHub issue via ZenHub.
title(required): Issue titlerepository_id(required): Repository IDbody(optional): Issue descriptionlabels(optional): Array of label namesassignees(optional): Array of GitHub usernames
zenhub_close_issues
Close one or more issues.
issue_ids(required): Array of issue IDs
zenhub_reopen_issues
Reopen one or more closed issues.
issue_ids(required): Array of issue IDspipeline_id(required): Pipeline ID to move issues toposition(optional): Position in pipeline (START or END)
zenhub_move_issue
Move issues to a position in a pipeline.
issue_ids(required): Array of issue IDspipeline_id(required): Pipeline ID to move issues toposition(optional): Position in pipeline (0-based)
zenhub_add_assignees_to_issues
Add assignees to multiple issues.
issue_ids(required): Array of issue IDsassignees(required): Array of GitHub usernames
zenhub_add_labels_to_issues
Add labels to multiple issues.
issue_ids(required): Array of issue IDslabels(required): Array of label names
zenhub_set_estimate
Set an estimate for an issue.
issue_id(required): Issue IDvalue(required): Estimate value
zenhub_set_multiple_estimates
Set estimates on multiple issues.
estimates(required): Array of issue ID and estimate value pairs
zenhub_add_issues_to_epics
Add issues to epics.
issue_ids(required): Array of issue IDsepic_ids(required): Array of epic IDs
Epic Management (1 tool)
zenhub_create_epic
Create a new epic in ZenHub.
title(required): Epic titlerepository_id(required): Repository IDbody(optional): Epic description
Workspace Management (4 tools)
zenhub_get_user_workspaces
Get all workspaces accessible to the current user.
query(optional): Search query to filter workspacesfirst(optional): Number of workspaces to return (default: 20)
zenhub_get_user_organizations
Get all ZenHub organizations accessible to the current user.
query(optional): Search query to filter organizationsfirst(optional): Number of organizations to return (default: 10)
zenhub_get_organization_workspaces
Get all workspaces within a specific ZenHub organization.
organization_id(required): ZenHub organization IDquery(optional): Search query to filter workspacesfirst(optional): Number of workspaces to return (default: 20)
zenhub_create_workspace
Create a new workspace in ZenHub.
name(required): Workspace namedescription(optional): Workspace descriptionorganization_id(required): ZenHub organization IDrepository_ids(required): Array of GitHub repository IDsdefault_repository_id(optional): Default repository ID
Sprint Management (2 tools)
zenhub_create_sprint
Create a new sprint.
name(required): Sprint namestart_date(required): Start date (ISO format)end_date(required): End date (ISO format)workspace_id(required): Workspace IDtimezone(optional): Timezone identifiersettings(optional): Sprint settings object
zenhub_add_issues_to_sprints
Add issues to sprints.
issue_ids(required): Array of issue IDssprint_ids(required): Array of sprint IDs
Architecture
The server uses a modular architecture for easy expansion:
src/
├── index.ts # Main MCP server
├── types.ts # TypeScript interfaces
└── tools/
├── index.ts # Tool registry
├── base.ts # Base tool class
├── queries.ts # Query tools
├── issues.ts # Issue management tools
├── epics.ts # Epic management tools
├── workspaces.ts # Workspace management tools
└── sprints.ts # Sprint management tools
Adding New Tools
- Create a new tool class extending
BaseToolin the appropriate category file - Add it to the tool export array
- The tool will automatically be registered with the MCP server
Available Operations Reference
All 176 available ZenHub GraphQL operations are documented in:
zenhub_api_operations.json- Complete operation list with descriptionsmutations.json- All 157 mutationsqueries.json- All 19 queries
Current implementation covers 54 of 176 operations (30.7%)
Development
npm run dev
Environment Variables
ZENHUB_API_KEY(required): Your ZenHub API key from ZenHub SettingsZENHUB_MCP_CUSTOM_INSTRUCTIONS(optional): Provide additional instructions for the MCP server. If set, this value will be appended to the default instructions that the server sends to the model. Use regular newlines or\nescape sequences to format multi-line prompts.
GraphQL Endpoint
This server connects to: https://api.zenhub.com/public/graphql
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.