Git MCP
MCP server for local git repositories. Contribute to kjozsa/git-mcp development by creating an account on GitHub.
kjozsa
README
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) anddate
(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 repositorymax_count
(optional): Maximum number of commits to return
- Returns: List of dictionaries with
hash
,author
,date
, andmessage
create_git_tag
Creates a new git tag in the specified repository.
- Parameters:
repo_name
: Name of the git repositorytag_name
: Name of the tag to createmessage
(optional): Message for annotated tag (if not provided, creates a lightweight tag)
- Returns: Dictionary with
status
,version
(tag name),date
(tag creation date), andtype
(annotated or lightweight)
push_git_tag
Pushes an existing git tag to the default remote repository.
- Parameters:
repo_name
: Name of the git repositorytag_name
: Name of the tag to push
- Returns: Dictionary with
status
,remote
(name of the remote),tag
(name of the tag), andmessage
(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
, andpull_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:
test_git_mcp.py
- Tests the underlying Git command functionality directly, without using the MCP server.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
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.
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
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
Gitingest-MCP
mcp server for gitingest. Contribute to puravparab/Gitingest-MCP development by creating an account on GitHub.
Playwright MCP Server
Contribute to showfive/playwright-mcp-server development by creating an account on GitHub.
Excel MCP Server
An MCP server that reads and writes spreadsheet data to MS Excel file - negokaz/excel-mcp-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
Claude Code MCP
claude-code-mcp. Contribute to auchenberg/claude-code-mcp development by creating an account on GitHub.
Apple MCP Server
Collection of apple-native tools for the model context protocol. - Dhravya/apple-mcp
@kazuph/mcp-taskmanager
Contribute to kazuph/mcp-taskmanager development by creating an account on GitHub.