github-pr-review-mcp

github-pr-review-mcp

Provides GitHub PR review capabilities to LLMs, enabling automated PR analysis, review submission, and inline commenting via MCP.

Category
Visit Server

README

GitHub PR Review MCP

A Model Context Protocol (MCP) server that provides GitHub PR review capabilities to LLMs in VSCode/Cursor and other compatible AI clients.

Features

๐Ÿ” MVP Feature 1: Review PRs in GitHub

  • Get PR Reviews - Fetch all existing reviews for analysis
  • Get PR Comments - Retrieve all comments and discussions
  • Analyze PR Code - AI-powered code analysis with security checks and suggestions
  • Get PR Files - List all changed files with additions/deletions
  • Get PR Details - Comprehensive PR information including status, author, metrics

โœ๏ธ MVP Feature 2: Implement Feedback & Reply to Reviews

  • Submit PR Review - Submit complete reviews with approval/changes/comments
  • Add Comments - Add general or line-specific comments to PRs
  • Reply to Reviews - Respond to existing review comments
  • Update PRs - Modify PR title, description, or state

๐ŸŽฏ MVP Feature 3: Diff-Aware Inline Comments & Pending Reviews

  • Get Diff Hunks - Retrieve diff hunks with precise line mapping for inline comments
  • Validate Comment Targets - Verify if a line/path is valid in the PR diff before commenting
  • Pending Review Management - Create, retrieve, and manage draft reviews
  • List Draft Comments - View all pending comments before submitting a review
  • No HTML Scraping - All operations use GitHub REST APIs for reliability

Quick Start

Prerequisites

  • Node.js 20.19.0 or higher
  • GitHub Personal Access Token with repo and read:user scopes

Installation

Option 1: Global Installation (Recommended)

npm install -g github-pr-review-mcp

Option 2: Development Setup

git clone https://github.com/jamesjfoong/github-pr-review-mcp.git
cd github-pr-review-mcp
npm install
npm run build

Setup

  1. Get GitHub Token: Generate a Personal Access Token with scopes:

    • repo (full repository access)
    • read:user (read user profile data)
  2. Configure Environment:

    cp .env.example .env
    # Edit .env and add your token:
    GITHUB_TOKEN=your_github_token_here
    
  3. Configure in Cursor/VSCode: Add to your MCP settings (usually in ~/Library/Application Support/Cursor/User/globalStorage/rooveterinaryinc.cursor-small/settings/cline_mcp_settings.json):

    {
      "mcpServers": {
        "github-pr-review": {
          "command": "npx",
          "args": ["github-pr-review-mcp"]
        }
      }
    }
    

Available Tools

Tool Description Parameters
get_pr_reviews Get all reviews for a PR owner, repo, prNumber
get_pr_comments Get all comments on a PR owner, repo, prNumber
analyze_pr_code AI code analysis with security/quality checks owner, repo, prNumber
get_pr_files List changed files with stats owner, repo, prNumber
get_pr_details Get comprehensive PR information owner, repo, prNumber
submit_pr_review Submit a review (approve/request changes/comment) owner, repo, prNumber, body, event, comments?
add_pr_comment Add general or line-specific comments owner, repo, prNumber, body, path?, line?, in_reply_to?
update_pr Update PR title, description, or state owner, repo, prNumber, title?, body?, state?
get_pr_diff_hunks Get diff hunks with line mapping for inline comment placement owner, repo, prNumber
validate_pr_comment_target Validate if a comment target exists in the PR diff owner, repo, prNumber, path, line, side?
ensure_pending_review Create or reuse a pending review for draft comments owner, repo, prNumber, body?
get_pending_review Get the current pending review (if any) owner, repo, prNumber
list_pending_review_comments List all draft comments in the pending review owner, repo, prNumber

Usage Examples

Example 1: Review a PR

๐Ÿค–: Please review PR #123 in microsoft/vscode

1. Get PR details: get_pr_details(owner: "microsoft", repo: "vscode", prNumber: 123)
2. Get changed files: get_pr_files(owner: "microsoft", repo: "vscode", prNumber: 123)
3. Analyze code: analyze_pr_code(owner: "microsoft", repo: "vscode", prNumber: 123)
4. Submit review: submit_pr_review(owner: "microsoft", repo: "vscode", prNumber: 123, body: "LGTM! Great work on...", event: "APPROVE")

Example 2: Implement Feedback

๐Ÿค–: The reviewer asked me to fix the error handling in line 45 of src/utils.ts

1. Add line comment: add_pr_comment(owner: "owner", repo: "repo", prNumber: 123, body: "Fixed error handling as requested", path: "src/utils.ts", line: 45)
2. Update PR description: update_pr(owner: "owner", repo: "repo", prNumber: 123, body: "Updated PR description with changes made...")

Example 3: Draft Review with Inline Comments (New!)

๐Ÿค–: Create a draft review with inline comments on PR #123

1. Ensure pending review exists: ensure_pending_review(owner: "owner", repo: "repo", prNumber: 123, body: "Draft review comments")
2. Get diff hunks to find valid lines: get_pr_diff_hunks(owner: "owner", repo: "repo", prNumber: 123)
3. Validate comment target: validate_pr_comment_target(owner: "owner", repo: "repo", prNumber: 123, path: "src/main.ts", line: 45, side: "RIGHT")
4. Add inline comment if valid: add_pr_comment(owner: "owner", repo: "repo", prNumber: 123, body: "Consider refactoring this method", path: "src/main.ts", line: 45)
5. List pending comments to verify: list_pending_review_comments(owner: "owner", repo: "repo", prNumber: 123)
6. Submit the review when ready: submit_pr_review(owner: "owner", repo: "repo", prNumber: 123, body: "Overall looks good!", event: "COMMENT")

Example 4: AI-Powered PR Review with Custom Prompt

๐Ÿค–: Review PR #123 using AI with custom guidelines

1. Get review prompt: review_pr_with_prompt(owner: "owner", repo: "repo", prNumber: 123, customPrompt: "Focus on security vulnerabilities and performance issues")
2. Use the returned reviewPrompt with your LLM to generate a review
3. Format the LLM response into review comments
4. Submit review: submit_pr_review(owner: "owner", repo: "repo", prNumber: 123, body: "AI-generated review...", event: "COMMENT")

Example 5: Automated Code Analysis

The analyze_pr_code tool automatically detects:

  • ๐Ÿ”’ Security issues: API key exposure, hardcoded passwords, XSS vulnerabilities
  • ๐Ÿงน Code smells: Console statements, debugger statements, TypeScript any types
  • ๐Ÿ“Š Quality metrics: Large file changes, missing tests, complexity analysis
  • โœ… Suggestions: Breaking large PRs, adding tests, security improvements

Development

AI Code Editors: If you're using Cursor, GitHub Copilot, or other AI code editors, this repository includes automatic configuration files:

  • .cursor/rules/ - Project rules (always applied)
  • .cursor/agents/ - Custom subagents for specialized tasks
  • .cursor/skills/ - Agent skills for procedural workflows
  • .github/copilot-instructions.md - GitHub Copilot instructions
  • AGENTS.md - General AI agent instructions

Project Structure

github-pr-review-mcp/
โ”œโ”€โ”€ src/
โ”‚   โ”œโ”€โ”€ index.ts          # Main MCP server entry point
โ”‚   โ”œโ”€โ”€ github-service.ts # GitHub API integration
โ”‚   โ”œโ”€โ”€ code-analyzer.ts  # Code analysis engine
โ”‚   โ””โ”€โ”€ types.ts          # TypeScript type definitions
โ”œโ”€โ”€ dist/                 # Compiled JavaScript output
โ”œโ”€โ”€ scripts/
โ”‚   โ””โ”€โ”€ setup.sh          # Automated setup script
โ””โ”€โ”€ package.json

Scripts

  • npm run build - Compile TypeScript
  • npm run dev - Development mode with auto-reload
  • npm start - Run compiled server
  • npm run prepublishOnly - Build before publishing

Contributing

  1. Fork the repository
  2. Create a feature branch: git checkout -b feature/amazing-feature
  3. Make your changes
  4. Add tests if applicable
  5. Run npm run build to ensure it compiles
  6. Submit a pull request

API Requirements

Your GitHub token needs these permissions:

  • Repository access: repo scope for private repos, or public_repo for public repos only
  • User data: read:user for accessing user profile information
  • Optional: write:discussion for advanced discussion features

Troubleshooting

Common Issues

1. "GITHUB_TOKEN environment variable is required"

  • Solution: Copy .env.example to .env and add your GitHub token

2. "Cannot find module" errors

  • Solution: Run npm install to install dependencies

3. Rate limiting

  • The server includes automatic rate limiting and retry logic
  • GitHub API has limits: 5,000 requests/hour for authenticated requests

4. Permission errors

  • Ensure your GitHub token has repo scope for the repositories you want to access
  • For organization repos, you may need additional permissions

Debug Mode

Enable debug logging by setting in your .env:

DEBUG=true

Roadmap

Future Features

  • ๐Ÿ”„ Auto-merge capabilities
  • ๐Ÿงช Test execution integration
  • ๐Ÿ“ˆ PR metrics and analytics
  • ๐Ÿค– Automated code fixes based on review comments
  • ๐Ÿ” Advanced search and filtering
  • ๐Ÿ“Š Reporting and dashboards

License

MIT License - see LICENSE file for details.

Support

Author

James Jeremy Foong - @jamesjfoong


โญ Star this repo if you find it useful!

๐Ÿ› Report issues on GitHub Issues

๐Ÿค Contributing is welcome! See our contributing guidelines above.

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