viberank

skill
Guvenlik Denetimi
Basarisiz
Health Gecti
  • License รขโ‚ฌโ€ License: MIT
  • Description รขโ‚ฌโ€ Repository has a description
  • Active repo รขโ‚ฌโ€ Last push 0 days ago
  • Community trust รขโ‚ฌโ€ 100 GitHub stars
Code Basarisiz
  • execSync รขโ‚ฌโ€ Synchronous shell command execution in packages/viberank-cli/cli.js
  • fs.rmSync รขโ‚ฌโ€ Destructive file system operation in packages/viberank-cli/cli.js
  • network request รขโ‚ฌโ€ Outbound network request in packages/viberank-cli/cli.js
  • execSync รขโ‚ฌโ€ Synchronous shell command execution in packages/viberank-mcp-server/src/index.ts
  • fs.rmSync รขโ‚ฌโ€ Destructive file system operation in packages/viberank-mcp-server/src/index.ts
  • network request รขโ‚ฌโ€ Outbound network request in packages/viberank-mcp-server/src/index.ts
Permissions Gecti
  • Permissions รขโ‚ฌโ€ No dangerous permissions requested

Bu listing icin henuz AI raporu yok.

SUMMARY

๐Ÿ† The AI coding usage leaderboard โ€” Claude Code, Codex, Gemini CLI & more. Real costs and tokens from ccusage data. Submit with: npx viberank-cli

README.md

viberank

A community-driven leaderboard for AI coding usage โ€” Claude Code, Codex, Gemini CLI and every other tool ccusage tracks. Submit your stats and see how you rank.

viberank
License
Next.js
TypeScript

Live at viberank.app.

v2 โ€” multi-tool support. viberank started as a Claude Code leaderboard. As ccusage grew to track Codex, Gemini CLI, Copilot, OpenCode and more, viberank evolved with it: submissions from any supported tool are now accepted, recorded per tool, and filterable on the leaderboard. Claude Code remains a first-class citizen โ€” you can now just see how it stacks up against the rest of your stack. Full details in the CHANGELOG.

Features

  • ๐Ÿ† Global leaderboard โ€” top-3 podium + full table, sorted by cost or tokens, with 7d / 30d / custom date filters
  • ๐Ÿงฐ Multi-tool โ€” usage from Claude Code, Codex, Gemini CLI, Copilot, OpenCode and other ccusage-supported agents; every row shows tool chips and the board filters per tool
  • ๐ŸŽฏ Per-tool boards โ€” dedicated leaderboards at /tool/claude, /tool/codex, /tool/gemini, /tool/copilot, /tool/opencode
  • ๐Ÿ“Š Profile pages at viberank.app/profile/{username} โ€” global rank, daily charts, token breakdown, tools used
  • โšก Server-rendered โ€” homepage, profiles, and tool boards are SSR'd with structured data (FAQPage, ProfilePage, BreadcrumbList) for fast paint and full crawlability
  • ๐Ÿš€ Three ways to submit: npx viberank-cli, plain curl, or signed-in web upload
  • ๐Ÿ” GitHub OAuth โ€” verified submissions show a blue check; unverified CLI submissions show a cli pill
  • ๐Ÿ›ก๏ธ Input validation โ€” one-sided token math (reasoning-token aware), cost/token ratio guard, date sanity, realistic-range ceilings
  • ๐Ÿ”„ Merge flow โ€” re-submitting the same range overwrites prior daily entries; merging combines unverified CLI rows into your verified profile
  • โœ๏ธ Blog โ€” data-backed posts on AI coding costs at viberank.app/blog

Submitting your usage data

Option 1: npx viberank-cli (recommended)

npx viberank-cli

This generates a fresh cc.json via ccusage daily --json (the aggregate report across all your detected tools) and POSTs it to /api/submit. It picks up your GitHub username from your git remote / git config user.name.

Option 2: curl

npx ccusage@latest daily --json > cc.json
curl -X POST https://www.viberank.app/api/submit \
  -H "Content-Type: application/json" \
  -H "X-GitHub-User: $(git config user.name)" \
  -d @cc.json

ccusage v20 keys daily entries by period and reports an agent per day; viberank normalizes this server-side, so either the new or older ccusage output works.

Option 3: Web upload

  1. Sign in to viberank.app with GitHub
  2. Click Submit Stats โ†’ Upload cc.json
  3. Drop your cc.json file

Web uploads come back with a verified badge automatically. CLI submissions show as unverified until you sign in and merge them via the prompt on the homepage.

Option 4: MCP server

If you use an MCP-compatible client, viberank-mcp (source) exposes submit and lookup tools:

npx viberank-mcp

Data validation

