GitHub MCP Server

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.

Category
Visit Server

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

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

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured