GitHub PR Reviewer
Enables reviewing GitHub pull requests via ChatGPT, including listing PRs, viewing diffs, posting comments, approving, and requesting changes.
README
ChatGPT GitHub PR Reviewer
A ChatGPT app that helps you review GitHub Pull Requests directly from within ChatGPT conversations. Built using OpenAI's Apps SDK with the Model Context Protocol (MCP).
Features
- Connect GitHub - OAuth login to connect your GitHub account
- List Pull Requests - View PRs you authored, need to review, or are involved in
- Get PR Context - Full PR details including files changed, diffs, and metadata
- Post Comments - Add general comments or inline comments on specific files/lines
- Approve PRs - Approve pull requests with optional comment
- Request Changes - Request changes with feedback
- Idempotency Protection - Prevents duplicate comments on retries
- OAuth 2.1 Compliant - Full MCP authorization spec with PKCE and discovery endpoints
MCP Tools
1. check_github_auth_status
Connect and check GitHub authentication status.
Input: None
Output (not authenticated):
{
"authenticated": false,
"authUrl": "https://github.com/login/oauth/authorize?..."
}
Output (authenticated):
{
"authenticated": true,
"user": { "login": "username", "name": "Full Name" }
}
2. list_pull_requests
List pull requests with priority cascade.
Input:
{
"username": "octocat" // Optional: filter by author
}
Default behavior (no username):
- First shows PRs where YOU are the author
- If none, shows PRs where you are a reviewer
- If none, shows PRs where you are involved
Output:
{
"pullRequests": [...],
"searchType": "authored" | "reviewing" | "involved" | "user_authored",
"totalCount": 5
}
3. get_pr_context
Get full context for a PR including files changed and diffs.
Input:
{
"pr_name": "owner/repo#123"
}
Output:
{
"pr": { "number": 123, "title": "...", "author": "..." },
"description": "PR description...",
"files": [
{ "filename": "src/index.ts", "status": "modified", "additions": 10, "deletions": 5, "patch": "..." }
],
"commits": 3,
"additions": 50,
"deletions": 20
}
4. post_review_comments
Post review comments to a PR. Supports general and inline comments.
Input:
{
"pr_name": "owner/repo#123",
"comments": [
{ "body": "Looks good!" },
{ "body": "Use async here", "path": "src/index.ts", "line": 42 }
],
"event": "COMMENT" | "APPROVE" | "REQUEST_CHANGES",
"idempotency_key": "unique-key-123"
}
Comment Types:
- General comment: Only
body- appears in PR conversation - Inline comment:
body+path+line- appears on specific line
Output:
{
"success": true,
"reviewId": 12345,
"prUrl": "https://github.com/owner/repo/pull/123",
"commentsPosted": 2
}
Example Prompts
1. Connect GitHub
| Prompt | Output |
|---|---|
| "Connect my GitHub" | Shows GitHub OAuth login button |
| "Login to GitHub" | Shows GitHub OAuth login button |
2. List Pull Requests
| Prompt | Output |
|---|---|
| "List my PRs" | Lists your PRs in priority: authored → reviewing → involved |
| "Show my PRs for review" | Lists PRs where you are a reviewer |
| "List m-musaz PRs" | Lists all open PRs by m-musaz |
3. Get PR Context
| Prompt | Output |
|---|---|
| "Review owner/repo#123" | Returns full PR details: title, description, files, diffs |
| "Get context for PR 123" | Returns full PR details with code changes |
4. Post Review Comments
| Prompt | Output |
|---|---|
| "Add comment: 'Looks good!'" | Posts general comment on PR |
| "Comment on line 42 of src/index.ts: 'Use async here'" | Posts inline comment |
| "Approve this PR" | Approves the PR |
| "Request changes: 'Please add tests'" | Requests changes with feedback |
Project Structure
chatgpt-github-pr-reviewer/
├── package.json # Root package with npm workspaces
├── server/
│ └── src/
│ ├── index.ts # Express server with OAuth endpoints
│ ├── mcp-server.ts # MCP protocol handler
│ ├── mcp-oauth.ts # OAuth 2.1 implementation
│ ├── github-auth.ts # GitHub OAuth logic
│ ├── github-api.ts # GitHub API integration
│ ├── idempotency-service.ts # Duplicate prevention
│ ├── token-store.ts # GitHub token storage
│ └── types.ts # TypeScript types
└── widget/
└── src/
├── GitHubWidget.tsx # Main widget component
└── components/ # UI components
Environment Variables
# GitHub OAuth (from GitHub Developer Settings)
GITHUB_CLIENT_ID=your_github_client_id
GITHUB_CLIENT_SECRET=your_github_client_secret
GITHUB_REDIRECT_URI=http://localhost:3000/github/callback
# Server
PORT=3000
NODE_ENV=development
# MCP OAuth (for ChatGPT authentication)
MCP_OAUTH_CLIENT_ID=chatgpt-mcp-client
MCP_OAUTH_CLIENT_SECRET=chatgpt-mcp-secret-key-2024
# Widget Base URL
WIDGET_BASE_URL=https://your-app.railway.app
GitHub OAuth App Setup
Step 1: Create GitHub OAuth App
- Go to GitHub Developer Settings
- Click "OAuth Apps" → "New OAuth App"
- Fill in:
- Application name: ChatGPT PR Reviewer
- Homepage URL:
https://your-app.railway.app - Authorization callback URL:
https://your-app.railway.app/github/callback
- Copy Client ID and Client Secret to
.env
Step 2: Required Scopes
| Scope | Purpose |
|---|---|
read:user |
Read user profile |
read:org |
Read organization/team membership |
repo |
Full repository access (required for posting reviews) |
Local Development
# Install dependencies
npm install
# Create .env file
cp .env.example .env
# Edit .env with your GitHub OAuth credentials
# Start development server
npm run dev
Deployment
Railway
- Connect your GitHub repo to Railway
- Add environment variables:
GITHUB_CLIENT_ID=your_client_id GITHUB_CLIENT_SECRET=your_client_secret GITHUB_REDIRECT_URI=https://your-app.railway.app/github/callback PORT=3000 NODE_ENV=production WIDGET_BASE_URL=https://your-app.railway.app
ChatGPT Integration
- Create a new ChatGPT App
- Configure MCP:
- Discovery URL:
https://your-app.railway.app/.well-known/oauth-authorization-server
- Discovery URL:
- Test with: "Connect my GitHub" or "List my PRs"
Credits
Built with:
Happy PR Reviewing!
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.