ZenHub
Access the ZenHub GraphQL API to manage project workflows and enhance productivity.
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
Verwandte Server
Obsidian Semantic MCP Server
An AI-optimized MCP server for Obsidian that consolidates over 21 tools into 5 intelligent operations with contextual workflow hints.
Bexio MCP
Complete Swiss accounting integration for Bexio via MCP. Works with Claude Desktop, n8n, and any MCP client. 221 tools for invoices, contacts, projects & more.
PaperlessMCP
MCP server for Paperless-ngx document management. 43 tools for AI-powered document organization - full CRUD on documents, tags, correspondents, document types, storage paths, and custom fields.
Omnispindle
A todo management system designed for coordinating tasks across multiple projects, utilizing MongoDB and MQTT.
GoHighLevel
Integrate GoHighLevel with AI assistants like Claude and ChatGPT using a private API key.
Outlook Calendar
Access and manage your local Microsoft Outlook calendar on Windows.
Mcptix
A simple and powerful ticket tracking system with AI assistant integration.
Valkey AI Tasks
A task management system for AI agents that uses Valkey as its persistence layer.
Taiwan Holiday
Provides Taiwan national holidays and compensatory workday information. Data is fetched and cached automatically.
PostalForm MCP
Mail real letters from agents: PDF → checkout → status.