01 · Roasts
Bootstrap Tourist
Your top language is CSS at 61% — but that's almost entirely inherited from a Bootstrap template you barely modified. 'This is my first project' in the README is doing a lot of heavy lifting for 5 years of commits.
CI/CD Stranger
Zero repos have CI across your entire portfolio. You're automating Kubernetes clusters with Flux and GitOps for fun, but can't be bothered to add a GitHub Actions workflow to any of your own repos. The cobbler's children have no shoes.
Ghost of Commits Past
Your heatmap is a wasteland — 35+ weeks of pure zeros, with one frantic burst of activity in weeks 24–25 and then silence. 230 commits/year sounds decent until you see they're crammed into about 8 weeks total.
51 PRs, 5 Followers
You opened 51 pull requests this year — more than one a week — and somehow still only have 5 followers. Either you're exclusively grinding private repos or you're the most productive invisible engineer on GitHub.
Brand New Baby Module
Your Terraform GKE scheduler module was created 2 days before this review with 0 stars and minimal commits. Bold strategy to count a 48-hour-old repo as portfolio evidence.
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% weight43D
- Consistency20% weight55D
- Quality20% weight57D
- Depth15% weight50D
- Breadth10% weight55D
- Community10% weight40D
03 · Stats
365-day commit heatmap
31 active days
Language distribution
- CSS61%
- HCL13%
- Shell10%
- HTML7%
- Python4%
- PowerShell2%
- Other3%
04 · Numbers
Owned repos
non-fork
7
Commits
last 12 months
230
Followers
5
Joined GitHub
Apr 2018
05 · Top repos
gianniskt /
k8s-gitops-chaos-lab
Active portfolio project: a comprehensive k3d/Kubernetes homelab with GitOps (Flux), chaos engineering (Chaos Mesh), service mesh (Linkerd), and autoscaling (KEDA). Well-documented with working setup automation, but limited stars/adoption.
gianniskt /
terraform-google-gke-operation-scheduler
Fresh Terraform module (25 KB) for scheduling GKE node pool start/stop operations via Cloud Scheduler and Cloud Functions. Typed HCL with structured multi-file layout, comprehensive README, working code examples, and Python function implementation. Created 2 days ago with minimal commit history.
gianniskt /
resume
Personal resume website using Bootstrap template, deployed to GitHub Pages. Single-file HTML structure with minimal customization; no CI/CD, tests, or substantial code development. Functional but template-driven with limited technical depth.
06 · Timeline
- Apr 11, 2018Joined GitHub
- Dec 31, 2020Created resume — Koutroumpis Giannis Personal Page
- Oct 9, 2025Created k8s-gitops-chaos-lab — Kubernetes GitOps Homelab with Flux, Linkerd, Cert-Manager, Chaos Mesh, Keda & Prometheus
- Jan 26, 2026Created terraform-google-gke-operation-scheduler — Terraform module to schedule start/stop of GKE node pools using Cloud Scheduler + Cloud Functions
- Mar 16, 2026Most recent push to resume
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.