Skip to main content

Model Context Protocol server for Federal Reserve Economic Data (FRED) API

Project description

MCP-FRED

Model Context Protocol server for Federal Reserve Economic Data (FRED) API

A comprehensive MCP server providing access to all FRED API endpoints with intelligent large data handling, project-based storage, and async job processing for AI assistants like Claude.

Python 3.11+ License: MIT Code style: ruff


Features

  • 12 MCP Tools covering 50+ FRED API endpoints (categories, releases, series, sources, tags, maps)
  • Conservative Token Estimation - Automatically saves large datasets to files to prevent context overflow
  • Project-Based Storage - Organized file management for economic data
  • Async Job Processing - Background processing for large datasets (>10K observations)
  • Multiple Transports - STDIO (local) and Streamable HTTP (remote) support
  • Smart Output Handling - Auto-detect when to return data vs. save to file
  • Type Safety - Full Pydantic validation for all inputs and outputs

Quick Start

Two Installation Options

Option 1: Claude Desktop Extension (Recommended)

The easiest way to get started - no manual setup required!

Requirements:

  • Python 3.11+
  • uv package manager (brew install uv)

Installation:

  1. Download mcp-fred.mcpb from GitHub Releases
  2. Double-click the file (or run open mcp-fred.mcpb)
  3. Enter your FRED API key when prompted
  4. Done! The extension is now available in Claude Desktop

See EXTENSION.md for detailed instructions and troubleshooting.


Option 2: Manual Installation

Prerequisites:

Installation:

  1. Clone the repository:

    git clone https://github.com/cfdude/mcp-fred.git
    cd mcp-fred
    
  2. Create virtual environment:

    python3.11 -m venv venv
    source venv/bin/activate  # On Windows: venv\Scripts\activate
    
  3. Install dependencies:

    pip install -r requirements.txt
    
  4. Configure environment:

    cp .env.example .env
    # Edit .env and add your FRED_API_KEY
    

Usage with Claude Desktop:

Add to your Claude Desktop configuration file:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json
{
  "mcpServers": {
    "fred": {
      "command": "python",
      "args": ["-m", "mcp_fred"],
      "env": {
        "FRED_API_KEY": "your_api_key_here",
        "FRED_STORAGE_DIR": "/Users/username/Documents/fred-data"
      }
    }
  }
}

Restart Claude Desktop, and the FRED tools will be available!

CLI Usage Example:

Use the MCP CLI (or compatible host) to manage FRED data projects and background jobs:

# Create a new project workspace with canonical subdirectories
mcp-cli call fred_project_create --operation create --project macro-demo

# List known projects with file counts and storage metadata
mcp-cli call fred_project_list --operation list --output screen

# Review background job progress or filter for completed runs
mcp-cli call fred_job_list --operation list --status completed --output screen

# Cancel a long-running job when you no longer need the export
mcp-cli call fred_job_cancel --operation cancel --job_id fred-job-123

# Check the final status for a specific job (useful after cancellations)
mcp-cli call fred_job_status --operation get --job_id fred-job-123

Note: The CLI examples assume mcp-cli is configured with your FRED_API_KEY and optional FRED_STORAGE_DIR. Substitute actual job identifiers when invoking job status tools.


Available Tools

Data Retrieval Tools

Tool Description Example Operations
fred_category Category operations get, children, related, series, tags
fred_release Release operations get, dates, series, sources, tags, tables
fred_series Series operations get, observations, categories, release, search, tags, updates, vintagedates
fred_source Source operations get, releases
fred_tag Tag operations get, related, series
fred_maps GeoFRED maps shapes, series data

Job Management Tools

Tool Description
fred_job_status Check status of background jobs
fred_job_list List recent/active jobs
fred_job_cancel Cancel running job

Project Management Tools

Tool Description
fred_project_list List all projects in storage
fred_project_create Create new project directory
fred_project_files List files in a project

How It Works

Smart Output Handling

MCP-FRED intelligently decides whether to return data directly or save to a file:

  1. Small datasets (<50K tokens): Returned directly to Claude
  2. Large datasets (>50K tokens): Saved to file automatically
  3. Very large datasets (>10K observations): Processed in background job

Token Estimation

Conservative approach assuming 75% of context already used:

  • Claude Sonnet: 50K safe limit (out of 200K total)
  • GPT-4: 25K safe limit (out of 100K total)
  • Gemini Pro: 250K safe limit (out of 1M total)

Project-Based Storage

Files are organized by project:

fred-data/
  my-project/
    series/          # Series observation data
    maps/            # GeoFRED shape files
    releases/        # Release data
    categories/      # Category data
    sources/         # Source data
    tags/            # Tag data
    .project.json    # Project metadata

Example Usage

In Claude Desktop, ask:

"Using FRED data, get GDP observations for the last 10 years and save it to the 'economy-2024' project"

Claude will:

  1. Call fred_series with operation="get_observations"
  2. Estimate dataset size (~40 observations)
  3. Save to fred-data/economy-2024/series/GNPCA_observations.csv
  4. Return file path for further analysis

For large datasets:

"Get all unemployment observations since 1948"

Claude will:

  1. Estimate size (>10K observations)
  2. Create background job
  3. Return job ID immediately
  4. Check status with fred_job_status
  5. Get file path when complete

Configuration

All configuration via environment variables (.env file or MCP client config):

Required

  • FRED_API_KEY - Your FRED API key

