enforces budget
Project description
coreason-budget (The Controller)
Mission: Enforce Financial Operations (FinOps) guardrails for LLM usage.
This package acts as the "Controller," treating Compute (Tokens) as Cash. It enforces daily quotas and rejects requests immediately if limits are exceeded.
Features
- Atomic Counting: Uses Redis for high-speed, atomic, thread-safe counters.
- Hierarchical Quotas: Enforces limits at User, Project, and Global scopes.
- Fail Closed: Security-first design; if the budget cannot be checked, the transaction is blocked.
- Manual Integration: Designed to be integrated into your middleware with a "Check-then-Charge" lifecycle.
- Modes of Operation: Can be used as a python library or a standalone microservice.
Installation
pip install coreason-budget
or with Poetry:
poetry add coreason-budget
Note: For Server Mode, you need the extra dependencies:
pip install coreason-budget[server](if available) or simply installfastapianduvicorn.
Usage
The package can be used in two modes: Library Mode (Direct Python Import) or Server Mode (HTTP Microservice).
1. Server Mode (FinOps Microservice)
Deploy coreason-budget as a centralized service that other agents (Cortex, Sentinel) query via HTTP.
Docker Deployment
The easiest way to run the server is via Docker.
docker build -t coreason-budget .
docker run -p 8000:8000 \
-e COREASON_BUDGET_REDIS_URL="redis://host.docker.internal:6379" \
coreason-budget
API Endpoints
POST /check Verify if a user has enough budget.
// Request
{
"user_id": "user_123",
"estimated_cost": 0.05
}
// Response (200 OK)
{ "status": "allowed" }
// Response (429 Too Many Requests)
{ "detail": "Budget exceeded for User user_123..." }
POST /spend Record actual usage after an operation.
// Request
{
"user_id": "user_123",
"cost": 0.045,
"project_id": "proj_alpha",
"model": "gpt-4"
}
// Response (200 OK)
{ "status": "recorded" }
GET /health Check service health and Redis connectivity.
{ "status": "healthy", "redis": "connected" }
2. Library Mode
The package exposes a BudgetManager that you integrate directly into your Python application.
2.1. Configuration
The system is configured via BudgetConfig or environment variables (COREASON_BUDGET_*).
from coreason_budget import BudgetManager, BudgetConfig, BudgetExceededError
# Initialize with Redis URL and Limits
config = BudgetConfig(
redis_url="redis://localhost:6379",
daily_user_limit_usd=10.0,
daily_project_limit_usd=500.0,
daily_global_limit_usd=5000.0
)
budget = BudgetManager(config)
2.2. The Check-Charge Lifecycle
The middleware operates in two phases: Pre-Flight Check and Post-Flight Charge.
# --- Phase 1: Pre-Flight Check ---
# Before calling the LLM, verify budget availability.
user_id = "user_123"
try:
# Check if user can spend (optionally pass estimated_cost)
await budget.check_availability(user_id)
except BudgetExceededError:
# Block the request immediately
return Response("Daily Limit Reached", status_code=429)
# --- Execute LLM ---
# Perform the inference call
response = await llm.generate(...)
# --- Phase 2: Post-Flight Charge ---
# Calculate precise cost based on provider metadata
cost = budget.pricing.calculate(
model="gpt-4",
input_tokens=response.usage.prompt_tokens,
output_tokens=response.usage.completion_tokens
)
# Atomically record the spend
await budget.record_spend(
user_id=user_id,
cost=cost,
project_id="project_launch_sim", # Optional
model="gpt-4" # Optional, for logging
)
print(f"Transaction Cost: ${cost}")
Configuration Options
| Environment Variable | Description | Default |
|---|---|---|
COREASON_BUDGET_REDIS_URL |
Redis Connection URL | Required |
COREASON_BUDGET_DAILY_USER_LIMIT_USD |
Daily limit per user ($) | 10.0 |
COREASON_BUDGET_DAILY_PROJECT_LIMIT_USD |
Daily limit per project ($) | 500.0 |
COREASON_BUDGET_DAILY_GLOBAL_LIMIT_USD |
Global hard limit ($) | 5000.0 |
COREASON_BUDGET_LOG_PATH |
Path to log file | logs/app.log |
Architecture
- RedisLedger: Manages atomic increments and key expiration (UTC Midnight).
- BudgetGuard: Enforces limits and raises
BudgetExceededError. - PricingEngine: Calculates costs using
liteLLMor configured overrides.
Development
-
Install Dependencies:
poetry install -
Run Tests:
poetry run pytest
-
Code Quality:
poetry run pre-commit run --all-files
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
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 coreason_budget-0.4.1.tar.gz.
File metadata
- Download URL: coreason_budget-0.4.1.tar.gz
- Upload date:
- Size: 13.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
960c7e1988366f9d9b8d1a98242d5d727479acfdd35ce446ae97c278f72b1c29
|
|
| MD5 |
961602be615a1e99bdaef46402eacf1e
|
|
| BLAKE2b-256 |
9329e5d236aa617092d7cafdb168afafd2dd9202c883d6da1fc83c5896deda6a
|
Provenance
The following attestation bundles were made for coreason_budget-0.4.1.tar.gz:
Publisher:
publish.yml on CoReason-AI/coreason-budget
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
coreason_budget-0.4.1.tar.gz -
Subject digest:
960c7e1988366f9d9b8d1a98242d5d727479acfdd35ce446ae97c278f72b1c29 - Sigstore transparency entry: 867363485
- Sigstore integration time:
-
Permalink:
CoReason-AI/coreason-budget@c180b4427911fabc51211532db4bde2c3872840b -
Branch / Tag:
refs/tags/v0.4.1 - Owner: https://github.com/CoReason-AI
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@c180b4427911fabc51211532db4bde2c3872840b -
Trigger Event:
release
-
Statement type:
File details
Details for the file coreason_budget-0.4.1-py3-none-any.whl.
File metadata
- Download URL: coreason_budget-0.4.1-py3-none-any.whl
- Upload date:
- Size: 16.4 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 |
6e00af7b39d173516acfa6dd78635bca115e77a464e3c3b1f3c863d4f4b81e55
|
|
| MD5 |
ed931b1f7870169fa7156986cfaabd20
|
|
| BLAKE2b-256 |
cc165d5b8b174f808b12a230df3d6c08243bb4b41fb7056690f94294223fa5bf
|
Provenance
The following attestation bundles were made for coreason_budget-0.4.1-py3-none-any.whl:
Publisher:
publish.yml on CoReason-AI/coreason-budget
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
coreason_budget-0.4.1-py3-none-any.whl -
Subject digest:
6e00af7b39d173516acfa6dd78635bca115e77a464e3c3b1f3c863d4f4b81e55 - Sigstore transparency entry: 867363488
- Sigstore integration time:
-
Permalink:
CoReason-AI/coreason-budget@c180b4427911fabc51211532db4bde2c3872840b -
Branch / Tag:
refs/tags/v0.4.1 - Owner: https://github.com/CoReason-AI
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@c180b4427911fabc51211532db4bde2c3872840b -
Trigger Event:
release
-
Statement type: