gitpulse-mcp
Provides tools for analyzing GitHub repository activity, including code review bottlenecks, stale pull requests, and commit message hygiene.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@gitpulse-mcpfind stale PRs in vercel/next.js"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
gitpulse-mcp
A remote MCP (Model Context Protocol) server that exposes GitHub engineering-analytics tools to LLM clients — Claude Desktop, Claude Code, the Cloudflare AI Playground, or any MCP-compatible client. It answers three questions:
Where are code reviews bottlenecked? (time-to-first-review, time-to-merge, worst offenders)
Which open PRs are at risk of going stale? (no review activity past a threshold)
Is our commit hygiene improving? (% of commits matching a convention, trend over time)
Built as a portfolio project generalizing a commit-lint + CI enforcement tool
([A-Z]+-[0-9]+: description) into a broader "engineering health" MCP server.
Architecture
flowchart LR
Client["MCP Client\n(Claude Desktop / Code / AI Playground)"] -->|Streamable HTTP /mcp| Worker
subgraph Worker["Cloudflare Worker"]
MCP["GitPulseMCP\n(McpAgent, Durable Object)"]
Tools["tools/\nrepoPulse · stalePrs · reviewBottlenecks · commitLint"]
Analytics["analytics/\npure functions: percentiles, staleness, lint stats"]
Cache["cache.ts\nWorkers KV, TTL 10-15min"]
GH["github/client.ts\nfetch wrapper, retries, rate-limit handling"]
end
MCP --> Tools
Tools --> Analytics
Tools --> Cache
Tools --> GH
GH -->|REST + GraphQL| GitHub[("GitHub API")]
Cache -.->|get/put| KV[("Workers KV")]Related MCP server: GitHub Repository Analyzer
Tools
get_repo_pulse(owner, repo, days = 30)
Activity snapshot: PRs opened/merged/closed, commit count, active contributor count over the window.
"How active has
cloudflare/workers-sdkbeen in the last 2 weeks?"
find_stale_prs(owner, repo, stale_after_days = 7)
Open PRs with no activity past the threshold, sorted most-stale first (capped at 20).
"Which open PRs on
vercel/next.jshaven't been touched in over a week?"
get_review_bottlenecks(owner, repo, days = 30)
Median + p90 time-to-first-review and time-to-merge for recently merged PRs, plus the 5 slowest. Uses a single paginated GraphQL search query to avoid REST fan-out.
"Where is code review slowest in
facebook/reactright now?"
lint_commit_history(owner, repo, days = 30, pattern = "^[A-Z]+-[0-9]+: .+")
% of commits matching a regex convention, worst-offender authors, and week-over-week trend. Pattern is compiled defensively (invalid regex and pathological length are rejected before matching).
"Is commit message hygiene improving on our repo month over month?"
Every tool returns shaped JSON plus a one-line summary string, and caches its result
in Workers KV (key: toolName:sha256(args), TTL 10–15 min) to stay within GitHub's
rate limits.
Design decisions
GraphQL only for
get_review_bottlenecks. Computing time-to-first-review per PR over REST would mean one request per PR (N+1) to fetch review timelines. GraphQL'ssearchconnection lets us pull merged PRs and their first review in one paginated query.find_stale_prsusesupdated_atas an activity proxy (v1). The REST PR list endpoint doesn't expose "last review activity" directly; a more precise signal (last review/comment event) would require a timeline fetch per PR. Revisit ifupdated_atproves too noisy (e.g. bot-only pushes counting as activity).Secrets never touch
vars.GITHUB_TOKENis awrangler secret, not awrangler.jsoncvar — the config file is committed to a public repo.
Local development
npm install
cp .dev.vars.example .dev.vars # then fill in a fine-grained PAT (public repo, read-only)
npm run dev # wrangler dev -> http://localhost:8787/mcp
npm test # vitest — analytics unit tests against fixture JSON
npm run typecheck # tsc --noEmitConnect a local MCP client with mcp-remote
pointed at http://localhost:8787/mcp, or use the
Cloudflare AI Playground against the deployed URL.
Deploying
wrangler kv namespace create GITPULSE_CACHE # once, then paste the id into wrangler.jsonc
wrangler secret put GITHUB_TOKEN # once per environment
npm run deployCI runs typecheck + tests on every PR and deploys to workers.dev on merge to main
(needs a CLOUDFLARE_API_TOKEN repo secret).
Roadmap
Phase 1 (current): core server. 4 tools, PAT auth, KV caching, fixture-based tests, CI/CD.
Phase 2: real auth. Migrate to GitHub OAuth (per-user tokens, private-repo access), drop the shared PAT.
Phase 3: backfill/precompute. Background jobs + persistence for large-repo history that times out at request time.
Phase 4: polish & publish. Per-client rate limiting, basic metrics, a write-up analyzing a large OSS repo.
Not in scope (unless explicitly requested): dashboard UI, multi-repo org aggregation, webhooks, write-access tools, non-GitHub forges.
This server cannot be installed
Maintenance
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
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/mahi397/gitpulse-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server