GitHub Prod MCP
Provides tools for interacting with GitHub's API, enabling AI agents to manage repositories, issues, pull requests, and other GitHub resources.
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., "@GitHub Prod MCPshow me the open pull requests for octocat/Hello-World"
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.
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
Related MCP server: GitHub MCP Server Plus
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.ps12. 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=INFORun the MCP server
python -m github_prod_mcp.mainRun the REST API
python -m github_prod_mcp.rest_apiREST 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 controlRun 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
Maintenance
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/nouhailadahmany/github-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server