Local-first usage analytics for Codex, Claude Code, and Cursor.
AI Coding Usage Tracker reads local AI coding data and generates a private
dashboard for token usage, app/source totals, estimated Codex credits,
estimated USD, project breakdowns, terminal reports, and optional WakaTime
ai coding time.
AI coding tools can burn through tokens, but it is hard to answer basic questions:
- Which project used the most tokens?
- Which thread was the most expensive?
- How much active AI coding time did I spend today?
- How much of my input was cached?
- Can my Codex app activity show up in WakaTime?
This tool gives you those answers locally, without uploading Codex transcripts to another service.
- Reads local Codex app rollout logs from
~/.codex - Reads Claude Code project transcripts from
~/.claude/projects - Reads Cursor AI edit activity from
~/.cursor/ai-tracking/ai-code-tracking.db - Generates
HTML,CSV, andJSONreports - Serves a live local web dashboard with auto-refresh on
127.0.0.1 - Shows trend bars, provider comparison tabs, budget signals, and connector status
- Prints
daily,weekly,monthly,session,project,model, andsourceterminal reports - Estimates Codex credits from input, cached input, and output tokens
- Shows estimated USD for Codex and Claude Code where local token logs and known rates exist
- Checks optional official billing connectors without printing configured keys
- Includes
doctoranddemocommands for first-run confidence - Supports date filters with
--days,--since,--until, and--timezone - Supports share-safe output with
--redactand--hash-projects - Sends optional WakaTime
ai codingheartbeats - Works without an OpenAI API key
Install from PyPI with pipx:
pipx install codex-usage-tracker
ai-coding-usage-tracker demoOr install with pip:
python -m pip install codex-usage-tracker
ai-coding-usage-tracker demoThe PyPI package is still named codex-usage-tracker for compatibility. New
installs expose ai-coding-usage-tracker; the legacy codex-usage-tracker
command remains available.
For local development, clone the repo:
git clone https://github.com/SuvenSeo/ai-coding-usage-tracker.git
cd ai-coding-usage-trackerRun directly with Python:
python codex_app_tracker.py reportOr install the CLI locally:
pip install -e .
ai-coding-usage-tracker reportWindows users can also download AICodingUsageTracker.exe from the
latest release.
The release includes a SHA256 checksum file.
Check your machine:
ai-coding-usage-tracker doctorGenerate the full local dashboard:
ai-coding-usage-tracker reportInclude Codex, Claude Code, and Cursor in one report:
ai-coding-usage-tracker --sources all reportOpen:
out/dashboard.html
Serve a live local web dashboard:
ai-coding-usage-tracker --sources all --days 14 serveBy default this opens http://127.0.0.1:8765/, reloads the page every 10
seconds, and keeps all data local. Use serve --port 0 --no-open when you want
an auto-selected port without launching a browser.
Open the live native desktop dashboard:
ai-coding-usage-tracker --sources all --days 7 --timezone Asia/Colombo guiThe GUI uses Python's built-in Tkinter toolkit, polls selected local sources every 10
seconds by default, opens in dark mode by default, includes a button to generate
the normal out/ HTML/CSV/JSON reports, and includes an Open live web
dashboard button for the smoother browser UI. Change the interval with:
ai-coding-usage-tracker gui --refresh-seconds 5Build a double-clickable Windows EXE:
python -m pip install -e ".[build]"
.\scripts\build_windows_exe.ps1The generated app is written to dist\AICodingUsageTracker.exe. Double-clicking it
opens the live GUI with Codex, Claude Code, and Cursor selected. It reads only
local data folders on your machine.
Install it as a normal user-level Windows app:
.\scripts\install_windows_app.ps1That copies the EXE to %LOCALAPPDATA%\Programs\AICodingUsageTracker and creates
Start Menu plus Desktop shortcuts. Remove it with:
.\scripts\uninstall_windows_app.ps1Try a safe public demo:
ai-coding-usage-tracker demoThat writes synthetic reports to out/demo/.
Global scope and privacy flags go before the command:
ai-coding-usage-tracker --days 7 daily
ai-coding-usage-tracker --since 2026-05-01 --until 2026-05-24 weekly
ai-coding-usage-tracker --timezone Asia/Colombo monthly
ai-coding-usage-tracker --sources all source
ai-coding-usage-tracker session --limit 10 --compact
ai-coding-usage-tracker project --format json
ai-coding-usage-tracker model --format csvCreate a share-safe report:
ai-coding-usage-tracker --sources all --redact --hash-projects reportSource selection is opt-in. The default is --sources codex; use
--sources claude, --sources cursor, or a comma-separated list such as
--sources codex,claude.
Audit every local and official source the tracker knows about:
ai-coding-usage-tracker --sources all source-auditThe audit writes out/source_audit.json and out/source_audit.md. It separates
exact local metrics from estimates and blocked sources. For example, Cursor's
legacy state.vscdb daily stats can show historical suggested/accepted line
counts, but not exact Cursor tokens, credits, or spend. Vendor admin APIs can
provide deeper billing detail only when the matching admin key is configured.
Check optional official billing connector status:
ai-coding-usage-tracker billingSet provider admin keys only when you want official account-side checks, then run an explicit fetch:
ai-coding-usage-tracker billing --fetch --format jsonSupported environment variable names are OPENAI_ADMIN_KEY,
ANTHROPIC_ADMIN_KEY, and CURSOR_ADMIN_API_KEY. Keys are never printed.
Add dashboard budget signals with global flags before the command:
ai-coding-usage-tracker --sources all --daily-token-budget 250000 --daily-usd-budget 5 --monthly-usd-budget 100 reportWakaTime sync is optional. It requires wakatime-cli and a normal ~/.wakatime.cfg file.
Generate reports and sync recent Codex activity:
ai-coding-usage-tracker run --sync-wakatimeThe tracker sends conservative heartbeats with:
- category:
ai coding - entity type:
app - project name/folder
- timestamp
It does not send prompts, responses, transcripts, or token totals to WakaTime. WakaTime sync currently uses Codex records only; Claude Code and Cursor are included in reports but not synced as WakaTime heartbeats.
On Windows, you can install a scheduled task:
.\install_scheduled_task.ps1Remove it:
.\uninstall_scheduled_task.ps1By default, reports are written to out/:
dashboard.htmlcodex_usage_summary.jsonthreads.csvdaily.csvsources.csvprojects.csvmodels.csv
Do not commit generated reports. They can include private local paths, project names, thread titles, and usage details unless you use privacy flags.
The tracker reports local token counts where app logs provide them.
Cost estimates are not an invoice:
estimated_codex_creditsuses OpenAI's current Codex token-based rate card for Codex records.estimated_api_usd_equivuses public OpenAI API standard short-context prices for Codex and Anthropic token prices for Claude Code when known local model rates exist.- Cursor local AI tracking exposes AI edit activity, request counts, models, timestamps, and active time, but not exact token totals.
- The included rates were verified against official OpenAI and Anthropic docs on 2026-05-31.
- Real billing/credit balance, fast-mode uplifts, taxes, and any workspace exceptions should be checked with the vendor.
Pricing can change. The current source pages are OpenAI's Codex rate card, OpenAI API pricing, Anthropic Claude pricing, and Cursor pricing. Review and update MODEL_RATES in codex_app_tracker.py when vendor rates change.
This is a local parser. Depending on --sources, it reads from ~/.codex,
~/.claude/projects, and/or ~/.cursor/ai-tracking. It writes local reports.
Use --redact to hide thread titles, local folders, and log paths. Use --hash-projects to replace project names with stable anonymous labels.
See docs/PRIVACY.md before sharing dashboards or CSV files.
| Tool | Best For | Difference |
|---|---|---|
| AI Coding Usage Tracker | AI coding users who want local Codex, Claude Code, and Cursor visibility | Dependency-light, private generated dashboard with Codex token/cost depth |
| ccusage | Multi-agent terminal usage reports | Broader agent support and mature CLI reporting |
| agentsview | Local multi-agent session intelligence | Richer local web app and session indexing |
| codex-wakatime | Codex CLI WakaTime hook | Focused time tracking, not token/cost dashboards |
The near-term goal is to keep Codex as the deepest parser while adding honest local visibility for adjacent AI coding tools.
Run checks:
python -m py_compile codex_app_tracker.py
python -m unittest discover -s tests -vBuild package artifacts:
python -m pip install build
python -m buildNew contributors can start with good first issues or the current roadmap. See CONTRIBUTING.md for the privacy rules and PR checklist.
See docs/ROADMAP.md.
Built by SuvenSeo for developers who want local visibility into AI coding usage.
Early alpha. Codex, Claude Code, and Cursor local storage formats may change, so
parser compatibility can break. The v0.2.0 GitHub release adds multi-source
reports. The Python package is published on
PyPI and can be installed with
pipx install codex-usage-tracker or python -m pip install codex-usage-tracker.
Issues and PRs are welcome.