Server data from the Official MCP Registry
GitHub repo maintainability verdicts—maintained, slowing, at-risk, abandoned—via MCP.
GitHub repo maintainability verdicts—maintained, slowing, at-risk, abandoned—via MCP.
Remote endpoints: streamable-http: https://joeslade--github-repo-intelligence-mcp.apify.actor/mcp
Valid MCP server (2 strong, 2 medium validity signals). No known CVEs in dependencies. Imported from the Official MCP Registry.
Endpoint verified · Requires authentication · 1 issue found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Remote Plugin
No local installation needed. Your AI client connects to the remote endpoint directly.
Add this to your MCP configuration to connect:
{
"mcpServers": {
"io-github-digitalgremlin-github-repo-intelligence-mcp": {
"url": "https://joeslade--github-repo-intelligence-mcp.apify.actor/mcp"
}
}
}From the project's GitHub README.
GitHub Repo Health Check is an MCP server that answers the one question your dependency list can't: is this repo still maintained, or am I building on sand? Last-commit date lies. Star count lies. One signal isn't a verdict. So it returns a four-way read — Actively maintained, Slowing, At-risk, or Likely abandoned — synthesized across four dimensions (activity, issues, PRs, contributors), backed by the transparent, inspectable thresholds that produced it. Point it at any owner/name (or GitHub URL) and your agent gets a verdict it can act on, plus the raw numbers so it can see exactly why. Same repo state + config → the same verdict, every time.
It runs as a Standby Actor on the Apify platform — always warm, reachable over the Streamable HTTP transport at the /mcp path, with API access, scheduling, and monitoring included.
If you've ever asked "is this repo abandoned?" or run a GitHub repo health check by hand, this server does it programmatically at any scale.
Most GitHub tools hand an agent raw API access and leave the judgment to the model — inconsistent, hand-rolled heuristics on every call. This server does the synthesis for you.
The differentiator is judgment, not raw access: every verdict ships alongside the pinned thresholds and raw metrics that produced it, so the agent (and you) can audit the reasoning. Same repo state + same config always yields the same verdict.
One GitHub fetch per repository is cached and shared across all five tools. Drilling from the headline verdict into a specific dimension costs no extra upstream calls.
https://<your-standby-url>/mcp) using the Streamable HTTP transport.get_repo_health with a repo argument ("owner/name" or any https://github.com/owner/name URL) to get the headline verdict.get_activity_metrics, get_issue_health, get_pr_health, or get_contributor_insights when you need detail beyond the headline. All five tools read from the same cached payload.All tools take a single repo argument — either "owner/name" or any https://github.com/owner/name[/...] URL (case-insensitive).
get_repo_health — headline verdictReturns the overall verdict, a per-dimension breakdown, and a rationale string explaining the worst dimension.
{
"repo": "honojs/hono",
"overallVerdict": "Actively maintained",
"dimensions": {
"activity": { "verdict": "Healthy", "lastCommitDaysAgo": 1, "commits90d": 412 },
"issues": { "verdict": "Healthy", "medianFirstResponseDays": 2.4, "staleOpenRatio": 0.12 },
"pullRequests": { "verdict": "Healthy", "mergeRate": 0.88, "oldestOpenPrDaysAgo": 14 },
"contributors": { "verdict": "Healthy", "totalContributors": 312, "busFactorFlag": false }
},
"rationale": "Overall: activity is Healthy; weakest dimension is issues (Healthy).",
"stars": 21000,
"forks": 640,
"fetchedAt": "2026-06-01T00:00:00.000Z",
"authenticated": true
}
get_activity_metrics — commit cadence and momentumCommit volumes over trailing windows, release frequency, and a momentum trend.
{
"repo": "honojs/hono",
"verdict": "Healthy",
"lastCommitDaysAgo": 1,
"commits30d": 140,
"commits90d": 412,
"commits365d": 1680,
"releaseCount365d": 48,
"lastReleaseDaysAgo": 3,
"momentumTrend": "steady",
"fetchedAt": "2026-06-01T00:00:00.000Z"
}
momentumTrend is accelerating / steady / declining, derived from the 30-day commit rate vs the 90-day rate. Repos that tag rather than cutting GitHub Releases will show releaseCount365d: 0 and lastReleaseDaysAgo: null — this does not by itself degrade the verdict.
get_issue_health — responsiveness and backlog hygieneHow quickly maintainers respond to issues and how much of the backlog has gone stale.
{
"repo": "honojs/hono",
"verdict": "Healthy",
"openIssues": 32,
"closedIssues": 1840,
"openClosedRatio": 0.017,
"medianFirstResponseDays": 2.4,
"medianTimeToCloseDays": 5.1,
"staleOpenIssues": 4,
"staleOpenRatio": 0.12,
"fetchedAt": "2026-06-01T00:00:00.000Z"
}
An issue is stale if untouched for more than 90 days. Medians are null when no qualifying events exist in the analysis window — absence is not the same as zero.
get_pr_health — PR throughput and queue ageHow effectively the project merges or closes contributions, and how old the oldest open PR is.
{
"repo": "honojs/hono",
"verdict": "Healthy",
"openPrs": 6,
"mergedPrs": 220,
"closedUnmergedPrs": 30,
"mergeRate": 0.88,
"medianTimeToMergeDays": 1.2,
"oldestOpenPrDaysAgo": 14,
"fetchedAt": "2026-06-01T00:00:00.000Z"
}
mergeRate excludes still-open PRs from the denominator. It is null when no PRs have been decided in the analysis window.
get_contributor_insights — concentration and bus-factor riskHow many contributors the project has and whether commit activity is dangerously concentrated.
{
"repo": "honojs/hono",
"verdict": "Healthy",
"totalContributors": 312,
"topContributorShare": 0.28,
"topTwoContributorShare": 0.41,
"busFactorFlag": false,
"fetchedAt": "2026-06-01T00:00:00.000Z"
}
busFactorFlag is true when the top contributor owns more than 50% of commits, or the top two together own more than 80%. totalContributors is the repository's all-time contributor count (sourced from GitHub's stable /contributors list endpoint) — it is not a 90-day-active count.
Verdicts come from pinned, transparent thresholds — same repo state plus same config always yields the same verdict.
| Dimension | Healthy | Moderate | At-Risk | Notes |
|---|---|---|---|---|
| Activity | last commit ≤ 30d | 30–180d | 180–365d | Likely abandoned if > 365d |
| Issues | median first response ≤ 7d and staleOpenRatio ≤ 0.40 | ≤ 30d and ≤ 0.60 | otherwise | null median → judged on staleOpenRatio alone |
| Pull requests | mergeRate ≥ 0.60 and oldestOpenPr ≤ 30d | mergeRate ≥ 0.30 or oldestOpenPr ≤ 90d | otherwise | null mergeRate → judged on oldestOpenPr alone |
| Contributors | totalContributors ≥ 3 and not bus-factor | 1–2 contributors, or ≥ 3 with bus-factor | 0 contributors | solo active maintainer → at most Moderate |
Overall verdict is activity-dominant, evaluated top-down (first match wins):
Likely abandoned (no commits in > 365 days).At-Risk, or any two of {issues, PRs, contributors} are At-Risk.Healthy and no dimension is At-Risk.Moderate, or Healthy activity with one At-Risk dimension).The server boots with no input required (a Standby constraint — all fields are optional in the schema so the container never crash-loops on startup). In practice, you must provide a GitHub token for the Actor to return verdicts rather than rate-limit errors.
| Field | Type | Default | Description |
|---|---|---|---|
githubToken | string (secret) | — | Effectively required. GitHub's GraphQL API (this Actor's primary data source) rejects unauthenticated requests, and on Apify's shared IPs the anonymous REST quota (~60 req/hour per IP) is typically already exhausted by other traffic. A token gives 5,000 req/hour and enables private-repo analysis. |
cacheTtlMinutes | integer | 20 | How long a repo's fetched payload is reused before refetching. Lower = fresher data; higher = fewer GitHub API calls. |
analysisWindowDays | integer | 90 | Trailing window (30–365 days) over which issue and PR activity is measured. |
GitHub token setup. A classic token with no scopes is sufficient for public repositories. A fine-grained token scoped to specific repos works for private-repo analysis. For Standby deployments the recommended approach is to set a
GITHUB_TOKENenvironment variable on the Actor (stored as a secret) rather than pasting the token into the input field — it persists across restarts. Both paths work; both are stored as secrets and never exposed in logs.
Each tool returns a single structured JSON object (shown above in each tool's section). Responses are deterministic — same repo state plus same config always produces the same verdict. Each response includes a fetchedAt timestamp reflecting when the underlying GitHub payload was pulled. A cached read returns the same timestamp as the original fetch for that TTL window.
| Field | What it tells you |
|---|---|
overallVerdict | The headline: Actively maintained / Slowing / At-risk / Likely abandoned |
lastCommitDaysAgo | Days since the most recent commit; null if no commits found |
commits30d / commits90d / commits365d | Commit counts over trailing 30, 90, and 365-day windows |
momentumTrend | Whether commit rate is accelerating, steady, or declining (30d vs 90d rate) |
medianFirstResponseDays | Median time (days) until a maintainer first responds to a new issue |
staleOpenRatio | Fraction of open issues that have had no activity in 90+ days |
mergeRate | Merged PRs ÷ (merged + closed-unmerged) — excludes still-open PRs |
oldestOpenPrDaysAgo | Age of the oldest PR that is still open |
totalContributors | All-time contributor count (not a 90-day-active figure — see FAQ) |
busFactorFlag | true when commit activity is dangerously concentrated on 1–2 people |
This Actor runs in Standby mode and is billed for the compute used while warm and serving requests. Health reads are lightweight — each repo's GitHub data is fetched once, cached (default 20 minutes), and shared across all five tools. Drilling into multiple dimensions for the same repo costs a single upstream fetch.
A GitHub token is required in practice (see Input) and adds no extra Apify cost.
get_repo_health for the headline verdict, then call a dimension tool only when you need detail — they all share the same cached payload.cacheTtlMinutes when triaging a long list of repos in a batch to minimize GitHub API calls. Lower it when you need fresh reads.GITHUB_TOKEN as an environment variable on the Actor rather than in the input field — it persists across Standby restarts without re-supplying input.analysisWindowDays (30–365) to match how recent you need issue and PR signals to be. A shorter window surfaces recent trajectory; a longer window averages over a steadier baseline.get_repo_health) with a repo argument.config.ts and return a dimension verdict.fetchedAt — is returned to the MCP client.All five tools share step 2's cached payload. The verdict logic is deterministic and clock-injected (testable without network).
Part of a small slate of agent-focused Apify Actors:
Does it work on private repositories?
Yes — provide a githubToken with read access to the repo.
Is the verdict subjective or configurable? No. Every verdict comes from the pinned thresholds documented above. Same repo state always yields the same verdict. The raw metrics are returned alongside it so you can audit every call.
Why is totalContributors not a 90-day-active count?
GitHub's per-period contributor stats endpoint (/stats/contributors) is unreliable on a cold cache — it returns 202 and rarely warms within a request cycle. Contributors are sourced from the stable all-time /contributors list instead. The field reflects repository-lifetime contributor breadth, not recent activity.
What does the rationale field contain?
It names the activity verdict and the weakest non-activity dimension, e.g. "Overall: activity is Healthy; weakest dimension is issues (Moderate)." It's designed for agent logs and human audit trails, not user-facing copy.
The Actor returned a rate-limit error — what do I do? Add a GitHub token. See Input. A classic token with no scopes is free and takes under a minute to create at github.com/settings/tokens.
Found a bug or want a feature? Open an issue on the Actor's Issues tab. Custom variations are available on request.
Copyright © 2026 Joe Slade.
Licensed under the GNU Affero General Public License v3.0 (AGPL-3.0). You're free to use, study, modify, and self-host this software; if you run a modified version as a network service, the AGPL requires you to offer your modified source to its users under the same license. For a commercial license not subject to the AGPL's network-copyleft, contact the author.
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Web content fetching and conversion for efficient LLM usage
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.