Git MCP

Git MCP

MCP server for local git repositories. Contribute to kjozsa/git-mcp development by creating an account on GitHub.

kjozsa

Version Control
Developer Tools
File Systems
Local
Python
Visit Server

README

Image 1: smithery badge MCP server for managing Git operations on local repositories.

Installation

Installing via Smithery

To install Git MCP for Claude Desktop automatically via Smithery:

npx -y @smithery/cli install @kjozsa/git-mcp --client claude

Installing Manually

Configuration

Add the MCP server using the following JSON configuration snippet:

{ "mcpServers": { "git-mcp": { "command": "uvx", "args": ["git-mcp"], "env": { "GIT_REPOS_PATH": "/path/to/your/git/repositories" } } } }

Features and Usage

Environment Variables

  • GIT_REPOS_PATH: Path to the directory containing your Git repositories (required)

You can set this in your environment or create a .env file in the directory where you run the server.

Available Methods

list_repositories

Lists all Git repositories in the configured path.

  • Parameters: None
  • Returns: List of repository names

get_last_git_tag

Finds the last Git tag in the specified repository.

  • Parameters: repo_name (Name of the Git repository)
  • Returns: Dictionary with version (tag name) and date (tag creation date)

list_commits_since_last_tag

Lists commit messages between the last Git tag and HEAD.

  • Parameters:
    • repo_name: Name of the Git repository
    • max_count (optional): Maximum number of commits to return
  • Returns: List of dictionaries with hash, author, date, and message

create_git_tag

Creates a new git tag in the specified repository.

  • Parameters:
    • repo_name: Name of the git repository
    • tag_name: Name of the tag to create
    • message (optional): Message for annotated tag (if not provided, creates a lightweight tag)
  • Returns: Dictionary with status, version (tag name), date (tag creation date), and type (annotated or lightweight)

push_git_tag

Pushes an existing git tag to the default remote repository.

  • Parameters:
    • repo_name: Name of the git repository
    • tag_name: Name of the tag to push
  • Returns: Dictionary with status, remote (name of the remote), tag (name of the tag), and message (success message)

refresh_repository

Refreshes a repository by checking out the main branch (or master as fallback) and pulling from all remotes.

  • Parameters:
    • repo_name: Name of the git repository
  • Returns: Dictionary with status, repository, branch, and pull_results (results for each remote)

Troubleshooting

  • Repository Not Found: Ensure GIT_REPOS_PATH is set correctly and the repository exists
  • No Tags Found: The repository doesn't have any tags yet

Development

Install dependencies

uv pip install -r requirements.txt

Run in dev mode with Inspector

mcp dev git_mcp/server.py

Testing

The project includes two test scripts:

  1. test_git_mcp.py - Tests the underlying Git command functionality directly, without using the MCP server.
  2. test_mcp_server.py - Tests the MCP server functionality by starting a server instance and making calls to it.

To run the tests:

Test the Git command functionality

python test_git_mcp.py

Test the MCP server (requires the git-mcp package to be installed)

python test_mcp_server.py

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol (MCP) server that provides browser automation capabilities using Playwright. This server enables LLMs to interact with web pages through structured accessibility snapshots, bypassing the need for screenshots or visually-tuned models.

Official
Featured
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Audiense Insights MCP Server is a server based on the Model Context Protocol (MCP) that allows Claude and other MCP-compatible clients to interact with your Audiense Insights account - AudienseCo/mcp-audiense-insights

Official
Featured
Local
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

It's like v0 but in your Cursor/WindSurf/Cline. 21st dev Magic MCP server for working with your frontend like Magic - 21st-dev/magic-mcp

Official
Featured
Local
TypeScript
Gitingest-MCP

Gitingest-MCP

mcp server for gitingest. Contribute to puravparab/Gitingest-MCP development by creating an account on GitHub.

Featured
Local
Python
Playwright MCP Server

Playwright MCP Server

Contribute to showfive/playwright-mcp-server development by creating an account on GitHub.

Featured
Local
TypeScript
Excel MCP Server

Excel MCP Server

An MCP server that reads and writes spreadsheet data to MS Excel file - negokaz/excel-mcp-server

Featured
Local
Go
MCP Package Docs Server

MCP Package Docs Server

An MCP server that provides LLMs with efficient access to package documentation across multiple programming languages - sammcj/mcp-package-docs

Featured
Local
TypeScript
Claude Code MCP

Claude Code MCP

claude-code-mcp. Contribute to auchenberg/claude-code-mcp development by creating an account on GitHub.

Featured
Local
JavaScript
Apple MCP Server

Apple MCP Server

Collection of apple-native tools for the model context protocol. - Dhravya/apple-mcp

Featured
Local
TypeScript
@kazuph/mcp-taskmanager

@kazuph/mcp-taskmanager

Contribute to kazuph/mcp-taskmanager development by creating an account on GitHub.

Featured
Local
JavaScript