01 · Roasts
The Heatmap Cliff
Your contribution graph looks like a heart monitor that flatlined — dense green for months, then six straight rows of zeros. 23 commits in the past year across 47 repos is less than one commit every two weeks.
Graveyard Curator
79% of your 47 repos haven't been touched in over 2 years. You've built a small city of abandoned projects. At least name a street after them.
Test? Never Heard of Her
Zero tests, zero CI across every single scored repo — re-scratch, AbirPortfolio, Polaroid-App. You're shipping to production with vibes and prayer.
Community of One
0 PRs, 0 issues filed in the past year. 17 followers. The open-source community doesn't know you exist, and you haven't tried to introduce yourself.
4 Stars, 47 Repos
That's 0.085 stars per repo. Your entire public portfolio has attracted fewer stars than a repo named 'hello-world' gets by accident.
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% weight36F
- Consistency20% weight55D
- Quality20% weight50D
- Depth15% weight50D
- Breadth10% weight55D
- Community10% weight40D
03 · Stats
365-day commit heatmap
244 active days
Language distribution
- JavaScript58%
- TypeScript29%
- CSS9%
- Java3%
- HTML2%
- Solidity0%
04 · Numbers
Owned repos
non-fork
34
Commits
last 12 months
23
Followers
17
Joined GitHub
Jan 2021
05 · Top repos
AbirSantra /
re-scratch
A React block-based coding environment inspired by Scratch with drag-and-drop blocks, multiple sprites, collision detection, and nested repeat blocks. Fresh project with typed React + Zustand state, clean architecture, but no tests or CI.
AbirSantra /
AbirPortfolio
Personal portfolio site built with Next.js + TypeScript + Sanity CMS. Typed, well-structured, and documented, but 1 star, no tests/CI, and clearly a showcase of owner's own work rather than a reusable project.
AbirSantra /
Polaroid-App
Polaroid is a TypeScript + React + Vite social media app with authentication, posts, comments, likes, and user profiles. Typed code, structured layout, and comprehensive validation, but no tests, CI, or license; README is boilerplate; 30 commits over ~3.5 months is modest depth for a 357 KB codebase.
06 · Timeline
- Jan 29, 2021Joined GitHub
- Jul 5, 2023Created AbirPortfolio
- Jan 4, 2024Created Polaroid-App
- Feb 20, 2026Created re-scratch — An attempt to recreate the basic scratch editor with collision feature
- Feb 22, 2026Most recent push to re-scratch
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.