Optional

  • FRED_STORAGE_DIR - Storage location (default: ./fred-data)
  • FRED_PROJECT_NAME - Default project name (default: default)
  • FRED_OUTPUT_FORMAT - Default format: csv or json (default: csv)
  • FRED_OUTPUT_MODE - Output mode: auto, screen, or file (default: auto)
  • FRED_OUTPUT_FILE_CHUNK_SIZE - Rows per CSV flush (default: 1000)
  • FRED_JOB_RETENTION_HOURS - Job retention period (default: 24)

See .env.example for complete list.


Development

Setup Development Environment

# Clone and setup
git clone https://github.com/cfdude/mcp-fred.git
cd mcp-fred
git checkout dev

# Create virtual environment
python3.11 -m venv venv
source venv/bin/activate

# Install dependencies
pip install -r requirements.txt

# Configure environment
cp .env.example .env
# Edit .env with your FRED_API_KEY

Run Tests

# Run all tests with coverage
pytest --cov=mcp_fred --cov-report=html

# Run specific tests
pytest tests/test_tools/test_series.py

# Run with verbose output
pytest -v

Code Quality

# Lint and format
ruff check .
ruff format .

# Fix auto-fixable issues
ruff check --fix .

Documentation

CI/CD

Automated testing and security checks run on every commit and pull request.

Install pre-commit hook (recommended for development):

./scripts/install-pre-commit-hook.sh

The hook runs before each commit:

  • Code formatting check (ruff)
  • Linting (ruff)
  • Full test suite (pytest)
  • Coverage validation (80% minimum)

GitHub Actions workflows:

  • CI: Tests, formatting, linting on Python 3.11 & 3.12
  • Security: Secret scanning, dependency vulnerabilities

See CI_CD.md for complete details.


Architecture

Core Components

mcp-fred/
  src/mcp_fred/
    server.py           # MCP server entry point
    config.py           # Configuration management
    api/                # FRED API client
      client.py         # Async HTTP client
      endpoints/        # API endpoint implementations
      models/           # Pydantic response models
    tools/              # MCP tool implementations (12 tools)
    utils/              # Utilities
      token_estimator.py    # Token counting (tiktoken)
      file_handler.py       # File I/O and path security
      json_to_csv.py        # JSON to CSV conversion
      job_manager.py        # Async job tracking
      background_worker.py  # Background task processing
    transports/         # STDIO and HTTP transports
  tests/                # Test suite (80% coverage target)

Key Design Decisions

  1. Conservative Token Limits: Assume 75% context used, safe limits at 25% of total
  2. Project-Based Storage: User-configurable directory, organized subdirectories
  3. Async Job Processing: Background jobs for datasets >10K rows or >10 seconds
  4. Type Safety: Pydantic for all validation, runtime error catching
  5. Error Handling: Consistent JSON error responses with codes and details

FRED API Coverage

50+ FRED API endpoints mapped to 12 MCP tools

Critical Operations (Large Data)

  • Series Observations: Up to 100K observations per series
  • GeoFRED Maps: Shape files can be 1MB+ per region

Rate Limits

  • 120 requests per minute (FRED API limit)
  • Automatic retry with exponential backoff

Testing Philosophy

  • Target: 80% code coverage minimum
  • Focus: Unit tests (primary), integration tests (as needed)
  • Mocking: Mock FRED API responses, no real API calls in tests
  • No E2E: MCP product doesn't require end-to-end testing
  • Reference: See docs/TESTING_STRATEGY.md for scenarios, fixtures, and tooling details.

Contributing

We welcome contributions! Please:

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Follow conventional commit format (feat:, fix:, docs:, etc.)
  4. Run tests and linting (pytest && ruff check .)
  5. Submit a pull request to dev branch

License

This project is licensed under the MIT License - see the LICENSE file for details.


Acknowledgments

  • FRED API: Federal Reserve Bank of St. Louis for providing free economic data API
  • Model Context Protocol: Anthropic for the MCP specification
  • Snowflake MCP: Inspiration for smart output handling approach

Support

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

mcp_fred-0.1.0.tar.gz (38.2 kB view details)

Uploaded Source

Built Distribution

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

mcp_fred-0.1.0-py3-none-any.whl (47.7 kB view details)

Uploaded Python 3

File details

Details for the file mcp_fred-0.1.0.tar.gz.

File metadata

  • Download URL: mcp_fred-0.1.0.tar.gz
  • Upload date:
  • Size: 38.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.9 {"installer":{"name":"uv","version":"0.9.9"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for mcp_fred-0.1.0.tar.gz
Algorithm Hash digest
SHA256 1d026628ba0f97fda25e7fc4f0c17670acb7d03db41a8e9bab8a4c198df2a596
MD5 be61f209c37f2c96969959f40831bc52
BLAKE2b-256 ffadc2a7d9507afa1aa96f101a0c784e5764ac100357346f2709b64ab7b9da3a

See more details on using hashes here.

File details

Details for the file mcp_fred-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: mcp_fred-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 47.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.9 {"installer":{"name":"uv","version":"0.9.9"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for mcp_fred-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3623834e9b2ae54947b03451a1d3601efebac9fb3271134c28e2b22e664e45f1
MD5 245484d8cd4c67408a7e96312136eb65
BLAKE2b-256 36da95e92a357ad7636f40648f4883309e16b104a9f88df6b57c7bc619a02688

See more details on using hashes here.

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