Skip to main content
Glama

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

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.

Install Server
A
security – no known vulnerabilities
A
license - permissive license
A
quality - confirmed to work

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/software-engineer-mj/github-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server