Skip to main content
Glama

git-mcp

CI codecov NPM Version

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 skillskills/git-mcp-workflow/ documents MCP-first Git workflows, recovery, worktrees, releases, and advanced operations for AI agents and coding agents; installable via skills-npm and skill.sh

  • Multi-repo — pass repo_path per-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: true in their MCP annotations

  • git_commits action=reset mode=hard requires confirm=true

  • git_commits action=nuke requires confirm=true

  • Force push (--force) is disabled unless GIT_ALLOW_FORCE_PUSH=true; force_with_lease is always available

  • Hook bypass (--no-verify) is disabled unless GIT_ALLOW_NO_VERIFY=true

  • git_flow hook and filter execution is disabled unless GIT_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

A
license - permissive license
-
quality - not tested
A
maintenance

Maintenance

Maintainers
Response time
3dRelease cycle
6Releases (12mo)
Commit activity

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

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

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