fred-mcp

fred-mcp

Enables AI agents to search and retrieve FRED economic time series, including vintage (as-published) data, with tools for series search, observation retrieval, release calendar, revision history, and more.

Category
Visit Server

README

fred-mcp

<!-- mcp-name: io.github.mcpwright/fred-mcp -->

FRED® economic data inside your AI agent — including what the numbers said before the revisions. An MCP server for the Federal Reserve Bank of St. Louis's FRED® API: search and read 800,000+ U.S. and international time series, follow the release calendar, and — the distinctive part — query ALFRED® vintage data: any series exactly as it was known on a past date, and any single data point's full revision history from its initial print to today's value.

Read-only, built on public endpoints, powered by your own free FRED API key. Live API calls with a volatility-aware cache (vintage reads are immutable and cache long; current data stays fresh) — no bulk mirroring.

This product uses the FRED® API but is not endorsed or certified by the Federal Reserve Bank of St. Louis. By using this server you agree to the FRED® API Terms of Use.

Status: v0.1.0 — live on PyPI (uvx mcpwright-fred) and the official MCP Registry (io.github.mcpwright/fred-mcp). 9 tools, CI-gated, built on mcpwright-core.

Why vintage data matters

Economic numbers get revised — sometimes dramatically. The advance estimate of Q4-2008 real GDP told policymakers the economy was shrinking far more slowly than the number that stands today. If an agent reasons about what decision-makers knew at the time using current data, it is quietly wrong. get_series_as_of and get_revision_history make as-published data a first-class question.

Tools

Tool What it does
search_series Find series IDs by free text, best matches first
get_series One series' full metadata + verbatim notes
get_observations A date window of values; transforms (pct_change_yoy, …) + downsampling
get_latest The most recent value + the next scheduled release date
compare_series 2–5 series aligned on one date axis
get_release_calendar Upcoming data releases ("when's the next jobs report?")
get_series_as_of A series exactly as known on a past date (ALFRED vintage)
get_revision_history One data point's life: initial print → every revision → today
get_vintage_dates When a series was released/revised; bounds the vintage tools

All tools are read-only and annotated as such.

What can you ask?

Every question below was run live against the real FRED API through these tools (answers as of June 2026 — ask again and they'll be current).

Everyday questions:

  1. "What's the unemployment rate right now, and when's the next jobs report?"get_latest(UNRATE) → 4.3% (May 2026), next release 2026-07-02.
  2. "What's the 10-year Treasury yield today?"get_latest(DGS10) → 4.53% (it correctly skips the . rows daily series publish on holidays).
  3. "How has inflation trended over the past year?"get_observations(CPIAUCSL, transform=pct_change_yoy) → 2.4% → 3.3% → 3.8% → 4.2% over Feb–May 2026.
  4. "Find me data on median household income."search_seriesMEHOINUSA672N (real) and MEHOINUSA646N (nominal), annual.
  5. "Is the labor market loosening? Compare unemployment and job openings since 2024."compare_series([UNRATE, JTSJOL]) → one aligned table.
  6. "What economic data comes out this week?"get_release_calendar(7) → 241 release dates, CPI included.
  7. "What was real GDP growth each quarter of 2025?"get_observations(A191RL1Q225SBEA) → −0.6, +3.8, +4.4, +0.5%.
  8. "Give me CPI as annual averages for the 2020s."get_observations(CPIAUCSL, frequency=annual) → one row per year.

Questions only the vintage tools can answer:

  1. "How bad did Q4-2008 GDP look to policymakers in early 2009, versus what we know now?"get_series_as_of(GDPC1, "2009-02-15") → a −3.8% annualized decline as known then (in chained-2000 dollars — the metadata is vintage-pinned too) versus −8.5% in today's data. Policy ran on the first number.
  2. "Was the May 2020 COVID unemployment rate ever revised?"get_revision_history(UNRATE, "2020-05-01") → first published as 13.3 (2020-06-05), currently 13.2, with each revision dated.
  3. "What mortgage rate did the Fed see going into the March 2022 liftoff meeting?"get_series_as_of(MORTGAGE30US, "2022-03-16") → 3.85% as known then; 6.48% today.
  4. "How often does GDP actually get revised?"get_vintage_dates(GDPC1) → 415 vintages since 1991-12-04.

Install

You need a free FRED API key (takes seconds): https://fred.stlouisfed.org/docs/api/api_key_request.html. Keys are personal under the FRED terms — bring your own.

uvx (any MCP client)

{
  "mcpServers": {
    "fred": {
      "command": "uvx",
      "args": ["mcpwright-fred"],
      "env": { "FRED_API_KEY": "your-key-here" }
    }
  }
}

Claude Code

claude mcp add fred -e FRED_API_KEY=your-key-here -- uvx mcpwright-fred

Claude Desktop

Use the one-click .mcpb extension from the latest release (it prompts for your API key), or add the uvx JSON above to your claude_desktop_config.json.

OpenAI Agents SDK / other clients

Any MCP-capable client works — point it at uvx mcpwright-fred over stdio with FRED_API_KEY in the environment.

Notes

  • Revisions: current values often differ from what was originally published; for "what was known at the time", use the vintage tools.
  • Copyrighted series: some FRED series are owned by third parties; their notes carry the owner's terms (surfaced verbatim, flagged via copyrighted). You are responsible for complying with them beyond personal use.
  • Caching & rate limits: responses are cached in-memory (vintage reads long, live reads short) and requests are throttled well under FRED's rate limit. Set FRED_MCP_CACHE=0 to disable caching, FRED_MCP_USER_AGENT to identify your own deployment.

Develop

git clone https://github.com/mcpwright/fred-mcp && cd fred-mcp
uv sync
uv run pytest                                  # tests
uv run mypy                                    # types
uv run ruff check src/ && uv run ruff format --check src/   # lint + format
uv run pre-commit run --all-files              # everything, like CI

Dev loop: feature branch → PR → Code Quality & Tests green → squash-merge.

Roadmap

  • [x] v1 tool surface (9 tools incl. the ALFRED vintage lane)
  • [x] Publish to PyPI (mcpwright-fred) + the MCP Registry
  • [x] Site page at mcpwright.com/fred
  • [x] .mcpb one-click Claude Desktop extension (v0.1.0 release)
  • [ ] GeoFRED / maps (pairs with census-mcp)

Questions & feedback

Discussions for questions and ideas · Issues for bugs.


Part of mcpwright — polished MCP servers for authoritative public data · built by Devender Gollapally. FRED® and ALFRED® are registered trademarks of the Federal Reserve Bank of St. Louis. This project is not affiliated with, endorsed, or certified by the Federal Reserve Bank of St. Louis.

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
Qdrant Server

Qdrant Server

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

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