Connects Claude to your local AI CLI usage analytics through stdio transport. Exposes tools for scanning local logs and SQLite databases from tools like Cursor and Cline, then returns token counts, cost breakdowns, and confidence labels as JSON. The get_agent_guide tool serves as the entry point with workflow instructions and privacy guardrails. Scan operations require explicit confirmation flags before touching files. You'd reach for this when building agents that need visibility into their own token usage patterns or when you want programmatic access to the same local-first analytics that TokenTrace's dashboard provides. All data stays on your machine, no telemetry or cloud accounts required.
Local-first AI CLI usage analytics. TokenTrace scans local CLI logs and local usage databases, normalizes token usage, estimates missing counts with confidence labels, and shows cost, model, project, session, repair, and evidence analytics in a browser dashboard.
TokenTrace is designed for local development machines first, with macOS-oriented defaults. It does not require a cloud account and does not send telemetry or logs anywhere.

Run without installing:
npx tokentrace
Or install globally:
npm install -g tokentrace
tokentrace
The command starts the local dashboard, chooses an available localhost port starting at 3030, opens your default browser, and keeps the server running until you press Ctrl+C.
CLI commands:
tokentrace # Start local dashboard
tokentrace serve # Start local dashboard
tokentrace serve --port 3210 --no-open
# Start on a fixed port without opening a browser
tokentrace agent --json # Print machine-readable agent discovery manifest
tokentrace capabilities --json
# Alias for agent discovery manifest
tokentrace roadmap --json
# Print release status handoff
tokentrace mcp # Start the local stdio MCP server
tokentrace scan # Scan local AI CLI usage logs
tokentrace doctor --json
# Inspect scan health and repair recommendations
tokentrace evidence --json
# Print metric evidence trails as JSON
tokentrace repair --json
# Print unknown-cost repair groups as JSON
tokentrace digest --json
# Print current-month local usage digest
tokentrace digest --since yesterday
# Print a scoped local usage digest
tokentrace report --markdown
# Print a deterministic Markdown report
tokentrace review --json
# Print post-session scan and review movement
tokentrace insights --json
# Print local recommendations as JSON
tokentrace status --json
# Print local usage status as JSON
tokentrace statusline claude
# Render a Claude Code status line from stdin
tokentrace statusline claude --compact
# Render a shorter Claude Code status line
tokentrace statusline setup claude
# Print Claude Code statusLine setup JSON
tokentrace watch --session
# Watch local usage status in a terminal split
tokentrace watch --session --compact
# Watch a compact live status line
tokentrace pricing refresh
# Refresh public model prices
tokentrace run <cmd> # Optional wrapper mode for command runtime diagnostics
tokentrace reset # Reset imported local data
tokentrace reset --yes # Reset without confirmation
tokentrace --help # Print help
tokentrace --version # Print version
Agents should start with the read-only discovery manifest:
tokentrace agent --json
The alias below returns the same manifest:
tokentrace capabilities --json
The manifest describes TokenTrace's local-first privacy model, safe JSON commands,
common workflows, Claude Code status-line setup, Codex sidecar fallback, and
guardrails such as never running tokentrace reset without explicit human
approval. The discovery command does not scan files, initialize the database, or
start the dashboard.
Package-level agent references are included for agents that inspect repository or npm package contents before invoking commands:
MCP-capable clients can start the local stdio server after installing or using the npm package:
tokentrace mcp
Registry name: io.github.abhiyoheswaran1/tokentrace.
First MCP call for agents: get_agent_guide.
Self-test the local MCP entrypoint without scanning files:
tokentrace mcp selftest --json
The MCP server exposes the same local-first surfaces as tools: capabilities,
status, Scan Health, evidence, repair queue, reports, and an explicit scan tool.
It does not scan files on startup, and its scan tool requires
confirmLocalScan=true before reading local usage files or writing the local
database.
When the local dashboard is already running, agents can fetch the same manifest over localhost:
curl http://127.0.0.1:3030/api/agent
curl http://127.0.0.1:3030/api/capabilities
The Local Sources & Trust release handoff is also machine-readable:
tokentrace roadmap --json
curl http://127.0.0.1:3030/api/roadmap
npm install
npm run db:migrate
npm run db:seed
npm run dev
Open http://localhost:3000.
Useful source commands:
npm run dev # Start the Next.js dev server
npm run build # Build the production app
npm run start # Serve the production build
npm run scan # Scan default and configured folders
npm run db:migrate # Create/update local SQLite tables
npm run db:seed # Seed editable provider/model prices
npm run screenshots:seed
# Seed a guarded public-safe screenshot database
npm run reset # Clear imported data and scan history
npm test # Run parser and cost tests
npm run verify # Run Vitest, TypeScript, and ESLint checks
npm run package:test # Verify, build, and dry-run the npm package
npm run package:inspect
# Check package transparency guardrails
npm run security:ioc
# Scan lockfiles, workflows, and local AI-tool hooks for supply-chain IOCs
npm run smoke:packed
# Inspect packed tarball and smoke test packed CLI
tokentrace roadmap --json
# Inspect roadmap handoff, action recipes, and release status
TokenTrace 0.12.0 bundles local source expansion, evidence exports, scan scheduling, scoped guardrails, parser profile preview, saved reports, and agent-readable release status.
New trust surfaces include:
The 0.12.0 dashboard also tightens the daily operator path: setup buttons now open the exact Settings section, scan results show what changed and where to go next, and Evidence explains when it is being opened as a contextual drill-down rather than a sidebar destination.
TokenTrace labels the trust level behind imported numbers:
The dashboard surfaces a Data Confidence score on Overview, Projects, Sessions, and Session Timeline pages. Scan Health also includes a supply-chain IOC check so package trust is visible in the product, not only in release scripts.
Public releases require maintainer approval. See docs/RELEASE_CHECKLIST.md before bumping versions, tagging, creating GitHub releases, or publishing npm.
In local development, the SQLite database defaults to .tokentrace/tokentrace.db. Override it with:
TOKENTRACE_DB=/absolute/path/tokentrace.db npm run dev
When installed from npm, TokenTrace stores runtime data outside the package folder:
~/Library/Application Support/TokenTrace/~/.local/share/tokentrace/%APPDATA%/TokenTrace/The CLI sets TOKENTRACE_DB and DATABASE_URL automatically. You can override the base directory with:
TOKENTRACE_HOME=/custom/path tokentrace
Default discovery checks these locations when present:
~/.claude/~/.config/claude/~/.codex/~/.config/codex/~/.openai/.claude, .codex, .openai, and .ai in the directory where tokentrace was invokedUse Settings in the dashboard to add custom folders, toggle raw message storage, and trigger scans. Use Scan Health, Discovery, Parsers, and Raw Data to inspect discovered files, parser decisions, warnings, failures, extracted metadata, and confidence levels.
Settings also supports optional local monthly usage guardrails. Set a cost limit, token limit, or both, and Overview will show month-to-date progress from imported local CLI usage.
Sessions includes built-in and local saved views for recurring review paths: unknown cost, high-cost sessions, Claude/Codex this month, estimated tokens, guardrail review, and parser review. Open a session's Timeline link to see ordered interactions, model changes, token spikes, cache activity, tool calls, parser confidence, and unknown-cost events. Raw prompts and message bodies stay hidden by default.
TokenTrace's primary ingestion architecture is direct local filesystem ingestion:
TokenTrace does not use MITM proxies, packet sniffing, browser extensions, traffic interception, or cloud telemetry.
Each adapter detects compatibility, parses partial metadata where possible, and fails safely when a file format is unsupported. Imported interactions carry token confidence metadata:
exacthigh-confidence estimatelow-confidence estimateunknownExact and estimated token values are never mixed silently.
Filesystem ingestion is the primary product path. Wrapper mode is secondary and optional:
tokentrace run claude-code
tokentrace run codex
tokentrace run npm test
Wrapper mode launches the subprocess, measures duration, counts stdout/stderr bytes, detects structured JSON output when available, and writes a local JSONL diagnostic log under the app-data directory. It does not intercept network traffic.
Claude Code can run a local status-line command at the bottom of its terminal UI. TokenTrace supports that path directly:
tokentrace statusline setup claude
Add the printed statusLine block to ~/.claude/settings.json. It points Claude Code at:
tokentrace statusline claude
Claude Code sends session JSON to the command on stdin. TokenTrace reads the transcript path, model, context usage, and session cost, then prints one compact local line:
TokenTrace | Opus | ctx 7% | cost $0.1235 | processed 3.3K tokens | cache 2.0K | priced
Do not set the Claude Code statusLine.command to plain tokentrace. Plain tokentrace starts the dashboard, while tokentrace statusline claude prints exactly one status-line response.
You can also inspect the same local status outside Claude Code:
tokentrace status --json
tokentrace watch --session
Daily reporting commands stay deterministic and local:
tokentrace digest --since last-scan
tokentrace digest --since 2026-05-01 --json
tokentrace report --markdown --since yesterday
tokentrace review --json
Codex CLI status-line integration is intentionally deferred until its status-line and hook contracts are stable enough to support without fragile terminal output parsing. Use tokentrace watch --session --compact in a terminal split or tmux pane as the current fallback. See docs/CODEX_INTEGRATION_SPIKE.md for the current decision.
Dashboard views:




