Generate a local dashboard from Codex CLI / Claude Code / Cursor agent logs
Project description
Agent Usage Atlas
Turn your local AI coding agent logs into a rich, interactive analytics dashboard — zero dependencies, fully offline, one command.
一个从本地 AI 编程 Agent 日志生成可视化仪表盘的工具。支持 Codex CLI / Claude Code / Cursor 三大 Agent 栈,25+ 交互式图表,纯 Python 标准库实现。
Why Agent Usage Atlas?
You're burning tokens across multiple AI coding agents every day — but how much are you actually spending? Which model is the most cost-effective? When are you most productive? Are your caches saving you money?
Agent Usage Atlas reads your local log files (~/.codex/, ~/.claude/, ~/.cursor/), crunches the numbers, and generates a single self-contained HTML dashboard with 25+ interactive charts. No API keys, no cloud uploads, no dependencies beyond Python itself.
Supported Agents
| Agent | Token Tracking | Cost Estimation | Tool Call Tracking | Session Meta |
|---|---|---|---|---|
| Codex CLI | ✅ | ✅ | ✅ | ✅ |
| Claude Code | ✅ | ✅ | ✅ | ✅ |
| Cursor | Activity only | — | — | — |
Features
- 25+ interactive ECharts visualizations — cost trends, token breakdowns, Sankey flows, chord diagrams, heatmaps, radar charts, calendar views, burn rate projections
- Multi-agent unified view — Claude Code + Codex CLI + Cursor in one dashboard, with per-source drill-down
- Cost analytics — per-model, per-day, per-session cost estimation with 30-day burn rate forecasting
- Tool call intelligence — ranking, frequency density, bigram sequences, command success rates
- Cache efficiency tracking — hit rate, savings estimation, cache vs. uncached token split
- Working pattern heatmap — hour × weekday activity distribution to find your flow states
- Session deep-dive — duration histogram, complexity scatter, median session cost
- Live dashboard mode — SSE-powered auto-refresh server with date range tabs (All / 7 days / Today)
- Single self-contained HTML — one file, works offline, shareable, archivable
- Zero dependencies — pure Python standard library, no npm/Node/Rust/Docker required
- Fully local — all data stays on your machine, nothing sent anywhere
Screenshots
| Cost Analysis Daily cost trends, cost breakdown by token type, model cost ranking, Sankey flow |
Token & Activity Daily token trends, source radar, narrative summary, rose chart |
| Heatmap & Sessions Activity heatmap, source radar, token calendar, session bubble |
Tool Intelligence Tool ranking, bigram chord diagram, top commands, efficiency metrics |
Installation
pip (recommended)
pip install agent-usage-atlas
Homebrew
brew install heggria/tap/agent-usage-atlas
From source
git clone https://github.com/heggria/agent-usage-atlas.git
cd agent-usage-atlas
pip install .
Usage
# Default: last 30 days, output to ./reports/dashboard.html
python -m agent_usage_atlas
# Last 7 days
python -m agent_usage_atlas --days 7
# Custom start date
python -m agent_usage_atlas --since 2026-03-01
# Custom output path and auto-open in browser
python -m agent_usage_atlas --output /tmp/dashboard.html --open
# Start live dashboard with auto-refresh (SSE)
agent-usage-atlas --serve --interval 5 --open
# Live dashboard on custom host/port
agent-usage-atlas --serve --port 8765 --host 127.0.0.1 --interval 5
CLI Options
| Flag | Description | Default |
|---|---|---|
--days N |
Include the last N days | 30 |
--since YYYY-MM-DD |
Custom start date (overrides --days) |
— |
--output PATH |
Output HTML file path | ./reports/dashboard.html |
--open |
Open in browser after generation | off |
--serve |
Start local live dashboard server | off |
--host |
Host for --serve mode |
127.0.0.1 |
--port |
Port for --serve mode |
8765 |
--interval |
SSE refresh interval in seconds | 5 |
Live Mode Endpoints
| Endpoint | Description |
|---|---|
GET / |
Interactive HTML dashboard |
GET /api/dashboard?days=30 |
JSON payload |
GET /api/dashboard?since=2026-03-01 |
Custom date range |
GET /api/dashboard/stream?interval=5 |
SSE stream (auto-refresh) |
GET /health |
Health check |
How It Works
~/.codex/**/*.jsonl ─┐
~/.claude/**/*.jsonl ─┼─→ Parse → Aggregate → Render → dashboard.html
~/.cursor/**/*.jsonl ─┘ (parallel) (rollup) (ECharts)
- Parse — Reads JSONL log files and SQLite databases from each agent's local directory. Codex uses cumulative-delta token counting; Claude deduplicates by message ID; Cursor tracks activity counts.
- Aggregate — Computes source rollups, daily rollups, session rollups, tool bigrams, chord diagram data, Sankey flows, burn rate projections, heatmaps, and narrative text.
- Render — Injects the aggregated data into a self-contained HTML template with ECharts visualizations. In live mode, an SSE server pushes updates when log files change.
All data stays local — nothing is sent to any server.
Comparison with Alternatives
| Agent Usage Atlas | ccusage | splitrail | claudetop | Langfuse | Helicone | |
|---|---|---|---|---|---|---|
| Multi-agent | Claude + Codex + Cursor | Claude + Codex + others | 10+ agents | Claude only | Any (via SDK) | Any (via proxy) |
| Visualization | 25+ interactive ECharts | CLI tables | CLI + cloud | TUI (7 views) | Web dashboard | Web dashboard |
| Self-contained HTML | ✅ | — | — | — | — | — |
| Zero dependencies | ✅ Python stdlib | Node.js | Rust | Node.js | Docker + PG | Docker + infra |
| Fully local | ✅ | ✅ | Cloud optional | ✅ | Self-host | Self-host |
| Live dashboard | ✅ SSE | — | — | — | ✅ | ✅ |
| Tool-call analytics | Bigram, chord, Sankey | — | Basic | Basic | Via tracing | Via proxy |
| Cache efficiency | ✅ | — | — | Partial | — | — |
| Burn rate projection | ✅ | — | — | — | — | ✅ |
| Setup | python -m agent_usage_atlas |
npx ccusage |
Build from source | npx claudetop |
Deploy stack | Deploy proxy |
Key Differentiators
- Unified multi-agent dashboard — the only tool that tracks Claude Code + Codex CLI + Cursor simultaneously from local logs in a single view
- Richest visualization suite — 25+ chart types including Sankey flows, chord diagrams, tool-call bigrams, heatmaps, burn rate projections, calendar views
- True zero dependencies — Python stdlib only, no npm/Node/Rust/Docker/database required
- Single self-contained HTML — one file, works offline, email it to yourself, archive it
- Live SSE server — real-time auto-refresh with date range switching (All / 7 days / Today)
- Cache efficiency analytics — unique among local tools, tracks savings and hit rates
- Animated transitions — smooth number counter animations on live data refresh
Architecture
src/agent_usage_atlas/
├── cli.py # CLI entry point, build_dashboard_payload()
├── parsers.py # Codex / Claude / Cursor log parsers
├── models.py # UsageEvent, ToolCall, SessionMeta + pricing
├── aggregation.py # Full dashboard payload computation
├── template.py # Self-contained HTML/CSS/JS template
└── server.py # Live SSE server (stdlib http.server)
License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file agent_usage_atlas-0.0.1.tar.gz.
File metadata
- Download URL: agent_usage_atlas-0.0.1.tar.gz
- Upload date:
- Size: 49.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f6262832c63896b95daf1104c0c3d55fbb8d555261c97db39514c45d5146216e
|
|
| MD5 |
6640e677e1271e0fb276a4d4d2672420
|
|
| BLAKE2b-256 |
50221ba3b62a71ac04cb4d4adaf1423bf500eed7360159e20f9ac44719e5035b
|
Provenance
The following attestation bundles were made for agent_usage_atlas-0.0.1.tar.gz:
Publisher:
publish-pypi.yml on heggria/agent-usage-atlas
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agent_usage_atlas-0.0.1.tar.gz -
Subject digest:
f6262832c63896b95daf1104c0c3d55fbb8d555261c97db39514c45d5146216e - Sigstore transparency entry: 1114217643
- Sigstore integration time:
-
Permalink:
heggria/agent-usage-atlas@006c87599cac41121ee791d05f492d4e72e0e74f -
Branch / Tag:
refs/tags/v0.0.1 - Owner: https://github.com/heggria
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@006c87599cac41121ee791d05f492d4e72e0e74f -
Trigger Event:
push
-
Statement type:
File details
Details for the file agent_usage_atlas-0.0.1-py3-none-any.whl.
File metadata
- Download URL: agent_usage_atlas-0.0.1-py3-none-any.whl
- Upload date:
- Size: 48.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
40fe7cae81838a624fabeb69da9ed4355f484dd613e0d12d5adf66eea72a0d82
|
|
| MD5 |
8eebb053c5a4ebff0f1930d5d7c14aff
|
|
| BLAKE2b-256 |
d94659747b0374881628d09896c2a46b488df2b2c89a3096ae11275671d19487
|
Provenance
The following attestation bundles were made for agent_usage_atlas-0.0.1-py3-none-any.whl:
Publisher:
publish-pypi.yml on heggria/agent-usage-atlas
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agent_usage_atlas-0.0.1-py3-none-any.whl -
Subject digest:
40fe7cae81838a624fabeb69da9ed4355f484dd613e0d12d5adf66eea72a0d82 - Sigstore transparency entry: 1114217644
- Sigstore integration time:
-
Permalink:
heggria/agent-usage-atlas@006c87599cac41121ee791d05f492d4e72e0e74f -
Branch / Tag:
refs/tags/v0.0.1 - Owner: https://github.com/heggria
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@006c87599cac41121ee791d05f492d4e72e0e74f -
Trigger Event:
push
-
Statement type: