Skip to main content
Glama

Git PR MCP Server

by peterj

Git PR MCP Server

A Model Context Protocol (MCP) server for Git and Pull Request operations, providing tools for repository management and PR workflows.

Built with FastMCP and runs in SSE mode by default on 0.0.0.0:8000.

Features

This MCP server provides the following tools and capabilities:

Core Git Operations (on specified repository path):

  • get_git_status: Get the current git status of a repository.
  • list_branches: List all branches in the repository (with optional remote branches).
  • create_pr_summary: Create a summary for a pull request based on git diff.
  • get_commit_history: Get commit history for a branch.
  • get_git_diff: Get git diff between commits, branches, or working directory.

Automated PR Workflow (operates on an internally managed "active" repository):

  • clone_repository: Clones a GitHub repository into a managed temporary directory, making it the "active" repository for subsequent operations. Automatically cleans up any previously active repository's temporary directory.
  • create_git_branch: Creates a new branch in the active repository.
  • write_file_in_repo: Creates or overwrites files within the active repository.
  • git_commit_changes: Stages all changes (git add .) and commits them in the active repository.
  • git_push_branch: Pushes a specified branch from the active repository to its remote origin.
  • create_github_pr: Creates a pull request on GitHub for the active repository using the PyGithub library. Requires GITHUB_TOKEN.

State Management:

  • The server maintains the state of the currently "active" cloned repository (path, URL, owner, name) in an active_repo_state.json file. This allows some persistence across server restarts, though the temporary clone directory itself might be OS-managed.

Installation

  1. Clone this repository:
git clone <repository-url> cd git-pr-mcp
  1. Install using uv:
uv sync

Usage

The server runs in SSE mode by default on 0.0.0.0:9999 and is configured via environment variables. Here's a sample .env file:

FASTMCP_HOST=0.0.0.0 FASTMCP_PORT=9999 GITHUB_TOKEN=your_github_token

Quick Start

# Run with defaults (0.0.0.0:8000) uv run python main.py # Or run the server module directly uv run python -m src.git_pr_mcp.server

You can then access the MCP server at http://localhost:9999/sse.

-
security - not tested
F
license - not found
-
quality - not tested

An MCP server that enables Git repository operations and GitHub PR workflows, allowing users to manage repositories, create branches, commit changes, and create pull requests through natural language.

  1. Features
    1. Installation
      1. Usage
        1. Quick Start

      Related MCP Servers

      • A
        security
        F
        license
        A
        quality
        MCP Server for the GitHub API, providing features for file operations, repository management, and advanced search, with automatic branch creation and comprehensive error handling.
        Last updated -
        18
        4
        3
        TypeScript
        • Linux
        • Apple
      • A
        security
        F
        license
        A
        quality
        MCP server for managing Git operations on local repositories, allowing users to list repositories, get and create tags, list commits, push tags, and refresh repositories through a standardized interface.
        Last updated -
        6
        Python
      • -
        security
        A
        license
        -
        quality
        An MCP server that wraps around the GitHub CLI tool, allowing AI assistants to interact with GitHub repositories through commands for pull requests, issues, and repository operations.
        Last updated -
        123
        TypeScript
        MIT License
        • Linux
        • Apple

      View all related MCP servers

      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/peterj/git-pr-mcp'

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