CLI startup and help:

Local scan output:

Optional wrapper diagnostics:

TOKENTRACE_DISABLE_PRICE_REFRESH=1 to use only bundled prices.Stop the server with Ctrl+C in the terminal where tokentrace is running.
preinstall, install, or postinstall scripts..next/server route bundles.tokentrace serve prepares the local dashboard build in the user's TokenTrace app-data directory the first time it is needed.npm run package:inspect fails if generated Next.js build output appears in the published tarball.npm run security:ioc scans lockfiles, workflows, and local Claude/VS Code hook files for high-signal supply-chain compromise indicators.npm audit --audit-level=moderate.See SECURITY.md for the full security and privacy model.
Model prices change. TokenTrace ships with bundled public list prices and can refresh them from a public TokenTrace model-rate manifest. Manual edits made in Model Rates are preserved by future refreshes.
The bundled catalog includes common OpenAI, Anthropic, Google Gemini, xAI, DeepSeek, Mistral, and Cohere models, checked on May 8, 2026.
Seed sources:
Review and update rates in Model Rates before treating cost estimates as financial truth, especially if you use batch processing, priority/flex modes, data residency, long-context surcharges, subscriptions, or provider-specific discounts.
Refresh from the dashboard or from the CLI:
tokentrace pricing refresh
Cost is calculated per interaction:
inputTokens * inputPricePer1M / 1,000,000
+ outputTokens * outputPricePer1M / 1,000,000
+ cacheReadTokens * cachedInputPricePer1M / 1,000,000
+ cacheWriteTokens * cacheWritePricePer1M / 1,000,000
Cache read and cache write prices fall back to input price when a model has no separate cache rate. Anthropic seed rows use the 5-minute prompt cache write price by default. Rows are marked exact, estimated, or unknown depending on token availability and pricing configuration.
Adapters live under src/ingestion/adapters/:
claude-code.tscodex-cli.tsstructured-usage-log.tscursor-chat.tssqlite-history.tsgeneric-jsonl.tsgeneric-json.tsgeneric-log.tsFormats for Claude Code and Codex CLI can vary across versions, so these adapters are defensive and best-effort. Unknown files fail safely and show warnings in the Raw Data page.
TokenTrace keeps a visible support contract so daily scans are easier to trust:
| Surface | Support level | Notes |
|---|---|---|
| Claude Code project transcripts | Stable | Primary local CLI ingestion source. |
| Codex CLI session artifacts | Best-effort | Parsed defensively while CLI formats evolve. |
| Structured usage JSONL/NDJSON | Stable | Local wrapper and team logs with session, model, token, and source-cost fields. |
| Cursor-style chat exports | Best-effort | Imports local editor chat/composer exports without storing raw prompt text by default. |
| Usage-shaped SQLite histories | Best-effort | Reads local databases that expose session, model, token, or cost-like columns. |
| Generic JSONL, JSON, and text logs | Best-effort | Conservative usage-shaped records only. |
| Claude/Codex cache, plugin, todo, config, and support files | Ignored | Tracked as non-usage files, not parser failures. |
| Editable model pricing | Stable | Local pricing rows drive costs and unknown-cost repair queues. |
| Claude Code status line | Stable | Uses Claude Code's documented statusLine stdin contract. |
| Codex sticky status line | Best-effort fallback | Use tokentrace watch --session --compact in a split or tmux pane. |
| Desktop app scraping, browser extensions, proxying, packet capture, telemetry | Unsupported | Outside TokenTrace's product boundary. |
Example generic JSONL fixtures are in fixtures/generic-jsonl/.
The ingestion system is intentionally pluggable:
IngestionAdapter.src/ingestion/adapters/index.ts.tests/.Contributions are welcome. See CONTRIBUTING.md for local setup, parser guidelines, pricing update notes, and the release policy.
prebuild-install deprecation warning during installnpm warn deprecated prebuild-install@7.1.3: No longer maintained...
This is a transitive dependency of better-sqlite3 (the native SQLite driver TokenTrace uses to store local data). The warning is harmless — the install completes normally and TokenTrace runs as expected. It will go away once better-sqlite3 upstream migrates to a different prebuilt binary loader; there is nothing to fix on the TokenTrace side.
better-sqlite3If the prebuilt binary cannot be downloaded (offline machine, restrictive proxy, unsupported Node ABI), better-sqlite3 will try to compile from source and may fail. Workarounds:
>= 20.0.0; Node 20 or 22 LTS is recommended).build-essential and python3 on Linux, or the "Desktop development with C++" workload on Windows.github.com so the prebuilt binary can be fetched.EBADENGINE warningsThese appear when your local Node version is older than the engines field of a transitive dependency. They are warnings, not errors. Upgrading to the latest Node LTS resolves them.
Open source by Abhi Yoheswaran. Released under the MIT License. See LICENSE.
io.github.infoinlet-marketplace/mcp-observability
betterdb-inc/monitor
com.mcparmory/datadog
thotischner/observability-mcp
io.github.tantiope/datadog-mcp
io.github.us-all/datadog