Brings Gitrama's AI-powered Git intelligence into any MCP-compatible editor. Exposes 15 tools covering the full development loop: smart commits, branch naming, PR descriptions, code review, and workflow stream management. The diff and review tools are standouts, launching risk-annotated HTML panels with churn rates, coupling context, and contributor data overlaid on every changed file. Results pull from a structural health scan that scores files for continuity risk and boundary entropy. You can stage, commit, push, and switch workflow streams without leaving chat. Runs locally via pip or connects to a hosted endpoint at mcp.gitrama.ai. Best suited for teams already using Gitrama who want to automate Git operations through their AI assistant rather than the command line.
AI-powered Git intelligence for your IDE — smart commits, branch names, PR descriptions, diffs, code review, push, and workflow management.
Gitrama MCP Server exposes Gitrama's CLI as 15 MCP tools that any AI assistant can use. Instead of typing gtr commit in your terminal, your AI assistant calls the tool directly — analyzing your code changes, generating commit messages, suggesting branch names, reviewing code, and more.
Works with: Cursor · Claude Desktop · Claude Code · Windsurf · VS Code · Zed · any MCP-compatible client
gitrama_scan, gitrama_diff, gitrama_review, gitrama_status, and gitrama_pushgitrama_health now returns the MCP server version so you can confirm exactly what's runninggitrama_diff launches a browser panel with risk-annotated diffs, churn rates, coupling context, and contributor info overlaid on every changed filegitrama_push supports upstream tracking, force-with-lease, and auto-resolves the current branchhttps://mcp.gitrama.ai/mcp, no local install requiredpip install gitrama-mcp
Or with uv:
uv pip install gitrama-mcp
This installs both the MCP server and the gitrama CLI.
Add to .cursor/mcp.json in your project (or global settings):
{
"mcpServers": {
"gitrama": {
"command": "gitrama-mcp",
"env": {
"GITRAMA_TOKEN": "your_token_here"
}
}
}
}
Add to claude_desktop_config.json:
~/Library/Application Support/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.json{
"mcpServers": {
"gitrama": {
"command": "gitrama-mcp",
"env": {
"GITRAMA_TOKEN": "your_token_here"
}
}
}
}
claude mcp add gitrama gitrama-mcp
Add to .vscode/mcp.json:
{
"mcpServers": {
"gitrama": {
"command": "gitrama-mcp",
"env": {
"GITRAMA_TOKEN": "your_token_here"
}
}
}
}
Add to ~/.codeium/windsurf/mcp_config.json:
{
"mcpServers": {
"gitrama": {
"command": "gitrama-mcp",
"env": {
"GITRAMA_TOKEN": "your_token_here"
}
}
}
}
Add to Zed settings (⌘,):
{
"context_servers": {
"gitrama": {
"command": {
"path": "gitrama-mcp"
},
"env": {
"GITRAMA_TOKEN": "your_token_here"
}
}
}
}
Connect directly to the hosted Gitrama MCP server. Works with Claude.ai, Claude Desktop, Cursor, Windsurf, VS Code, and any MCP-compatible client:
{
"mcpServers": {
"gitrama": {
"url": "https://mcp.gitrama.ai/mcp",
"env": {
"GITRAMA_TOKEN": "your_token_here"
}
}
}
}
Or install via Smithery:
smithery mcp add GitramaLLC/gitrama-mcp
Ask your AI: "Commit my staged changes" — and watch it call gitrama_commit.
| Tool | Description |
|---|---|
gitrama_health | Check AI server health and confirm MCP server version |
| Tool | Description |
|---|---|
gitrama_ask | Ask any question about your repo — ownership, history, risk, changes |
gitrama_scan | Full structural health scan — continuity risk, boundary entropy, recurrence patterns |
gitrama_status | Show working tree status with AI interpretation |
| Tool | Description |
|---|---|
gitrama_diff | Risk-annotated diff with interactive HTML panel — churn, coupling, contributor context |
gitrama_review | AI code review before you push — security, correctness, risk, coupling |
| Tool | Description |
|---|---|
gitrama_commit | Generate an AI commit message for staged changes |
gitrama_stage_and_commit | Stage files + commit in one step |
gitrama_unstage | Remove files from staging without discarding changes |
| Tool | Description |
|---|---|
gitrama_branch | Create a branch from a natural language description |
gitrama_push | Push current branch to remote with upstream and force-with-lease support |
| Tool | Description |
|---|---|
gitrama_pr | Generate a PR description from branch diff |
gitrama_changelog | Generate a changelog between refs |
| Tool | Description |
|---|---|
gitrama_stream_status | Show current workflow stream |
gitrama_stream_switch | Switch to a different stream |
gitrama_stream_list | List all streams in the repo |
gitrama_healthCheck AI server connectivity and confirm the running MCP server version.
Example prompt: "Run a gitrama health check"
Example output:
✅ AI server is healthy!
🤖 Model: grok-4.20-reasoning
🌐 Connected to: https://api.x.ai/v1
🔖 Gitrama MCP Server: v1.3.2
gitrama_scanRun a full structural health scan of the repository. Scores every file for continuity risk, boundary entropy, and recurrence patterns. Results are cached in last_scan.json for use by gtr diff and gtr review.
Example prompt: "Run a full gitrama scan of my repo"
gitrama_diffShow a risk-annotated diff of current changes. Opens an interactive HTML browser panel with Gitrama's structural intelligence overlaid — risk scores, churn rates, coupling gaps, and contributor context for every changed file.
Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
target | string | "" | Branch or commit to diff against |
staged | bool | false | Diff staged changes only |
Example prompts:
gitrama_reviewRun an AI code review on current changes before committing. Returns severity-graded findings — security, correctness, risk, coupling — plus a verdict and suggested commit message.
Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
mode | string | "staged" | "staged", "uncommitted", "quick", "full" |
Example prompts:
gitrama_pushPush the current branch to a remote repository. Uses --force-with-lease for safe force pushes and auto-resolves the current branch if none is specified.
Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
remote | string | "origin" | Remote to push to |
branch | string | "" | Branch to push (default: current branch) |
force | bool | false | Force push with --force-with-lease |
set_upstream | bool | false | Set upstream tracking branch (-u) |
Example prompts:
gitrama_statusShow the working tree status with AI interpretation of staged, unstaged, and untracked files.
Example prompt: "What's my current git status?"
gitrama_askAsk a natural language question about your repository. Gitrama analyzes commit history, file structure, blame data, and diffs to answer.
Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
question | string | required | Any question about your repo |
stream | string | "" | Optional stream context override |
deep | bool | false | Enable full repo history access |
Example prompts:
gitrama_commitGenerate an AI-powered commit message for staged changes.
Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
message | string | "" | Optional custom message (skips AI generation) |
Example prompt: "Commit my staged changes"
gitrama_stage_and_commitStage files and commit in one step.
Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
files | string | "." | Files to stage (. for all, or space-separated paths) |
message | string | "" | Optional custom message |
Example prompt: "Stage and commit all my changes"
gitrama_unstageRemove files from the staging area without discarding changes.
Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
files | string | "" | Space-separated file paths to unstage |
all_files | bool | false | Unstage everything currently staged |
Example prompt: "Unstage src/auth.py"
gitrama_branchGenerate an AI-powered branch name from a description and optionally create it.
Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
description | string | required | What you're working on |
create | bool | true | Create and switch to the branch |
Example prompts:
gitrama_prGenerate a PR description from the diff between the current branch and base.
Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
base | string | "" | Target branch (default: main/master) |
Example prompt: "Write a PR description for this branch"
gitrama_changelogGenerate a changelog between refs.
Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
since | string | "" | Start ref (tag, branch, hash) |
until | string | "" | End ref (default: HEAD) |
format | string | "markdown" | "markdown" or "json" |
Example prompt: "Generate a changelog since v1.1.4"
| Tool | Parameters | Example prompt |
|---|---|---|
gitrama_stream_status | none | "What stream am I on?" |
gitrama_stream_switch | name, description | "Switch to the hotfix stream" |
gitrama_stream_list | none | "List all my gitrama streams" |
With all 15 tools connected, your full dev loop runs from chat:
describe intent → stream switch
write code
ask gitrama what changed → diff (HTML panel)
review before push
commit with AI message
push
PR description generated
No terminal. No manual git commands.
| Variable | Default | Description |
|---|---|---|
GITRAMA_TOKEN | "" | Your Gitrama API key |
GTR_CWD | os.getcwd() | Working directory for git operations |
GTR_MCP_TRANSPORT | "stdio" | Transport: "stdio" or "streamable-http" |
GTR_MCP_HOST | "0.0.0.0" | HTTP host (when using streamable-http) |
GTR_MCP_PORT | "8765" | HTTP port (when using streamable-http) |
GTR_MCP_TRANSPORT=streamable-http GTR_MCP_PORT=8765 gitrama-mcp
Then connect your client to http://localhost:8765/mcp.
Set your API key:
gtr config --key YOUR_API_KEY
Or use a local model:
gtr config --provider ollama --model llama3
git clone https://github.com/GitramaLLC/gitrama-mcp.git
cd gitrama-mcp
pip install -e ".[dev]"
# Test with MCP Inspector
mcp dev src/gitrama_mcp/server.py
Proprietary — see LICENSE.
Built by Alfonso Harding · gitrama.ai
🌿