Skip to main content

MCP Server for GitHub/GitLab code review - enables AI assistants to review pull requests and merge requests

Project description

Code Review MCP Server

English | ไธญๆ–‡

PyPI version License: MIT Python 3.10+

MCP (Model Context Protocol) server for code review. Enables AI assistants to review GitHub/GitLab Pull Requests and Merge Requests.

โœจ Features

  • ๐Ÿ” Multi-platform: Supports both GitHub and GitLab (including self-hosted)
  • ๐Ÿš€ Multiple Transports: Supports stdio, SSE, and WebSocket protocols
  • ๐Ÿ“ฆ Easy Install: Quick install via uvx or pip
  • ๐Ÿณ Containerized: Docker image available
  • โ˜๏ธ Cloud Deploy: One-click Smithery deployment
  • ๐Ÿ”’ Security First: Environment variable configuration, no data persistence

๐Ÿš€ Quick Start

Option 1: Using uvx (Recommended)

# Run directly, no installation needed
uvx code-review-mcp

Option 2: Using pip

pip install code-review-mcp

# Run the server
code-review-mcp

# (Optional) Install Cursor rules to your project
code-review-mcp init-rules

Option 3: From Source

git clone https://github.com/OldJii/code-review-mcp.git
cd code-review-mcp
pip install -e .
code-review-mcp

๐Ÿ”ง Configuration

Environment Variables

Variable Description Required
GITHUB_TOKEN GitHub personal access token When using GitHub
GITLAB_TOKEN GitLab personal access token When using GitLab
GITLAB_HOST GitLab host URL For self-hosted (default: gitlab.com)

Getting Tokens

GitHub

# Option 1: Using gh CLI (Recommended)
brew install gh
gh auth login

# Option 2: Manual Token Creation
# Visit https://github.com/settings/tokens
# Create Personal Access Token with 'repo' scope
export GITHUB_TOKEN="your-token-here"

GitLab

# Option 1: Using glab CLI (Recommended)
brew install glab
glab auth login

# For self-hosted GitLab
glab auth login --hostname gitlab.yourcompany.com

# Option 2: Manual Token Creation
# Visit GitLab -> Settings -> Access Tokens
# Create token with 'api' scope
export GITLAB_TOKEN="your-token-here"
export GITLAB_HOST="gitlab.yourcompany.com"  # For self-hosted

๐Ÿ“ฑ Client Configuration

Cursor

Edit ~/.cursor/mcp.json:

{
  "mcpServers": {
    "code-review": {
      "command": "uvx",
      "args": ["code-review-mcp"],
      "env": {
        "GITHUB_TOKEN": "your-github-token",
        "GITLAB_TOKEN": "your-gitlab-token"
      }
    }
  }
}

Claude Desktop

Edit ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):

{
  "mcpServers": {
    "code-review": {
      "command": "uvx",
      "args": ["code-review-mcp"],
      "env": {
        "GITHUB_TOKEN": "your-github-token",
        "GITLAB_TOKEN": "your-gitlab-token"
      }
    }
  }
}

SSE Mode (Remote Deployment)

# Start SSE server
code-review-mcp --transport sse --port 8000

Client configuration:

{
  "mcpServers": {
    "code-review": {
      "url": "http://your-server:8000/sse"
    }
  }
}

WebSocket Mode (Remote Deployment)

# Start WebSocket server
code-review-mcp --transport websocket --port 8000

Client configuration:

{
  "mcpServers": {
    "code-review": {
      "url": "ws://your-server:8000/ws"
    }
  }
}

๐Ÿณ Docker Deployment

Build Image

docker build -t code-review-mcp .

Run Container

stdio mode

docker run -i --rm \
  -e GITHUB_TOKEN="your-token" \
  code-review-mcp

SSE mode

docker run -d --rm \
  -e GITHUB_TOKEN="your-token" \
  -p 8000:8000 \
  code-review-mcp --transport sse

๐Ÿ”จ MCP Tools

Rules

Tool Description
get_review_rules Get review rules (builtin + custom project rules)

Information Retrieval

Tool Description
get_pr_info Get PR/MR details (title, description, branches)
get_pr_changes Get code changes (diff), supports file type filtering
extract_related_prs Extract related PR/MR links from description

Adding Comments

Tool Description
add_inline_comment Add inline comment to specific code line
add_pr_comment Add general comment
batch_add_comments Batch add comments (inline + general)

๐Ÿ’ฌ Usage Examples

Chat with Cursor or Claude:

Review GitHub PR

Review https://github.com/facebook/react/pull/12345

Review GitLab MR

Review https://gitlab.com/group/project/-/merge_requests/678

Review Self-hosted GitLab MR

Review https://gitlab.yourcompany.com/team/project/-/merge_requests/90

Review Only Specific File Types

Review this PR, only check .py and .js files:
https://github.com/owner/repo/pull/123

๐Ÿงช Debugging & Testing

Using MCP Inspector

# Run with MCP Inspector
npx @modelcontextprotocol/inspector uvx code-review-mcp

This launches a web interface where you can:

  • View all available tools
  • Manually call tools and inspect results
  • Debug parameters and responses

Local Development

# Clone repository
git clone https://github.com/OldJii/code-review-mcp.git
cd code-review-mcp

# Install dev dependencies
pip install -e ".[dev]"

# Run tests
pytest

# Debug with Inspector
npx @modelcontextprotocol/inspector python -m code_review_mcp.server

๐Ÿ“ Project Structure

code-review-mcp/
โ”œโ”€โ”€ src/
โ”‚   โ””โ”€โ”€ code_review_mcp/
โ”‚       โ”œโ”€โ”€ __init__.py      # Package entry
โ”‚       โ”œโ”€โ”€ cli.py           # CLI commands (init-rules, etc.)
โ”‚       โ”œโ”€โ”€ server.py        # MCP server main logic
โ”‚       โ”œโ”€โ”€ providers.py     # GitHub/GitLab providers
โ”‚       โ””โ”€โ”€ rules/           # Bundled Cursor rules
โ”‚           โ”œโ”€โ”€ code-review.mdc
โ”‚           โ””โ”€โ”€ code-review-en.mdc
โ”œโ”€โ”€ pyproject.toml           # Project config & PyPI publishing
โ”œโ”€โ”€ Dockerfile               # Docker build file
โ”œโ”€โ”€ smithery.yaml            # Smithery deployment config
โ”œโ”€โ”€ CHANGELOG.md             # Changelog
โ”œโ”€โ”€ CONTRIBUTING.md          # Contributing guide
โ””โ”€โ”€ README.md                # Documentation

๐ŸŽฏ Cursor Rules (Recommended)

This package includes built-in code review rules for Cursor IDE. Install them to your project with one command:

# Install rules to current project
code-review-mcp init-rules

# Install to a specific directory
code-review-mcp init-rules --target /path/to/project

# Overwrite existing rules
code-review-mcp init-rules --force

# List available rules
code-review-mcp list-rules

After installation, the rules will be available in your project's .cursor/rules/ directory:

  • code-review.mdc - Chinese version
  • code-review-en.mdc - English version

Custom Project Rules

You can define project-specific review rules that the MCP server loads at runtime. This allows each project to enforce its own coding standards during reviews.

Quick Setup:

# Generate a custom rules template
code-review-mcp init-rules --custom

This creates .code-review-rules/project-rules.md in your project. Edit it with your project-specific conventions, then configure the MCP server to load it:

{
  "mcpServers": {
    "code-review": {
      "command": "uvx",
      "args": ["code-review-mcp"],
      "env": {
        "GITHUB_TOKEN": "your-token",
        "CODE_REVIEW_RULES_DIR": "/absolute/path/to/project/.code-review-rules"
      }
    }
  }
}

How It Works:

  • Set CODE_REVIEW_RULES_DIR to a directory containing .md or .mdc files
  • The get_review_rules tool returns both builtin and custom rules
  • AI assistants use these rules when performing reviews
  • Custom rules supplement (not replace) the builtin review guidelines

Environment Variable:

Variable Description Required
CODE_REVIEW_RULES_DIR Path to custom rules directory No (optional)

๐Ÿค Contributing

Contributions welcome! See CONTRIBUTING.md for details.

๐Ÿ“„ License

MIT

๐Ÿ”— Related Links

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

code_review_mcp-1.2.0.tar.gz (21.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

code_review_mcp-1.2.0-py3-none-any.whl (22.5 kB view details)

Uploaded Python 3

File details

Details for the file code_review_mcp-1.2.0.tar.gz.

File metadata

  • Download URL: code_review_mcp-1.2.0.tar.gz
  • Upload date:
  • Size: 21.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for code_review_mcp-1.2.0.tar.gz
Algorithm Hash digest
SHA256 fda4aa2edb472da1018dc48585ceb761145baae5573c3e5912616b346168c58d
MD5 9120dfc5e7709b71f74cd9ae87511d1a
BLAKE2b-256 a90a46eb3ceeacae4bd62d3da29afbfb350ddfc7ed6d9c2a2bf4ea230fe95ccc

See more details on using hashes here.

Provenance

The following attestation bundles were made for code_review_mcp-1.2.0.tar.gz:

Publisher: publish.yml on OldJii/code-review-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file code_review_mcp-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: code_review_mcp-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 22.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for code_review_mcp-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7e5b95e78b6afaceec083037352e575ffe9bd9f4c50fdea4588ee242be012328
MD5 3285f1292c4ef43f81b3eaf80493e640
BLAKE2b-256 c6d9d4ca986af0f13488a4665b8b469fc79f3a301f6728588026945247b49dee

See more details on using hashes here.

Provenance

The following attestation bundles were made for code_review_mcp-1.2.0-py3-none-any.whl:

Publisher: publish.yml on OldJii/code-review-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page