fs-git-mcp

fs-git-mcp

A Git-enforced filesystem MCP server that integrates git with filesystem operations, enforcing commits on writes, providing reads with history, and supporting staged branching.

Category
Visit Server

README

FS-Git MCP Server

A Git-enforced filesystem MCP server that integrates git with filesystem operations, enforcing commits on writes, providing reads with history, and supporting staged branching.

Features

  • Direct Mode: Write and commit in one call with templated messages.
  • Staged Mode: Open ephemeral branch, stage edits, preview, then merge/rebase or abort.
  • Reader Subagent: Intent-directed extraction and summarization.
  • Integrated Tools: Wraps file_system, text_replace, code_diff with git semantics.
  • Safety: Path traversal protection, git safe.directory, dirty tree guards.

Installation

uv venv && uv pip install -e .[dev]
pre-commit install

MCP Server Usage

Running the MCP Server

The fs-git MCP server can be run in two ways:

Option 1: Using the CLI command

# For Claude Desktop and MCP Inspector (stdio transport)
fs-git serve

# For development/testing (TCP transport)  
fs-git serve --transport tcp --port 8080

Option 2: Using the direct MCP server command

# stdio mode (default, for Claude Desktop)
fs-git-mcp

# TCP mode for development
fs-git-mcp --transport tcp --port 8080

Option 3: Using uvx (no installation required)

# Run directly without installation
uvx fs-git-mcp

# Or with the CLI
uvx --from . fs-git serve

Claude Desktop Configuration

Add this to your Claude Desktop configuration (~/.claude/config.json):

{
  "mcpServers": {
    "fs-git": {
      "command": "uvx",
      "args": ["fs-git-mcp"]
    }
  }
}

Or if installed locally:

{
  "mcpServers": {
    "fs-git": {
      "command": "fs-git-mcp"
    }
  }
}

Testing with MCP Inspector

# Install MCP Inspector
npm install -g @modelcontextprotocol/inspector

# Test the server
npx @modelcontextprotocol/inspector fs-git-mcp

Available MCP Tools

The MCP server exposes these tool namespaces:

  • git_fs: write_and_commit, read_with_history, start_staged, staged_write, staged_preview, finalize_staged, abort_staged
  • fs_reader: extract, answer_about_file
  • fs_text_replace: replace_and_commit
  • fs_code_diff: preview_diff
  • fs_io: read_file, stat_file, list_dir, make_dir

Path Authorization

FS-Git supports configurable path authorization for security. You can restrict which paths can be accessed using CLI parameters or environment variables.

CLI Parameters

# Allow only specific paths
fs-git write --repo <root> --path src/utils.py \
  --allow-paths "src/**,docs/**" \
  --deny-paths "!src/secrets/**,!**/node_modules/**" \
  --file - --subject "[{op}] {path} – {summary}" \
  --op "add" --summary "utility functions" <<'EOF'
def helper():
    return "utility"
EOF

Environment Variables

Set path patterns via environment variables for global configuration:

# Set allowed paths (comma-separated)
export FS_GIT_ALLOWED_PATHS="src/**,docs/**,*.md"

# Set denied paths (comma-separated, with ! prefix)
export FS_GIT_DENIED_PATHS="!**/node_modules/**,!**/.git/**,!src/secrets/**"

# Now all fs-git commands will use these patterns
fs-git write --repo <root> --path src/app.py --file - --subject "Add app" <<'EOF'
print("Hello World")
EOF

Pattern Support

  • Glob patterns: src/**, docs/**/*.md, *.txt
  • Regex patterns: r".*\.py$", r".*\.js$"
  • Deny patterns: Prefix with ! (e.g., !**/node_modules/**)
  • Absolute paths: /etc/hosts, /usr/local/bin/
  • Relative paths: src/, ./docs/

Priority: CLI parameters override environment variables.

Quick Start

  1. Initialize a repo:

    fs-git init <repo_root>
    
  2. Direct write:

    fs-git write --repo <root> --path <p> --file <in> \
      --subject "[{op}] {path} – {summary}" --op "edit" --summary "update"
    
  3. Staged flow:

    sid=$(fs-git staged start --repo <root> --ticket T-123)
    fs-git staged write --session "$sid" --path <p> --file <in> --summary "..."
    fs-git staged preview --session "$sid"
    fs-git staged finalize --session "$sid" --strategy rebase-merge
    
  4. Reader extract:

    fs-git reader extract --repo <root> --path <p> --query "foo.*bar" --regex
    

Demo

Quick Demo

Run the basic demo script:

make demo

Comprehensive Demo

Run the complete copy-paste demo that showcases all features:

# From the fs-git project root
bash repos/fs-git/scripts/comprehensive_demo.sh

This comprehensive demo includes:

  • Installation and setup
  • Basic direct write operations with git commits
  • Staged workflow with ephemeral branches
  • Text replacement and patch application
  • Path authorization with allowed/denied patterns
  • Environment variable configuration
  • MCP server testing
  • Claude Desktop integration examples

Development

  • Tests: make test
  • Lint: make fmt && make lint
  • E2E: make test-e2e

Architecture

See ARCHITECTURE.md for module details.

Tooling

See TOOLING.md for MCP schema and integrations.

Troubleshooting

Common Issues

  • Import Errors: Ensure mcp_server is in PYTHONPATH or installed with uv pip install -e .
  • Git Safe Directory: If git complains about unsafe repo, run git config --global --add safe.directory <repo_root>
  • Path Authorization Denied: Check your FS_GIT_ALLOWED_PATHS and FS_GIT_DENIED_PATHS env vars or CLI flags.
  • Staged Session Not Found: Sessions are stored in ~/.fs_git_sessions. Clear if corrupted.
  • MCP Inspector Connection: Use fs-git serve for stdio mode with Inspector. For TCP, use --transport tcp.
  • Subprocess Python Errors: Tests use sys.executable to match your Python environment.

Logs

  • Server logs: Check server.log or stderr.
  • Git logs: Use git log --oneline -10 in repo.

Debug Mode

Run with debug:

FS_GIT_DEBUG=true fs-git serve --transport tcp

Changelog

See CHANGELOG.md.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured