Open source MCP server for accurate public and effective cloud pricing (AWS, GCP, Azure)
Project description
OpenCloudCosts MCP
An open source MCP server that gives AI assistants accurate cloud pricing data for AWS, GCP, and Azure.
Supports both public list pricing (no credentials needed for AWS and Azure; GCP requires a free API key) and effective/bespoke pricing (post-discount: Reserved Instances, Savings Plans, CUDs, EDPs).
Key Use Cases
- "What is the on-demand price of an m5.xlarge in us-east-1 vs ap-southeast-2, and what's the % delta?"
- "Give me a TCO estimate for this architecture: 3x m5.xlarge + 1x 500GB gp3 EBS in us-east-1"
- "What's the cost per user if I run this stack for 50,000 MAUs?"
- "List all c6g instances in eu-west-1 with >= 8 vCPUs"
- "What's my effective hourly rate on m5.xlarge after Savings Plans?"
Tools (v0.8.0 — 15 tools)
Pricing
| Tool | Description |
|---|---|
get_price |
Unified pricing dispatcher — compute, storage, database, AI, networking, serverless, analytics, observability |
get_prices_batch |
Prices for multiple instance types in one call (concurrent) |
compare_prices |
Compare a spec across multiple regions with optional baseline deltas |
search_pricing |
Free-text search across the pricing catalog |
Discovery
| Tool | Description |
|---|---|
describe_catalog |
Full support matrix or targeted field guidance + copy-paste example_invocation for get_price |
list_regions |
All regions with friendly names |
list_instance_types |
Available instance types with vCPU/memory filters |
Region Analysis
| Tool | Description |
|---|---|
find_cheapest_region |
Cheapest region for any service spec, concurrently |
find_available_regions |
Every region where a service is available, sorted by price |
get_spot_history |
AWS spot price history and stability analysis (requires credentials) |
FinOps
| Tool | Description |
|---|---|
get_discount_summary |
Account-wide RI / Savings Plan / CUD utilisation (requires credentials) |
estimate_bom |
TCO for a multi-resource Bill of Materials |
estimate_unit_economics |
Cost per user/request/transaction |
Cache
| Tool | Description |
|---|---|
refresh_cache |
Invalidate pricing cache |
cache_stats |
Cache entry counts and DB size |
See docs/tools.md for full parameter reference and docs/finops-guide.md for usage examples.
Setup
Prerequisites
- uv installed (
curl -LsSf https://astral.sh/uv/install.sh | sh) - AWS credentials (optional — public pricing works without them)
Clone & configure
git clone https://github.com/x7even/cloudcostsmcp opencloudcosts
cd opencloudcosts
cp .env.example .env
# Edit .env if you want effective pricing / Cost Explorer
Test it works
uv run pytest
Run the server
uv run opencloudcosts
Run as HTTP server
HTTP transport enables shared/remote deployments — one server, many clients.
# Localhost only (default)
uv run opencloudcosts --transport http --port 8080
# Bind to all interfaces (e.g. for Docker or remote access)
uv run opencloudcosts --transport http --host 0.0.0.0 --port 8080
Environment variable equivalents: OCC_HTTP_HOST and OCC_HTTP_PORT.
Connect to Claude Code via .mcp.json:
{
"mcpServers": {
"cloudcost": {
"transport": "http",
"url": "http://localhost:8080/mcp/v1"
}
}
}
Docker
docker build -t opencloudcosts .
docker run -p 8080:8080 \
-e OCC_GCP_API_KEY=AIza... \
-v ~/.aws:/root/.aws:ro \
opencloudcosts
The container starts in HTTP transport mode by default (bound to 0.0.0.0:8080).
Pass cloud credentials via -e flags or mount your AWS credentials directory.
Connect to Claude Code
Add to your project's .mcp.json:
{
"mcpServers": {
"cloudcost": {
"command": "uv",
"args": ["run", "--directory", "/path/to/opencloudcosts", "opencloudcosts"],
"env": {
"AWS_PROFILE": "default",
"OCC_GCP_API_KEY": "AIza..."
}
}
}
}
Or to ~/.claude/settings.json for global access:
{
"mcpServers": {
"cloudcost": {
"command": "uv",
"args": ["run", "--directory", "/path/to/opencloudcosts", "opencloudcosts"]
}
}
}
Test with MCP Inspector
npx @modelcontextprotocol/inspector uv run --directory /path/to/opencloudcosts opencloudcosts
AWS Credentials
| Feature | Credentials needed |
|---|---|
| Public pricing (EC2, EBS, RDS list prices) | None |
| Effective pricing (RI / SP discounts) | AWS credentials + OCC_AWS_ENABLE_COST_EXPLORER=true |
Minimal IAM policy for public pricing:
{
"Effect": "Allow",
"Action": ["pricing:GetProducts", "pricing:DescribeServices", "pricing:GetAttributeValues"],
"Resource": "*"
}
Add these for effective pricing:
"ce:GetCostAndUsage", "savingsplans:DescribeSavingsPlans", "savingsplans:DescribeSavingsPlanRates"
Configuration
All settings via environment variables (prefix OCC_) or .env file:
| Variable | Default | Description |
|---|---|---|
OCC_CACHE_TTL_HOURS |
24 | Public price cache TTL |
OCC_AWS_ENABLE_COST_EXPLORER |
false | Enable effective pricing (costs $0.01/call) |
OCC_DEFAULT_REGIONS |
us-east-1,us-west-2 | Default regions |
AWS_PROFILE |
(default chain) | AWS credentials profile |
Caching
Prices are cached in SQLite at ~/.cache/opencloudcosts/pricing.db. Public list prices are cached for 24 hours — AWS pricing changes infrequently. Use the refresh_cache tool to force a refresh.
GCP Setup
Unlike AWS (which has public bulk pricing endpoints), GCP's pricing API always requires at least a free API key. No credit card or billing account is needed.
Option A — Free API key (recommended, 2 min setup):
- Go to console.cloud.google.com/apis/credentials
- Create a Project if you don't have one (free)
- Click Create Credentials → API key
- Set the key:
export OCC_GCP_API_KEY=AIza...
Or add OCC_GCP_API_KEY=AIza... to your .env file.
Option B — Application Default Credentials (if you already use gcloud):
gcloud auth application-default login
# or set GOOGLE_APPLICATION_CREDENTIALS=/path/to/service-account.json
GCP instance type format: {family}-{series}-{vcpus} e.g. n2-standard-4, e2-highmem-8, c2-standard-16
Azure Setup
Azure pricing is fully public — no credentials, API key, or subscription needed.
# No configuration needed — works out of the box
uv run opencloudcosts
Azure instance type format: ARM SKU names e.g. Standard_D4s_v3, Standard_E8s_v3, Standard_B2ms
Azure pricing terms: on_demand (default), reserved_1yr, reserved_3yr, spot
Azure regions: ARM region names e.g. eastus, westeurope, southeastasia (use list_regions for full list)
GCP pricing terms: on_demand (default), spot (preemptible), cud_1yr, cud_3yr
Security
OpenCloudCosts can access sensitive billing data when configured with cloud credentials (AWS Cost Explorer, GCP billing, Azure contract pricing). Follow these guidelines to keep that data safe.
Credential hygiene
- Use dedicated, least-privilege credentials — read-only access scoped to pricing and billing APIs only. Never use root, owner, or admin credentials.
- AWS: create an IAM user/role with only
ce:GetCostAndUsage,pricing:GetProducts, andsavingsplans:Describe*permissions. - Store credentials in
.env(see.env.example) and never commit that file to version control.
Transport security
- The default
stdiotransport is safe — the server runs as a local process with no network exposure. - If you use
--transport http, never expose it publicly without a reverse proxy and authentication in front of it. Treat it as an internal service.
MCP client trust
- Only add this server to MCP client configs you control.
- Avoid running it alongside untrusted third-party MCP servers — a malicious server can craft prompts that cause the LLM to call your billing tools and relay the results.
What this server can access With credentials configured: actual spend, contract/negotiated pricing, reservation and savings plan data. Understand this before granting access in shared or multi-user environments.
Phases
- Phase 1 ✅ AWS public pricing (EC2, EBS, list instances)
- Phase 2 ✅ AWS effective pricing (Cost Explorer, Savings Plans, Reserved Instances)
- Phase 3 ✅ GCP public pricing (Compute Engine families, Persistent Disk, CUDs)
- Phase 4 ✅ Azure public pricing (Retail Prices API, no credentials)
- Phase 4 ✅ Streamable-HTTP transport (
--transport http), Dockerfile - Phase 4 ✅ Spot price history tool (
get_spot_history), GCP Windows pricing - Phase 5 ✅ GCP managed services — GKE, Memorystore, BigQuery, Vertex AI, Gemini
- Phase 5 ✅ GCP networking — Cloud LB, CDN, NAT, Cloud Armor, Cloud Monitoring
- Phase 5 ✅ GCP Cloud SQL; Azure reserved pricing
- v0.8.0 ✅ Consolidated to 15-tool surface; unified
get_price(spec)dispatcher;describe_catalogdiscovery; 123/123 (100%) harness pass rate - Next: GCP effective pricing (BigQuery billing export)
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 opencloudcosts-0.8.0.tar.gz.
File metadata
- Download URL: opencloudcosts-0.8.0.tar.gz
- Upload date:
- Size: 241.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d268bd62a8c404ae631bf5bba13f662e81246cf03dda0c2bc461adba94beb90a
|
|
| MD5 |
c19f1f43a5179db6fc0bf47a3b9bd07d
|
|
| BLAKE2b-256 |
c2090f46b3f280292678f8816a40c49186b9990110759d228ff697c64d0049d0
|
Provenance
The following attestation bundles were made for opencloudcosts-0.8.0.tar.gz:
Publisher:
workflow.yml on x7even/cloudcostsmcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
opencloudcosts-0.8.0.tar.gz -
Subject digest:
d268bd62a8c404ae631bf5bba13f662e81246cf03dda0c2bc461adba94beb90a - Sigstore transparency entry: 1356236803
- Sigstore integration time:
-
Permalink:
x7even/cloudcostsmcp@40f56e8c3a347daee1664de5f3c774269ccca6a0 -
Branch / Tag:
refs/tags/v0.8.0 - Owner: https://github.com/x7even
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
workflow.yml@40f56e8c3a347daee1664de5f3c774269ccca6a0 -
Trigger Event:
push
-
Statement type:
File details
Details for the file opencloudcosts-0.8.0-py3-none-any.whl.
File metadata
- Download URL: opencloudcosts-0.8.0-py3-none-any.whl
- Upload date:
- Size: 87.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
88f31d0908bda0eded9446efa118b9764d3dc628af1800388773ba9ea3e88593
|
|
| MD5 |
5fda66b62022475bead86508dc53ce74
|
|
| BLAKE2b-256 |
81efe48f6408796d4acc8f2e0f6f41023ae839925494164bfb5773909c8cf7a8
|
Provenance
The following attestation bundles were made for opencloudcosts-0.8.0-py3-none-any.whl:
Publisher:
workflow.yml on x7even/cloudcostsmcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
opencloudcosts-0.8.0-py3-none-any.whl -
Subject digest:
88f31d0908bda0eded9446efa118b9764d3dc628af1800388773ba9ea3e88593 - Sigstore transparency entry: 1356236864
- Sigstore integration time:
-
Permalink:
x7even/cloudcostsmcp@40f56e8c3a347daee1664de5f3c774269ccca6a0 -
Branch / Tag:
refs/tags/v0.8.0 - Owner: https://github.com/x7even
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
workflow.yml@40f56e8c3a347daee1664de5f3c774269ccca6a0 -
Trigger Event:
push
-
Statement type: