aws-cost-explorer

aws-cost-explorer

Enables AI assistants to query and analyze AWS costs and usage via the Cost Explorer API.

Category
Visit Server

README

AWS Cost Explorer MCP Server

A Python-based Model Context Protocol (MCP) server that provides tools for accessing AWS Cost Explorer data. This server enables AI assistants like Claude to query and analyze your AWS costs and usage.

Features

  • Cost and Usage Analysis: Get detailed cost breakdowns by time period
  • Dimension Values: Discover available services, regions, accounts, etc.
  • Flexible Filtering: Filter costs by various dimensions
  • Multiple Metrics: Support for different cost metrics (UnblendedCost, AmortizedCost, etc.)
  • Secure Authentication: Uses AWS profiles or environment variables

Prerequisites

  • Python 3.8 or higher
  • AWS account with Cost Explorer access
  • AWS credentials configured (via AWS CLI, environment variables, or IAM roles)

Installation

  1. Clone or download this repository

  2. Install dependencies:

    pip install -r requirements.txt
    
  3. Configure AWS credentials (choose one method):

    Option A: AWS CLI Profile

    aws configure --profile your-profile-name
    

    Option B: Environment Variables

    export AWS_ACCESS_KEY_ID=your_access_key
    export AWS_SECRET_ACCESS_KEY=your_secret_key
    export AWS_DEFAULT_REGION=us-east-1
    

    Option C: Use .env file

    cp .env.example .env
    # Edit .env with your credentials
    

Usage

Running the Server

python aws_mcp/main.py

The server will start and listen for MCP connections on stdio.

Connecting with Claude Desktop

Add the following to your Claude Desktop configuration file:

macOS: ~/Library/Application Support/Claude/claude_desktop_config.json Windows: %APPDATA%\Claude\claude_desktop_config.json

{
  "mcpServers": {
    "aws-cost-explorer": {
			"command": "uv",
			"args": [
				"--directory",
				"/absolute/path/to/aws_mcp",
				"run",
				"aws-cost-explorer",
				"--profile",
				"dev"
			],
    }
  }
}

Available Tools

1. get_cost_and_usage

Get AWS costs for a specified time period with optional grouping and filtering.

Parameters:

  • start (optional): Start date (YYYY-MM-DD, inclusive)
  • end (optional): End date (YYYY-MM-DD, exclusive)
  • granularity: Time granularity - "DAILY" or "MONTHLY" (default: "MONTHLY")
  • group_by (optional): List of dimensions to group by (max 2)
  • metrics (optional): List of cost metrics (default: ["UnblendedCost"])
  • filter_config (optional): Filter by dimension and values
  • max_results: Maximum results (1-100, default: 100)
  • profile (optional): AWS profile name

Example Usage:

"What were my AWS costs last month by service?"
"Show me daily costs for the last 30 days"
"Get costs by region for this year"

2. get_dimension_values

Get available values for a specific Cost Explorer dimension (services, regions, etc.).

Parameters:

  • dimension: The dimension name (SERVICE, REGION, LINKED_ACCOUNT, etc.)
  • time_period_start (optional): Start date for search
  • time_period_end (optional): End date for search
  • search_string (optional): Filter dimension values
  • max_results: Maximum results (1-1000, default: 50)
  • profile (optional): AWS profile name

Example Usage:

"What AWS services am I using?"
"Show me all available regions in my account"
"List my linked accounts"

Supported Dimensions

  • SERVICE
  • LINKED_ACCOUNT
  • REGION
  • USAGE_TYPE
  • OPERATION
  • INSTANCE_TYPE
  • PURCHASE_TYPE
  • RECORD_TYPE

Supported Metrics

  • UnblendedCost
  • AmortizedCost
  • NetAmortizedCost
  • NetUnblendedCost
  • NormalizedUsageAmount
  • UsageQuantity
  • BlendedCost

Security Considerations

  • This server requires read access to AWS Cost Explorer
  • Use least-privilege IAM policies
  • Store credentials securely using AWS best practices
  • Consider using IAM roles for EC2/Lambda deployments

Required AWS Permissions

Your AWS credentials need the following permissions:

{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Effect": "Allow",
      "Action": [
        "ce:GetCostAndUsage",
        "ce:GetDimensionValues"
      ],
      "Resource": "*"
    }
  ]
}

Troubleshooting

Common Issues

  1. "No credentials found"

    • Ensure AWS credentials are properly configured
    • Check that the profile name is correct (if using profiles)
  2. "Access denied"

    • Verify IAM permissions for Cost Explorer
    • Ensure billing access is enabled for your account
  3. "Invalid date format"

    • Use YYYY-MM-DD format for dates
    • Ensure end date is after start date

Testing

The server includes a test script to verify functionality:

# Basic functionality test (with credentials configured)
python test_server.py

Expected output when working correctly:

Initializing connection...
Available tools: ['get_cost_and_usage', 'get_dimension_values']
Testing get_cost_and_usage tool...

If you see "Unable to locate credentials", configure AWS credentials as described in the Configuration section above.

Development

To extend this server:

  1. Add new tools using the @server.tool() decorator
  2. Follow the MCP protocol specifications
  3. Use proper error handling for AWS API calls
  4. Test with different AWS account configurations

License

This project is open source. See LICENSE file for details.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured