GitHub Prod MCP
A production-ready MCP server for GitHub operations, providing tools for repository management, issues, pull requests, and more via both MCP stdio and REST API.
README
GitHub Prod MCP
Production-ready GitHub MCP server implemented in Python, based on the official GitHub REST API documentation at https://docs.github.com/en/rest.
Features
- MCP stdio server for GitHub operations
- REST API wrapper exposing the same tools
- POST-only tool endpoints
- Request-body-only inputs for tool APIs
- Centralized validation with Pydantic models
- GitHub API version header support
- Timeout handling and normalized API errors
- Shared service layer for MCP and REST parity
Implemented tools
get_authenticated_usercreate_repositoryget_repositoryget_repository_detailslist_branchesget_branchlist_repository_filesget_file_contentsearch_repositoriessearch_codesearch_issueslist_issuesget_issuecreate_issueupdate_issuecreate_issue_commentlist_pull_requestsget_pull_requestcreate_pull_requestmerge_pull_requestget_commitcompare_commitscreate_or_update_filedelete_filecreate_repository_dispatchtrigger_workflow_dispatchlist_workflow_runs
Project structure
src/github_prod_mcp/main.py- MCP stdio serversrc/github_prod_mcp/rest_api.py- REST API wrappersrc/github_prod_mcp/github_api.py- GitHub REST clientsrc/github_prod_mcp/service.py- shared business layersrc/github_prod_mcp/models.py- request and response schemassrc/github_prod_mcp/config.py- environment-driven settings
Requirements
- Python 3.10+
- A GitHub token with the scopes required for the operations you plan to use
Setup
1. Create a virtual environment
PowerShell:
python -m venv .venv
.venv\Scripts\Activate.ps1
2. Install dependencies
python -m pip install --upgrade pip
python -m pip install -e .
3. Configure environment
Copy .env.example to .env and set your token:
GITHUB_TOKEN=ghp_your_token_here
GITHUB_API_BASE_URL=https://api.github.com
GITHUB_API_VERSION=2022-11-28
GITHUB_USER_AGENT=github-prod-mcp/0.1.0
GITHUB_TIMEOUT_SECONDS=30
REST_HOST=127.0.0.1
REST_PORT=8080
LOG_LEVEL=INFO
Run the MCP server
python -m github_prod_mcp.main
Run the REST API
python -m github_prod_mcp.rest_api
REST docs will be available at:
http://127.0.0.1:8080/docshttp://127.0.0.1:8080/openapi.json
REST API design rule
All tool endpoints are exposed as POST endpoints under /tools/....
For tool execution:
- no path variables
- no query variables
- inputs are passed in the JSON request body only
Examples:
Get repository
POST /tools/get_repository
Content-Type: application/json
{
"owner": "octocat",
"repo": "Hello-World"
}
Get repository details
POST /tools/get_repository_details
Content-Type: application/json
{
"owner": "octocat",
"repo": "Hello-World",
"include_branches": true,
"include_root_files": true,
"include_readme": false
}
List repository files
POST /tools/list_repository_files
Content-Type: application/json
{
"owner": "octocat",
"repo": "Hello-World",
"path": "",
"ref": "main"
}
Get file content metadata
POST /tools/get_file_content
Content-Type: application/json
{
"owner": "octocat",
"repo": "Hello-World",
"path": "README.md",
"ref": "main"
}
Create issue
POST /tools/create_issue
Content-Type: application/json
{
"owner": "octocat",
"repo": "Hello-World",
"title": "Bug report",
"body": "Something is broken"
}
Trigger workflow dispatch
POST /tools/trigger_workflow_dispatch
Content-Type: application/json
{
"owner": "octocat",
"repo": "Hello-World",
"workflow_id": "ci.yml",
"ref": "main",
"inputs": {
"environment": "prod"
}
}
MCP registration
Update .bob/mcp.json so Bob can launch the stdio server.
Example configuration:
{
"mcpServers": {
"github-prod-mcp": {
"command": "python",
"args": [
"-m",
"github_prod_mcp.main"
],
"cwd": "c:/Users/abdenourChenouf/Documents/MCP-Github/github-prod-mcp",
"env": {
"GITHUB_TOKEN": "YOUR_GITHUB_TOKEN",
"GITHUB_API_BASE_URL": "https://api.github.com",
"GITHUB_API_VERSION": "2022-11-28",
"GITHUB_USER_AGENT": "github-prod-mcp/0.1.0",
"GITHUB_TIMEOUT_SECONDS": "30",
"LOG_LEVEL": "INFO"
},
"disabled": false,
"alwaysAllow": [],
"disabledTools": []
}
}
}
Production notes
- Use a fine-grained GitHub token with least privilege
- Rotate tokens regularly
- Keep
.envout of source control - Run the REST API behind a reverse proxy for TLS and access control
- Add request authentication in front of the REST API before internet exposure
- Tune timeout and logging for your environment
- Add tests before deploying to shared environments
Official API basis
This implementation follows GitHub REST API conventions including:
Accept: application/vnd.github+jsonAuthorization: Bearer <token>X-GitHub-Api-Version: 2022-11-28
Reference:
https://docs.github.com/en/rest
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.