Analyze a GitHub profile and get honest, actionable advice for building real reputation
Project description
github-rep
Score any GitHub user's reputation across 11 honest signals and get a prioritized fix list — in under 30 seconds.
Why this exists
GitHub profiles are the de-facto developer resume. Most advice on building GitHub reputation is either vague ("just contribute more") or gameable (spam-stars, low-effort PRs). This tool measures the signals that actually matter to recruiters, maintainers, and other developers — and tells you exactly what to fix first, ordered by impact.
Install
pip install github-rep
Requires Python 3.9+. No configuration needed — works unauthenticated (60 req/hr) or with a GitHub token for 5000 req/hr.
Quickstart
# Analyze any GitHub user
github-rep analyze-profile torvalds
# Use a token to avoid rate limits
export GITHUB_TOKEN=ghp_yourtoken
github-rep analyze-profile sindresorhus
# Machine-readable JSON output
github-rep analyze-profile gvanrossum --json
# Show all findings, including low-priority ones
github-rep analyze-profile octocat --verbose
# Compare multiple profiles side by side
github-rep compare torvalds gvanrossum sindresorhus
# Check your API rate limit
github-rep rate-limit
Sample output
$ github-rep analyze-profile torvalds
╭──────────────────────────────── GitHub Profile ─────────────────────────────╮
│ @torvalds | Linus Torvalds │
│ │
│ Followers: 305,509 | Public repos: 12 | Stars earned: 246,028 │
╰──────────────────────────────────────────────────────────────────────────────╯
Grade: B (78/100)
Tier: Active developer
Score Breakdown
┏━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━┳━━━━━━━┓
┃ Dimension ┃ Score ┃ Max ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━╇━━━━━━━┩
│ Profile Completeness │ 4 │ 10 │
│ Readme Quality │ 12 │ 15 │
│ Star Signal │ 20 │ 20 │
│ Contribution Streak │ 15 │ 15 │
│ Repo Diversity │ 7 │ 10 │
│ Description Quality │ 10 │ 10 │
│ Topic Tags │ 0 │ 5 │
│ Fork Ratio │ 5 │ 5 │
│ Recent Activity │ 5 │ 10 │
│ Release Cadence │ 0 │ 5 │
│ Profile Readme │ 0 │ 5 │
└──────────────────────────┴────────┴───────┘
Priority fixes:
[HIGH] Missing bio
Your bio is empty. It is the first thing visitors read.
Fix: Write 1-2 sentences: your focus, what you build, your superpower.
What is working:
[GOOD] Strong star signal (246028 total, top repo: 235147)
[GOOD] Active recent commits (0d ago)
[GOOD] All repos have descriptions
Grades: A (≥80) · B (≥65) · C (≥50) · D (≥35) · F
The 11 scored dimensions
| # | Dimension | Max pts | What it measures |
|---|---|---|---|
| 1 | Profile Completeness | 10 | Name, bio, avatar, location, website / social link |
| 2 | README Quality | 15 | Top repo README length, code examples, install instructions |
| 3 | Star Signal | 20 | Total stars earned across all repos (log-scaled) |
| 4 | Contribution Streak | 15 | Days since last profile activity |
| 5 | Repo Diversity | 10 | Number of public repos and language breadth |
| 6 | Description Quality | 10 | Fraction of repos with meaningful descriptions |
| 7 | Topic Tags | 5 | Repos tagged with relevant GitHub topics |
| 8 | Fork Ratio | 5 | Proportion of original work vs. forked repos |
| 9 | Recent Activity | 10 | Repos with pushes in the last 90 days |
| 10 | Release Cadence | 5 | Published GitHub Releases on top repos |
| 11 | Profile README | 5 | Presence and quality of the username/username profile README |
Total: 100 points.
Dimensions 10 and 11 are new in v0.2.0 and measure signals that indicate a polished, production-ready presence — publishing versioned releases and curating a profile page.
All flags
github-rep analyze-profile <username> [OPTIONS]
| Flag | Description |
|---|---|
--json |
Machine-readable JSON output (all scores + findings) |
--verbose / -v |
Show all findings including low-priority improvements |
--token / -t |
GitHub PAT (also reads GITHUB_TOKEN env var) |
--top N |
Number of top repos to deep-analyze (default: 10) |
--help |
Show help and exit |
JSON output
github-rep analyze-profile gvanrossum --json
{
"username": "gvanrossum",
"total": 72,
"grade": "B",
"tier": "Active developer",
"breakdown": {
"profile_completeness": 8,
"readme_quality": 12,
...
},
"findings": [
{
"category": "topic_tags",
"severity": "medium",
"title": "Most repos have no topic tags",
"detail": "Missing from GitHub Explore category pages entirely.",
"fix": "Add topics to your top 3 repos today - GitHub UI, takes 2 minutes."
}
]
}
Caching
Results are cached for 5 minutes under ~/.cache/github-rep/ to avoid hitting rate limits when
running the tool multiple times. Delete the cache directory to force a fresh fetch.
FAQ
Do I need a GitHub token?
No. Unauthenticated usage gets 60 API requests per hour — enough for a single profile analysis.
Set GITHUB_TOKEN to get 5000 requests per hour and avoid hitting limits when comparing many profiles.
How is the score calculated? Each dimension is scored independently against fixed max points (totalling 100). There is no machine learning or relative ranking — the score reflects the absolute presence or absence of each signal.
Can I game the score? You could game every individual metric, but you would also genuinely improve your GitHub presence in the process. The signals are chosen because they correlate with real reputation value.
Why does a well-known developer score lower than expected? Some high-reputation developers (including Linus Torvalds) score below 80 because they skip signals like topic tags, profile READMEs, or GitHub Releases. The tool measures profile hygiene signals, not absolute influence.
How often should I re-run this?
After each batch of improvements. Treat it like npm audit — run it, fix the findings, move on.
Contributing
See CONTRIBUTING.md. Bug reports and improvements welcome — open an issue on github.com/basilalshukaili/github-rep.
License
MIT — see LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file github_rep-0.2.0.tar.gz.
File metadata
- Download URL: github_rep-0.2.0.tar.gz
- Upload date:
- Size: 19.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6610f70e3e55c89fe176e97acb026a9df3b10cea088674e271733b51df75f73a
|
|
| MD5 |
f2aa7b36c88d7dee58a6b20149ac3258
|
|
| BLAKE2b-256 |
b58fe35548fc842c68cd2efa865cb7324901592e2fcc34d01f99d6117bdb3ac4
|
File details
Details for the file github_rep-0.2.0-py3-none-any.whl.
File metadata
- Download URL: github_rep-0.2.0-py3-none-any.whl
- Upload date:
- Size: 15.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f6a6418b25bc1fb71b7a9939c4c4c59df41e467a78a76d1eca8740a61e5e8e96
|
|
| MD5 |
b6168d6f166e1ea4b2a34062de058f9c
|
|
| BLAKE2b-256 |
7e934b90ecef8d4199494fe5fd72ed85d892bd6962240f67882dd757408036c9
|