Skip to main content

The open-source FinOps proxy for AI spend — track cost by feature, team, and customer across OpenAI, Anthropic, Google, Azure, Bedrock, and Groq.

Project description

BurnLens — The open-source FinOps proxy for AI spend

Track every dollar by feature, team, and customer across OpenAI, Anthropic, Google, Azure, AWS Bedrock, and Groq. Hard-cap budgets before the API call — not after the bill arrives.

PyPI Python 3.10+ License: Apache 2.0 GitHub stars

pip install burnlens
burnlens start
# Dashboard at http://127.0.0.1:8420/ui

The Problem

Bills tell you the model, not the why. Your invoice says gpt-4o: $4,287. It doesn't say which feature, which team, or which customer burned it. By the time you trace the spike, it's already on next month's card.

Alerts arrive after the damage. A bad deploy, a runaway agent, or one abusive customer can trigger thousands of API calls before any dashboard turns red. You find out when you open the bill — or when your CEO does.

Every provider is a different silo. OpenAI's usage page. Anthropic's console. Azure Cost Management. Bedrock CloudWatch. No unified view, no way to ask "which feature is our biggest AI spend across all providers."


How It Works

  1. Drop-in proxy. Point your SDK's BASE_URL at localhost:8420. Existing code works unchanged. Less than 20ms overhead. Full streaming passthrough. No changes to your application logic.

  2. Tag what matters. Three request headers (X-BurnLens-Tag-Feature, X-BurnLens-Tag-Team, X-BurnLens-Tag-Customer) attribute any call to any dimension. Tags are stripped before reaching the AI provider — they never leave your machine.

  3. Cap before you call. Register an API key with a daily dollar limit. At 100%, BurnLens returns 429 before the upstream request is made — not after the bill arrives. 50% and 80% thresholds fire Slack or email alerts.

  4. One dashboard, every provider. OpenAI, Anthropic, Google, Azure OpenAI, AWS Bedrock, and Groq spend in one unified view. Model breakdowns, waste detection, and budget tracking — reconciled to the provider bill.


Code Example

import os, openai

os.environ["OPENAI_BASE_URL"] = "http://127.0.0.1:8420/proxy/openai"

client = openai.OpenAI(default_headers={
    "X-BurnLens-Tag-Feature": "chat",
    "X-BurnLens-Tag-Team": "backend",
    "X-BurnLens-Tag-Customer": "acme-corp",
})

Tags are stripped before the request reaches OpenAI. They never appear in any API payload.


Use Cases

Coding agents. Cursor, Claude Code, Cline, Windsurf — attribute cost per PR, repo, or developer. Set a hard daily cap per API key so one runaway agent can't blow the team's monthly budget overnight.

Customer-facing AI. Tag each request with a customer ID. See which customers drive the most cost. Enforce per-customer monthly spend limits with automatic 429 enforcement before the call is forwarded.

RAG and agents. Tag retrieval calls, tool calls, and generation separately. See whether your vector search or synthesis step is the cost driver — and whether it justifies the output quality.

Internal tools. Set per-team monthly budgets, get Slack alerts at 80% and 100%, and export monthly reports that reconcile line-by-line to the actual provider bill.


Supported Providers

Provider Status Notes
OpenAI Stable All models, streaming, reasoning tokens
Anthropic Stable All models, streaming, prompt caching tokens
Google Stable Gemini 1.5/2.0, requires patch_google()
Azure OpenAI Roadmap v0.3
AWS Bedrock Roadmap v0.3
Groq Roadmap v0.2
Together Roadmap v0.2
Mistral Roadmap v0.2

Why BurnLens

BurnLens Helicone / Langfuse Vantage / CloudZero
Open source Partial
Local-first (prompts stay local)
Hard caps before API call
Per-customer attribution
Multi-cloud (Azure / AWS / GCP) Partial

Dashboard

BurnLens dashboard — LLM cost tracking by model, feature, team, and customer


Configuration

Zero config required — sensible defaults out of the box. Optional burnlens.yaml:

budget_limit_usd: 500.00
budgets:
  teams:
    backend: 200.00
    research: 100.00
  customers:
    acme-corp: 50.00
alerts:
  slack_webhook: https://hooks.slack.com/...

CLI

burnlens start                  # proxy + dashboard on :8420
burnlens top                    # live cost by model (htop-style)
burnlens report                 # weekly cost summary
burnlens analyze                # waste detection report
burnlens export                 # CSV of last 7 days
burnlens run -- python app.py   # auto-tag a process with repo / dev / pr / branch
burnlens key register <name>    # label an API key + set a daily cap
burnlens key list               # list registered keys with caps
burnlens keys                   # today's spend per registered key
burnlens scan claude            # import Claude Code session costs from disk
burnlens scan cursor            # import Cursor IDE session costs from disk
burnlens scan codex             # import OpenAI Codex session costs from disk
burnlens scan gemini            # import Gemini CLI session costs from disk

Contributing

Issues and PRs welcome. See CONTRIBUTING.md.

git clone https://github.com/sairintechnologycom/burnlens
cd burnlens
pip install -e ".[dev]"
pytest

License

Apache License 2.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

burnlens-1.3.0.tar.gz (147.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

burnlens-1.3.0-py3-none-any.whl (177.3 kB view details)

Uploaded Python 3

File details

Details for the file burnlens-1.3.0.tar.gz.

File metadata

  • Download URL: burnlens-1.3.0.tar.gz
  • Upload date:
  • Size: 147.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for burnlens-1.3.0.tar.gz
Algorithm Hash digest
SHA256 4c8bb6e4f2feb8e4832c95faf29db4080e16364d88c3d1085ac27b8963eab811
MD5 50237d8944ade22a7b98cbb669433fdc
BLAKE2b-256 8ef561621906b20414bfca2fbbb40821cab22480a533f54c025026de3a3d5623

See more details on using hashes here.

Provenance

The following attestation bundles were made for burnlens-1.3.0.tar.gz:

Publisher: publish.yml on sairintechnologycom/burnlens

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file burnlens-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: burnlens-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 177.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for burnlens-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2b748a7a4ae52a45d97c80e1697452ca9e2a7f53f263758a9c5f1e2f67f7d4b4
MD5 ea00e64bf158549be16d4a02782ce054
BLAKE2b-256 30443c13eb9524c43e777f6df6f6b4bd6d38e6523380bacc8e51569d0731a512

See more details on using hashes here.

Provenance

The following attestation bundles were made for burnlens-1.3.0-py3-none-any.whl:

Publisher: publish.yml on sairintechnologycom/burnlens

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page