GitHub MCP Server
A Python-based Model Context Protocol server that provides 87 tools for comprehensive interaction with the GitHub API. It enables AI agents to manage repositories, issues, pull requests, workflows, and projects through automated commands.
README
GitHub MCP Server
A comprehensive Model Context Protocol (MCP) server for the GitHub API, built with Python and the official MCP SDK.
This server exposes 87 tools across 25 categories, enabling AI agents like Claude to interact with GitHub repositories, issues, pull requests, discussions, projects, and more.
Features
| Category | Tools | Description |
|---|---|---|
| Repositories | 7 | List, get, create, fork repos; list commits; get commit details; get file contents |
| Issues | 6 | List, get, create, update issues; manage comments |
| Pull Requests | 8 | List, get, create, update, merge PRs; view files/commits; update branch |
| Search | 4 | Search repositories, code, issues, and users |
| Actions | 4 | List workflows/runs, trigger workflows, cancel runs |
| Releases | 4 | List, get latest, create releases; get release by tag |
| Tags | 2 | List tags, get annotated tag details |
| Git | 2 | Get repository tree, push multiple files in a single commit |
| Organizations | 3 | List orgs, get details, list members |
| Branches | 3 | List, create, delete branches |
| Branch Protection | 3 | Get, update, delete branch protection rules |
| Webhooks | 3 | List, create, delete repository webhooks |
| Files | 2 | Create/update and delete files via the Contents API |
| PR Reviews | 2 | Create and list pull request reviews |
| Review Comments | 3 | List, create, reply to PR review comments |
| Commit Statuses | 4 | List/create commit statuses; list/get check runs |
| Labels | 3 | List, create, delete repository labels |
| Gists | 4 | List, get, create, update gists |
| Stars | 3 | List starred repos, star/unstar repositories |
| Users | 2 | Get authenticated user info, get any user's profile |
| Notifications | 3 | List notifications, mark as read |
| Collaborators | 3 | List, add, remove repository collaborators |
| Discussions | 4 | List, get discussions; view comments; list categories (GraphQL) |
| Projects (Classic) | 2 | List repository and organization projects |
| Projects V2 | 3 | List, get projects; list project items (GraphQL) |
Requirements
- Python >= 3.10
- uv (recommended) or pip
- GitHub Personal Access Token
Installation
git clone https://github.com/software-engineer-mj/github-mcp.git
cd github-mcp
uv sync
Configuration
cp .env.example .env
Edit the .env file:
GITHUB_TOKEN=ghp_your_token_here
Token Permissions
Depending on which tools you use, your token needs these scopes:
| Scope | Required For |
|---|---|
repo |
Repositories, issues, PRs, branches, webhooks, collaborators, files, tags, git |
read:org |
Organizations, org members, org projects |
gist |
Gists |
notifications |
Notifications |
user |
Authenticated user info, starring |
workflow |
GitHub Actions (trigger, cancel) |
read:discussion |
Discussions |
project |
Projects (Classic), Projects V2 |
Usage
stdio (default)
uv run python -m github_mcp
Docker
docker build -t github-mcp .
docker run -e GITHUB_TOKEN=ghp_your_token github-mcp
MCP Client Configuration
Claude Desktop
Add to claude_desktop_config.json:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"github": {
"command": "uv",
"args": ["run", "--directory", "/path/to/github-mcp", "python", "-m", "github_mcp"],
"env": {
"GITHUB_TOKEN": "ghp_your_token_here"
}
}
}
}
Claude Code
Add to .mcp.json:
{
"mcpServers": {
"github": {
"command": "uv",
"args": ["run", "--directory", "/path/to/github-mcp", "python", "-m", "github_mcp"],
"env": {
"GITHUB_TOKEN": "ghp_your_token_here"
}
}
}
}
Development
# Install with dev dependencies
uv sync --dev
# Run tests
uv run pytest tests/ -v
# Lint
uv run ruff check src/ tests/
# Format
uv run ruff format src/ tests/
# Type check
uv run mypy src/
Tool Reference
Repositories
| Tool | Description |
|---|---|
list_repositories |
List repositories for a user or organization |
get_repository |
Get detailed repository information |
create_repository |
Create a new repository |
fork_repository |
Fork a repository |
list_commits |
List commits with optional filters (author, date range) |
get_commit |
Get commit details including stats and changed files |
get_file_contents |
Get file contents or directory listing |
Issues
| Tool | Description |
|---|---|
list_issues |
List issues with filters (state, labels, assignee) |
get_issue |
Get detailed issue information |
create_issue |
Create a new issue |
update_issue |
Update issue title, body, state, labels, assignees |
list_issue_comments |
List comments on an issue |
create_issue_comment |
Add a comment to an issue |
Pull Requests
| Tool | Description |
|---|---|
list_pull_requests |
List PRs with filters (state, base, head) |
get_pull_request |
Get detailed PR info including mergeable status |
create_pull_request |
Create a new pull request |
update_pull_request |
Update PR title, body, state, base branch |
merge_pull_request |
Merge a PR (merge, squash, or rebase) |
list_pr_files |
List files changed in a PR |
list_pr_commits |
List commits in a PR |
update_pull_request_branch |
Update a PR branch with the latest base branch changes |
Search
| Tool | Description |
|---|---|
search_repositories |
Search repos by name, language, stars, topics |
search_code |
Search code across repositories |
search_issues |
Search issues and PRs across GitHub |
search_users |
Search users by name, location, followers |
Actions
| Tool | Description |
|---|---|
list_workflows |
List GitHub Actions workflows |
list_workflow_runs |
List workflow runs with status filters |
trigger_workflow |
Trigger a workflow dispatch event |
cancel_workflow_run |
Cancel a running workflow |
Releases
| Tool | Description |
|---|---|
list_releases |
List releases in a repository |
get_latest_release |
Get the latest published release |
create_release |
Create a new release with tag |
get_release_by_tag |
Get a release by its tag name |
Tags
| Tool | Description |
|---|---|
list_tags |
List tags in a repository |
get_tag |
Get an annotated tag object by SHA |
Git
| Tool | Description |
|---|---|
get_repository_tree |
Get repository tree (directory listing) by SHA or branch |
push_files |
Push multiple files in a single commit via Git Data API |
Organizations
| Tool | Description |
|---|---|
list_user_orgs |
List authenticated user's organizations |
get_organization |
Get organization details |
list_org_members |
List organization members |
Branches
| Tool | Description |
|---|---|
list_branches |
List branches in a repository |
create_branch |
Create a new branch from an existing one |
delete_branch |
Delete a branch |
Branch Protection
| Tool | Description |
|---|---|
get_branch_protection |
Get branch protection rules |
update_branch_protection |
Update branch protection settings |
delete_branch_protection |
Delete branch protection |
Webhooks
| Tool | Description |
|---|---|
list_webhooks |
List repository webhooks |
create_webhook |
Create a webhook with event subscriptions |
delete_webhook |
Delete a webhook |
Files
| Tool | Description |
|---|---|
create_or_update_file |
Create or update a file (requires SHA for updates) |
delete_file |
Delete a file from a repository |
PR Reviews
| Tool | Description |
|---|---|
create_pr_review |
Submit a review (APPROVE, REQUEST_CHANGES, COMMENT) |
list_pr_reviews |
List reviews on a pull request |
Review Comments
| Tool | Description |
|---|---|
list_review_comments |
List review comments on a pull request |
create_review_comment |
Create a review comment (line, multiline, or file) |
reply_to_review_comment |
Reply to an existing review comment |
Commit Statuses
| Tool | Description |
|---|---|
list_commit_statuses |
List commit statuses for a ref |
create_commit_status |
Create a commit status (pending, success, failure, error) |
list_check_runs |
List check runs for a ref |
get_check_run |
Get details of a specific check run |
Labels
| Tool | Description |
|---|---|
list_labels |
List repository labels |
create_label |
Create a label with color and description |
delete_label |
Delete a label |
Gists
| Tool | Description |
|---|---|
list_gists |
List gists for a user or authenticated user |
get_gist |
Get gist details with file contents |
create_gist |
Create a new gist with multiple files |
update_gist |
Update gist description, files, or delete files |
Stars
| Tool | Description |
|---|---|
list_starred_repos |
List starred repositories |
star_repository |
Star a repository |
unstar_repository |
Unstar a repository |
Users
| Tool | Description |
|---|---|
get_authenticated_user |
Get current authenticated user's profile |
get_user |
Get any GitHub user's public profile |
Notifications
| Tool | Description |
|---|---|
list_notifications |
List notifications with filters |
mark_notifications_read |
Mark all notifications as read |
mark_thread_read |
Mark a specific notification thread as read |
Collaborators
| Tool | Description |
|---|---|
list_collaborators |
List repository collaborators |
add_collaborator |
Add a collaborator with permission level |
remove_collaborator |
Remove a collaborator |
Discussions
| Tool | Description |
|---|---|
list_discussions |
List discussions in a repository |
get_discussion |
Get details of a specific discussion |
get_discussion_comments |
Get comments on a discussion with replies |
list_discussion_categories |
List discussion categories for a repository |
Projects (Classic)
| Tool | Description |
|---|---|
list_repo_projects |
List repository projects (classic) |
list_org_projects |
List organization projects (classic) |
Projects V2
| Tool | Description |
|---|---|
list_projects_v2 |
List Projects V2 for an organization or user |
get_project_v2 |
Get details of a specific Project V2 |
list_project_v2_items |
List items (issues, PRs, drafts) in a Project V2 |
Project Structure
src/github_mcp/
├── __init__.py # FastMCP server instance
├── __main__.py # Entry point with auto-discovery
├── client.py # Async GitHub API HTTP client (httpx)
├── exceptions.py # Custom exception hierarchy
├── validators.py # Input validation (enum, clamping)
└── tools/
├── __init__.py
├── actions.py # GitHub Actions workflows
├── branch_protection.py # Branch protection rules
├── branches.py # Branch management
├── collaborators.py # Collaborator management
├── commit_statuses.py # Commit statuses and check runs
├── discussions.py # Discussions (GraphQL)
├── files.py # File create/update/delete
├── gists.py # Gist operations
├── git.py # Git Data API (tree, push files)
├── issues.py # Issue operations
├── labels.py # Label management
├── notifications.py # Notification management
├── organizations.py # Organization operations
├── projects.py # Classic project boards
├── projects_v2.py # Projects V2 (GraphQL)
├── pull_requests.py # Pull request operations
├── releases.py # Release management
├── repositories.py # Repository operations
├── review_comments.py # PR review comments
├── reviews.py # PR review operations
├── search.py # GitHub search
├── stars.py # Star/unstar repositories
├── tags.py # Tag operations
├── users.py # User profile operations
└── webhooks.py # Webhook management
tests/
├── conftest.py # Shared fixtures (mock GitHub client)
├── test_client.py # HTTP client, retry, cache, error tests
├── test_exceptions.py # Exception hierarchy tests
├── test_server.py # Tool registration tests
├── test_validators.py # Validator tests
└── tools/
├── conftest.py
└── test_<domain>.py # Tests matching each tool module
License
MIT - see LICENSE for details.
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.