git-mcp
Enables AI agents to perform full Git operations including branching, committing, pushing, stashing, rebasing, and more, with safety features and support for advanced workflows like Git Flow and LFS.
README
git-mcp
A Git MCP server that doesn't suck
Exposes the full Git workflow to any MCP-compatible AI agent — inspect, write, branch, remote, stash, rebase, LFS, git-flow, documentation lookup, and more. Designed to be safe by default, composable, and fast. Powered by simple-git.
Built for coding agents in tools like GitHub Copilot, Claude Code, Cursor, and OpenAI Codex, while remaining compatible with any MCP client that can call tools and resources.
Features
- 11 grouped tools with 60+ actions covering everyday Git workflows and advanced recovery operations
- Safety-first — destructive operations require explicit confirmation; force push and hook bypass are opt-in via server config
- GPG/SSH signing for commits and tags, with server-level auto-sign support
- Git LFS — track patterns, manage objects, install hooks, migrate history
- Git Flow — git-flow-next-style workflow support with preset init, overview, config CRUD, generalized topic actions, finish recovery, optional hook/filter parity, and classic feature/release/hotfix/support aliases, without requiring the external CLI
- Documentation lookup — search git-scm.com and fetch man pages directly from the LLM
- MCP Resources — URI-addressable read-only views of status, log, branches, and diff
- Bundled agent skill —
skills/git-mcp-workflow/documents MCP-first Git workflows, recovery, worktrees, releases, and advanced operations for AI agents and coding agents; installable viaskills-npmand skill.sh - Multi-repo — pass
repo_pathper-call or configure a server-level default - Cross-platform — macOS, Linux, Windows (Git for Windows)
Quick Start
npx (no install)
npx @selfagency/git-mcp --repo-path /path/to/your/repo
Install globally
npm install -g @selfagency/git-mcp
git-mcp --repo-path /path/to/your/repo
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"git": {
"command": "npx",
"args": ["-y", "@selfagency/git-mcp", "--repo-path", "/path/to/your/repo"]
}
}
}
VS Code (Copilot)
Add to .vscode/mcp.json in your project:
{
"servers": {
"git": {
"command": "npx",
"args": ["-y", "@selfagency/git-mcp", "--repo-path", "${workspaceFolder}"]
}
}
}
Configuration
All configuration is via environment variables. Pass them in your MCP client config:
| Variable | Default | Description |
|---|---|---|
GIT_REPO_PATH |
— | Default repository path (also: --repo-path CLI arg) |
GIT_ALLOW_NO_VERIFY |
false |
Allow --no-verify on commit/push (bypasses hooks) |
GIT_ALLOW_FORCE_PUSH |
false |
Allow --force on push |
GIT_ALLOW_FLOW_HOOKS |
false |
Allow git_flow hooks and filters to execute |
GIT_AUTO_SIGN_COMMITS |
false |
Automatically sign every commit |
GIT_AUTO_SIGN_TAGS |
false |
Automatically sign every tag |
GIT_SIGNING_KEY |
— | Default GPG key ID or SSH key path |
GIT_SIGNING_FORMAT |
— | Signing format: openpgp, ssh, or x509 |
Tool Reference
Tools are grouped by domain. Each root tool takes an action parameter that selects the operation. Where an action is marked as default, omitting action will use it.
Context (git_context)
| Action | Description |
|---|---|
summary |
(default) Full repo snapshot: branch, upstream, pending changes, in-progress operations |
search |
Search commit history and working tree content |
get_config |
Read a Git config value |
set_config |
Write a Git config value |
aliases |
List all configured git aliases |
Status (git_status)
| Action | Description |
|---|---|
status |
(default) Working tree and branch status |
diff |
Unstaged, staged, or ref-to-ref diff |
diff_main |
Changes from branch divergence point vs main (or configurable base branch) |
History (git_history)
| Action | Description |
|---|---|
log |
(default) Commit log with filtering, pagination, revision ranges, and pathspecs |
show |
Inspect a single commit |
blame |
Line-by-line attribution for a file |
reflog |
Full reflog — the recovery ledger |
lg |
Compact graph log (--oneline --graph --decorate --all) |
who |
Contributor shortlog (supports optional file_path) |
Commits (git_commits)
| Action | Description |
|---|---|
add |
Stage files or hunks |
restore |
Discard working tree changes |
unstage |
Remove files from the staging area |
commit |
Create a commit with message, signing, and author flags |
amend |
Amend the last commit without editing the message |
wip |
Stage all changes and commit with message WIP |
revert |
Create a revert commit for a given ref |
undo |
Soft-reset the last commit (reset --soft HEAD~1) |
reset |
Reset HEAD with configurable mode (soft/mixed/hard) |
nuke |
Hard-reset the last commit — requires confirm=true |
Branches (git_branches)
| Action | Description |
|---|---|
list |
(default) Local and remote branch listing |
create |
Create a branch |
delete |
Delete a branch |
rename |
Rename a branch |
checkout |
Switch to a branch or ref |
set_upstream |
Set or update tracking upstream |
recent |
Recent branches sorted by committer date |
Remotes (git_remotes)
| Action | Description |
|---|---|
list |
(default) List configured remotes |
manage |
Add, remove, or rename a remote |
fetch |
Fetch from a remote |
pull |
Pull (fetch + merge/rebase) |
push |
Push to a remote; force_with_lease supported |
Workspace (git_workspace)
| Action | Description |
|---|---|
stash |
Stash and pop/apply/drop/list/show stash entries |
stash_all |
Stash tracked and untracked changes in one operation |
rebase |
Start, continue, abort, or skip a rebase |
cherry_pick |
Apply one or more commits; supports continue/abort/skip |
merge |
Merge branches with full flag control |
bisect |
Binary search for a regression (start, good, bad, reset, log) |
tag |
Create, list, delete, or push tags; supports GPG/SSH signing |
worktree |
Add, list, remove, or prune linked worktrees |
submodule |
Add, update, sync, init, deinit, and list submodules |
Git Flow (git_flow)
Preset git-flow-next workflow without requiring the external CLI.
| Operation | Description |
|---|---|
init |
Initialize a repository with git-flow branch conventions |
overview |
Show the current flow state and active branches |
config |
Read or write git-flow configuration values |
topic |
Generalized topic branch action (start, finish, publish, track) |
control |
Flow control: resume interrupted finish, abort, or recover |
LFS (git_lfs)
| Action | Description |
|---|---|
track |
Add a tracking pattern to .gitattributes |
untrack |
Remove a tracking pattern |
ls-files |
List tracked LFS files |
status |
Show LFS status |
pull |
Pull LFS objects |
push |
Push LFS objects |
install |
Install LFS hooks in the repository |
migrate-import |
Migrate existing history to LFS |
migrate-export |
Migrate LFS history back to plain objects |
Documentation (git_docs)
| Action | Description |
|---|---|
search |
Search git-scm.com for documentation |
man |
Fetch and return a Git man page |
Health Check (git_ping)
Returns server status. Useful for confirming the server is reachable.
MCP Resources
URI-addressable read-only snapshots (subscribe-capable):
| Resource URI | Content |
|---|---|
git+repo://status/{repo_path} |
Working tree status (JSON) |
git+repo://log/{repo_path} |
Recent commit log (JSON) |
git+repo://branches/{repo_path} |
Branch list (JSON) |
git+repo://diff/{repo_path} |
Unstaged + staged diff (JSON) |
Bundled Agent Skill
git-mcp ships a bundled agent skill at skills/git-mcp-workflow/ that teaches any skills-npm-compatible agent to use the MCP tool surface instead of running raw git CLI commands. The skill covers:
- Why LLMs must not use the Git CLI (quoting hazards, silent failures)
- Inspect-before-mutate workflow rules
- Safety order for undo and recovery operations
- Full registered tool surface with action reference
- Workflow playbooks: feature branch, rebase, recovery, worktree, backport, release tagging, Git Flow, merge
- Git concept explanations anchored to MCP tools
Installing the skill
If your agent supports skills-npm:
npm install @selfagency/git-mcp # or pnpm/yarn
npx skills-npm
Or add to your project's package.json so it runs automatically:
{
"scripts": {
"prepare": "skills-npm"
}
}
Then add to .gitignore:
skills/npm-*
Safety
- All mutating tools have
destructiveHint: truein their MCP annotations git_commits action=reset mode=hardrequiresconfirm=truegit_commits action=nukerequiresconfirm=true- Force push (
--force) is disabled unlessGIT_ALLOW_FORCE_PUSH=true;force_with_leaseis always available - Hook bypass (
--no-verify) is disabled unlessGIT_ALLOW_NO_VERIFY=true git_flowhook and filter execution is disabled unlessGIT_ALLOW_FLOW_HOOKS=true- Paths are validated against the repository root — traversal attempts are rejected
- Credentials and tokens are never included in responses
Development
# Clone and install
git clone https://github.com/selfagency/git-mcp.git
cd git-mcp
pnpm install
# Run in development mode (hot reload)
pnpm dev
# Build
pnpm build
# Run tests
pnpm test
# Type check
pnpm typecheck
# Lint
pnpm lint
# Docs (dev server)
pnpm docs:dev
# Docs (build)
pnpm docs:build
License
MIT © Daniel Sieradski
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。