Submissions are checked at the API level. Anything that fails these rules is rejected:

  • Token math โ€” total >= input + output + cache_creation + cache_read. The total may legitimately exceed the four components because reasoning/thinking tokens (Gemini, Codex, Claude extended thinking) are counted in totalTokens but not broken out by ccusage. We only reject a total that is less than its known parts.
  • Cost/token ratio โ€” must fall within a realistic band; this is the primary guard against inflated token counts now that the token-sum check is one-sided
  • No negative values anywhere in totals or daily breakdowns
  • Valid date format โ€” YYYY-MM-DD
  • Not too far in the future โ€” dates after tomorrow-UTC are rejected (covers users at any global timezone offset)
  • Realistic ranges โ€” total cost can't exceed $5,000 ร— 365 days

Submissions can also be flagged for review by an admin via /admin; flagged rows are hidden from the leaderboard by default.

See VALIDATION.md for the full ruleset.

Merging multiple submissions

If you submit via the CLI before signing in, the row lands on the leaderboard as unverified (cli pill). Once you sign in with the matching GitHub account, the homepage shows a banner offering to verify or merge. That hits an authenticated /api/claim endpoint which:

  1. Finds all submissions under your GitHub username
  2. Picks a base submission (OAuth-verified row wins; else most recent)
  3. Merges daily breakdowns โ€” overlapping dates take the OAuth version
  4. Recomputes totals, sets verified: true, deletes the duplicates

Known limitation: submitting from multiple machines with overlapping dates currently overwrites instead of summing daily data โ€” see #43. Submit from one machine at a time until that's resolved.

Development

Prerequisites

  • Node.js 18+ and pnpm 10+
  • A Supabase project (free tier is fine)
  • A GitHub OAuth app

Setup

git clone https://github.com/sculptdotfun/viberank.git
cd viberank
pnpm install
cp .env.example .env.local

Fill in .env.local (see .env.example for the full list). The required keys are:

NEXT_PUBLIC_SUPABASE_URL=https://<project-ref>.supabase.co
NEXT_PUBLIC_SUPABASE_ANON_KEY=<anon-key>
SUPABASE_SERVICE_ROLE_KEY=<service-role-key>

NEXTAUTH_URL=http://localhost:3000
NEXTAUTH_SECRET=<openssl rand -base64 32>

GITHUB_ID=<github-oauth-client-id>
GITHUB_SECRET=<github-oauth-client-secret>

Apply the schema:

# Run the SQL in supabase/migrations/ in order against your project,
# either via the Supabase SQL editor or the supabase CLI:
#   001_initial_schema.sql
#   002_multi_tool.sql      # adds submissions.tools[] + daily_breakdowns.agents[]

Deploying v2 to an existing instance: apply 002_multi_tool.sql before deploying the app code. The migration is additive (new columns default to '{}'), so it's safe to run ahead of the deploy.

Run the dev server:

pnpm dev

Open http://localhost:3000.

Useful scripts

Command What it does
pnpm dev Start Next dev server (Turbopack) on port 3000
pnpm build Production build
pnpm start Serve the production build
pnpm lint Run next lint
pnpm test Run the ccusage normalization/validation tests (node test/ccusage.test.mts; pass a cc.json path to also test real data)
pnpm exec tsc --noEmit Type-check without emitting

Tech stack

  • Frontend: Next.js 16, React 19, TypeScript 5, Tailwind CSS 4
  • Backend: Next.js API routes + Supabase (Postgres)
  • Auth: NextAuth.js v4 with GitHub OAuth
  • Charts: Recharts
  • Animation: Framer Motion
  • Hosting: Vercel

API

POST /api/submit

Submit usage data. Authenticated submissions (with a NextAuth session cookie) are marked verified: true; otherwise the request must include an X-GitHub-User header.

Body: contents of cc.json (output of npx ccusage@latest daily --json).

Response:

{
  "success": true,
  "submissionId": "...",
  "message": "Successfully submitted data for username",
  "profileUrl": "https://viberank.app/profile/username"
}

POST /api/claim

Authenticated โ€” merges unverified CLI submissions into the caller's verified profile. Username is taken from the session, not the request body. Returns 401 without a session.

POST /api/admin/flag

Admin-only (allowlist in src/lib/admin.ts) โ€” flags or unflags a submission for review. Runs server-side with the service-role client; returns 403 for non-admins.

GET /api/health

Returns backend status:

{ "api": "ok", "backend": "supabase", "backendConnection": "ok", "timestamp": "..." }

Deployment

Designed to run on Vercel. Push to main to trigger an auto-deploy. The required production env vars are the same as .env.example; make sure SUPABASE_SERVICE_ROLE_KEY and the NEXT_PUBLIC_* Supabase vars are also listed in turbo.json's build.env allowlist so Turbo passes them through.

Deploy with Vercel

Contributing

See CONTRIBUTING.md.

License

MIT.

Acknowledgments

Links

Yorumlar (0)

Sonuc bulunamadi