Skip to main content

MCP server exposing the OptimNow Cloud FinOps skill (28 references) as queryable tools.

Project description

cloud-finops-mcp

MCP server exposing the OptimNow Cloud FinOps skill (28 reference files + 23 named-pattern playbooks) as queryable tools for any MCP-aware client (Claude Code, Cursor, Codex CLI, Windsurf, Aider, Cline, etc.).

The skill itself ships in canonical Claude Agent-Skills format and is also installable via the cross-tool installer (./install.sh) for direct context injection. This MCP server is the enrichment path: instead of loading the full skill into the prompt, the agent calls tools to discover, filter, and fetch only what it needs.

What the server exposes

Six tools, all read-only, split across two surfaces.

References — long-form provider and discipline files (~300-500 lines each):

Tool Purpose
list_references() List all 28 references with their FCP metadata.
get_reference(name) Fetch the full markdown body of one reference.
find_references(domain?, capability?, phase?, persona?, maturity?) Faceted query over the FinOps Capability/Phase frontmatter.

The reference faceted query supports any combination of:

  • domain - FinOps Framework domain (e.g. Optimize Usage & Cost, Quantify Business Value)
  • capability - FinOps capability (matches both primary and secondary)
  • phase - Inform, Optimize, Operate
  • persona - matches both primary and collaborating personas
  • maturity - Crawl, Walk, Run

Playbooks — small named-pattern runbooks (~80-130 lines each):

Tool Purpose
list_playbooks() List all 15 named-pattern playbooks with their metadata.
get_playbook(name) Fetch the full markdown body of one playbook.
find_playbooks(scope?, service?, waste_category?, confidence?) Faceted query over the playbook frontmatter.

The playbook faceted query supports:

  • scope - aws, azure, gcp, or cross-cloud
  • service - provider service (e.g. AWS NAT Gateway); exact-match
  • waste_category - orphaned, idle, overprovisioned, commitment-mismatch, schedule-blindness, modernization, ai-ml-inefficiency, egress
  • confidence - obvious, likely, possible (OptimNow three-tier model)

All filters across both surfaces AND together. String matches are case-insensitive and exact (no substring matching).

When to use which surface:

  • A playbook answers "how do I detect/fix this specific pattern?" (zombie NAT, snapshot sprawl, idle ELB). It includes problem statement, symptoms, a detection query (CUR / KQL / BigQuery SQL / CLI), fix steps, and the anti-pattern.
  • A reference answers anything broader: billing mechanics, commitment strategy, allocation methodology, persona-specific framings, or cross-pattern reasoning.

Install

pip install cloud-finops-mcp

Or run without installing via uv:

uvx cloud-finops-mcp

Configure your MCP client

After install, point your client at the cloud-finops-mcp console script.

Claude Code

Project-level (.mcp.json at the repo root) or user-level (~/.claude/mcp.json):

{
  "mcpServers": {
    "cloud-finops": {
      "command": "cloud-finops-mcp"
    }
  }
}

Restart Claude Code, then run /mcp to confirm the server is connected.

Cursor

~/.cursor/mcp.json:

{
  "mcpServers": {
    "cloud-finops": {
      "command": "cloud-finops-mcp"
    }
  }
}

Codex CLI

~/.codex/config.toml:

[mcp_servers.cloud-finops]
command = "cloud-finops-mcp"

Windsurf

~/.windsurf/mcp.json:

{
  "mcpServers": {
    "cloud-finops": {
      "command": "cloud-finops-mcp"
    }
  }
}

Any other MCP client

The server speaks MCP over stdio. Point any compatible client at cloud-finops-mcp (or python -m cloud_finops_mcp).

Example tool calls

Agent prompt: "Use the cloud-finops MCP to find references for the Optimize phase aimed at Engineering."

Calls find_references(phase="Optimize", persona="Engineering") and gets back the filtered subset (AWS, Azure, GCP, Bedrock, Databricks, etc.) without loading the full skill into the prompt.

Agent prompt: "Pull the AWS reference."

Calls get_reference(name="finops-aws") and gets back the full markdown body (~300 lines) instead of the entire 28-file knowledge base.

Agent prompt: "Show me the obvious-confidence AWS waste playbooks."

Calls find_playbooks(scope="aws", confidence="obvious") and gets back the list of high-signal AWS patterns (zombie NAT gateway, orphaned EBS volumes, etc.).

Agent prompt: "Walk me through the zombie NAT gateway pattern."

Calls get_playbook(name="aws-zombie-nat-gateway") and gets back the ~90-line runbook (problem, symptoms, detection query, fix, anti-pattern, see-also).

When to use this vs the installer

If you... Use
Want the skill loaded as static context for every chat The cross-tool installer (./install.sh)
Have a big-codebase session with limited context budget The MCP server (fetch on demand)
Want to filter references by FinOps domain/capability/phase/persona/maturity The MCP server (find_references)
Use a client that doesn't support MCP The cross-tool installer

The two paths are complementary. You can install both.

Development

git clone https://github.com/OptimNow/cloud-finops-skills.git
cd cloud-finops-skills/mcp_server
python scripts/sync_references.py        # populate src/cloud_finops_mcp/data/
pip install -e ".[dev]"
pytest

Versioning

The PyPI package version tracks the skill release tag. Tagging v1.13 on the parent repo triggers both the skill release zip and a new cloud-finops-mcp PyPI publish so the bundled references match what the rest of the repo ships.

License

CC BY-SA 4.0 - same as the parent skill. Credit OptimNow.

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

cloud_finops_mcp-1.22.2.tar.gz (335.3 kB view details)

Uploaded Source

Built Distribution

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

cloud_finops_mcp-1.22.2-py3-none-any.whl (383.2 kB view details)

Uploaded Python 3

File details

Details for the file cloud_finops_mcp-1.22.2.tar.gz.

File metadata

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

File hashes

Hashes for cloud_finops_mcp-1.22.2.tar.gz
Algorithm Hash digest
SHA256 2de873fcf89eb30eee27f33b2ae93b6b9803ffba863257f71d4be3f25e59d873
MD5 1f2ab4c8a28acb9fe2add478f7880d84
BLAKE2b-256 b329b9ec558f961d93ecb6f4ff118f785afb5ac8d316b0f304027765c71ec6ed

See more details on using hashes here.

Provenance

The following attestation bundles were made for cloud_finops_mcp-1.22.2.tar.gz:

Publisher: auto-tag-on-plugin-bump.yml on OptimNow/cloud-finops-skills

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

File details

Details for the file cloud_finops_mcp-1.22.2-py3-none-any.whl.

File metadata

File hashes

Hashes for cloud_finops_mcp-1.22.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c570839e378c197a3e82a70a8879a09cd4a85c001784ce45667400911547809a
MD5 e03b5d01d2f2a8f814901283ef73a342
BLAKE2b-256 abf0efd9c352925d7a8536fcab46570075deb23fbb3843abe0e29224396a17b6

See more details on using hashes here.

Provenance

The following attestation bundles were made for cloud_finops_mcp-1.22.2-py3-none-any.whl:

Publisher: auto-tag-on-plugin-bump.yml on OptimNow/cloud-finops-skills

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