01 · Roasts
One-Day Wonder
Your entire year of GitHub activity fits in a single Thursday afternoon — literally one cell lit up on the heatmap out of 364. Even your keyboard is embarrassed.
Deadline-Driven Developer
deepfake-check went from zero to 'submitted' in 3 days with 21 commits. That's not iterative development, that's panic with a Dockerfile slapped on top.
Credential Courageous
virtual-tour-guide-emas-mobile-app shipped with hardcoded credentials and no README. Security is clearly a future version feature.
92% Abandoned
staleRepoRatio = 0.92. You have 14 public repos and haven't touched 13 of them in over 2 years. That's not a portfolio, that's a graveyard with a LinkedIn link.
Polyglot on Paper
JavaScript, Dart, PHP, SCSS, Jupyter — impressive language spread for someone with 0 stars, 0 PRs, and 21 commits this year. The languages exist; the shipped products do not.
Built using
Zoral
Shadows one worker for a week, then takes over their job with zero extra setup. Behaves exactly like the original.
zoral.ai
02 · Category breakdown
- Impact25% weight25F
- Consistency20% weight20F
- Quality20% weight41D
- Depth15% weight35F
- Breadth10% weight65C
- Community10% weight25F
03 · Stats
365-day commit heatmap
1 active days
Language distribution
- JavaScript45%
- Jupyter Notebook19%
- CSS16%
- SCSS6%
- PHP6%
- Dart4%
- Other4%
04 · Numbers
Owned repos
non-fork
12
Commits
last 12 months
21
Followers
9
Joined GitHub
Oct 2019
05 · Top repos
Ruth44 /
deepfake-check
Flask-based deepfake detection web app with user auth, image upload, and model inference. Experimental FYP project (~93MB) built in ~3 days with basic structure but lacking tests, typing, and production hardening.
Ruth44 /
virtual-tour-guide-flutter
Flutter building manager app with BLoC architecture, basic CRUD operations for museums. Functional with tests but thin scope, sparse commits (4 of 30 in recent history), no CI/CD, no license, and limited documentation beyond README.
Ruth44 /
virtual-tour-guide-emas-mobile-app
Unfinished museum management backend with hardcoded credentials, no tests, no CI, no documentation, and security vulnerabilities. 0 stars, 15 commits over ~45 days, ~400 KB codebase.
06 · Timeline
- Oct 12, 2019Joined GitHub
- Dec 14, 2022Created virtual-tour-guide-emas-mobile-app
- Dec 21, 2022Created virtual-tour-guide-flutter
- Jul 10, 2025Created deepfake-check
- Jul 10, 2025Most recent push to deepfake-check
07 · Compare
08 · Rubric
How this score was produced
Overall = Σ (category × weight) + gentle top-end curve
Tier thresholds
▸ How the pipeline works
- 01Scrape.Pull every non-fork repo pushed in the last 90 days, plus your contribution calendar, followers, and language byte counts — straight from GitHub's REST & GraphQL APIs.
- 02Triage.A small model reads every repo's file tree + README and picks the 20 files per repo that actually reveal how you code.
- 03Grade each repo. All repos run in parallel through a fast scoring model that reads the picked files and rates each one independently on Impact, Quality, and Depth — with evidence citations.
- 04Aggregate. A larger reasoning model combines the per-repo scores with server-computed stats (heatmap, commit cadence, language entropy, follower count) to produce the 6-dimension profile score + roasts.
- 05Correct.Deterministic server-side checks enforce anchor-scale floors (e.g. a profile with 2,000+ public commits can't score 30 Consistency) and recompute the final verdict.
~90 seconds per profile, ~$0.25 in compute. Total of ~240 files read across your top-12 repos. One rating per GitHub account per day.
▸ Data sources & caveats
- Heatmap & commit totals: GitHub GraphQL
contributionsCollection— covers the last 365 days, includes private repos when the user has opted in (default). - Language %: byte totals across the top 30 owned non-fork repos.
- Curve: a small upward nudge centered on raw score ≈ 70, capping at 100. Prevents specialists from being unfairly penalised for narrow breadth.
- Anchor corrections: when server-measured signals (e.g. privateWorkLikely, multiRepoVolume, follower count) mandate a minimum category score, the aggregation step enforces it. These are signal-conditional, not identity-based floors.