Fed Speech MCP

Fed Speech MCP

Retrieves, parses, and analyzes speeches and testimonies from Federal Reserve officers, enabling searches by speaker, topic, and keyword with automatic RSS feed discovery and intelligent relevance scoring.

Category
Visit Server

README

Fed Speech MCP

An MCP (Model Context Protocol) server that retrieves, parses, and analyzes speeches and testimonies from major Federal Reserve officers.


Features

  • šŸ“” RSS Feed Discovery - Automatically discovers new speeches from Fed RSS feeds
  • šŸ” Index Page Scanning - Backfill capability by scanning yearly index pages
  • šŸ“ Smart Parsing - Extracts metadata, speaker info, and clean text from Fed HTML pages
  • šŸ“Š Feature Extraction - Detects topics (inflation, rates, labor market, etc.)
  • āš–ļø Importance Scoring - Rule-based scoring for market relevance
  • šŸ’¾ JSON Storage - Persistent storage with deduplication
  • šŸ”Œ MCP Interface - Full MCP compatibility for AI assistants

Covered Content

Speakers

  • Chair of the Federal Reserve
  • Vice Chair of the Federal Reserve
  • Federal Reserve Governors

Content Types

  • Speeches
  • Congressional Testimony
  • Prepared Remarks

Installation

Prerequisites

  • Python 3.10 or higher
  • uv package manager

Install uv (if you don't have it):

# macOS / Linux
curl -LsSf https://astral.sh/uv/install.sh | sh

# Windows
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"

Install the Project

cd fed-speech-mcp

# Create virtual environment and install
uv sync

That's it! The virtual environment is created and all dependencies are installed.


šŸš€ Quick Start: Test Locally in 5 Minutes

Want to see the MCP tools in action before connecting to an AI? Follow these steps:

Step 1: Install

cd fed-speech-mcp
uv sync

Step 2: Fetch Speeches from Fed Website

uv run python scripts/test_local.py refresh --limit 5

You'll see output like:

šŸ”„ REFRESHING SPEECHES FROM FED WEBSITE
==================================================
šŸ“” Discovering documents via RSS feeds...
   Found 20 document(s)

[1/5] Processing: Governor Bowman's Speech on Banking...
   āœ… Fetched 45231 bytes
   āœ… Parsed: Michelle W. Bowman - speech
   āœ… Normalized: fed-speech-a1b2c3d4e5f6
   āœ… Saved (NEW)
...
āœ… REFRESH COMPLETE
   Discovered: 5
   New: 5
   Total in storage: 5

Step 3: Explore the Data

View latest speeches:

uv run python scripts/test_local.py latest --limit 3

Output:

šŸ“° LATEST SPEECHES
==================================================
Found 3 speech(es):

1. Speech on Monetary Policy and the Economic Outlook
   šŸ“… 2024-12-15
   šŸ‘¤ Jerome H. Powell (Chair)
   šŸ“„ speech | 2500 words
   ⭐ high (0.85)
   šŸ·ļø  Topics: inflation, rates, labor
   šŸ”— https://federalreserve.gov/...
   šŸ†” fed-speech-abc123

Search by keyword:

uv run python scripts/test_local.py search --query "inflation"

Filter by speaker:

uv run python scripts/test_local.py speaker --name "Powell"
uv run python scripts/test_local.py speaker --role "Chair"

Get full speech content:

uv run python scripts/test_local.py get --doc-id fed-speech-abc123

View statistics:

uv run python scripts/test_local.py stats

Step 4: Run All Tests

uv run python scripts/test_local.py all

This runs a complete test suite: refresh → stats → latest → search → filter → get.

Available Test Commands

Command Description Example
refresh Fetch new speeches --limit 5, --include-index
latest Show latest speeches --limit 10, --since 2024-01-01
search Search by keyword --query "inflation"
speaker Filter by speaker --name "Powell", --role "Chair"
type Filter by doc type --doc-type testimony
get Get full speech --doc-id fed-speech-xxx
stats Show statistics (no options)
all Run all tests (no options)

Using with AI Assistants

Platform Compatibility Overview

Platform MCP Support Setup Method
Claude Desktop āœ… Native Direct MCP integration
Cursor IDE āœ… Native Direct MCP integration
ChatGPT āš ļø Via API HTTP API wrapper + Custom GPT
Google Gemini āš ļø Via API HTTP API wrapper + Google AI Studio
Other AI Tools āš ļø Via API HTTP API wrapper

Step-by-Step: Claude Desktop

Claude Desktop has native MCP support. This is the easiest setup.

Step 1: Install the Package

cd fed-speech-mcp
uv sync

Step 2: Locate Claude Desktop Config

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

Step 3: Add MCP Server Configuration

Edit claude_desktop_config.json:

{
  "mcpServers": {
    "fed-speech": {
      "command": "uv",
      "args": ["run", "fed-speech-mcp"],
      "cwd": "/path/to/fed-speech-mcp"
    }
  }
}

Note: Replace /path/to/fed-speech-mcp with your actual installation path.

Step 4: Restart Claude Desktop

Close and reopen Claude Desktop. You should see the Fed Speech tools available.

Step 5: Start Using

Ask Claude things like:

  • "Refresh the Fed speeches and show me the latest ones"
  • "What did Chair Powell say about inflation recently?"
  • "Show me all testimony from 2024"

Step-by-Step: Cursor IDE

Cursor IDE also supports MCP natively.

Step 1: Install the Package

cd fed-speech-mcp
uv sync

Step 2: Open Cursor Settings

  1. Open Cursor IDE
  2. Go to Settings (⌘+, on macOS, Ctrl+, on Windows)
  3. Search for "MCP" or navigate to Features → MCP Servers

Step 3: Add MCP Server

Click "Add MCP Server" and configure:

{
  "name": "fed-speech",
  "command": "uv",
  "args": ["run", "fed-speech-mcp"],
  "cwd": "/path/to/fed-speech-mcp"
}

Step 4: Enable and Use

Toggle the server on. You can now use Fed Speech tools in Cursor's AI chat.


Step-by-Step: ChatGPT (Custom GPT)

ChatGPT doesn't support MCP natively, but you can use the HTTP API wrapper.

Step 1: Install the Package

cd fed-speech-mcp
uv sync

Step 2: Start the HTTP API Server

uv run fed-speech-http

The server runs at http://localhost:8000 by default.

Step 3: Expose to Internet (Required for ChatGPT)

Use a tunneling service like ngrok:

# Install ngrok: https://ngrok.com/download
ngrok http 8000

Copy the public URL (e.g., https://abc123.ngrok.io).

Step 4: Create a Custom GPT

  1. Go to ChatGPT

  2. Click your profile → My GPTs → Create a GPT

  3. In the Configure tab:

    • Name: "Fed Speech Analyst"
    • Description: "Analyzes Federal Reserve speeches and testimonies"
    • Instructions:
      You are a Federal Reserve speech analyst. Use the available actions to:
      1. Fetch latest speeches with get_latest_speeches
      2. Search speeches by speaker, type, or keywords
      3. Analyze speech content for market-relevant insights
      Always refresh speeches first if the user asks about recent content.
      
  4. Click Create new action and import the OpenAPI schema:

openapi: 3.0.0
info:
  title: Fed Speech API
  version: 1.0.0
servers:
  - url: https://your-ngrok-url.ngrok.io
paths:
  /speeches/latest:
    get:
      operationId: getLatestSpeeches
      summary: Get latest Fed speeches
      parameters:
        - name: limit
          in: query
          schema:
            type: integer
            default: 10
        - name: since_date
          in: query
          schema:
            type: string
      responses:
        '200':
          description: List of speeches
  /speeches/search:
    get:
      operationId: searchSpeeches
      summary: Search speeches by keyword
      parameters:
        - name: query
          in: query
          required: true
          schema:
            type: string
        - name: limit
          in: query
          schema:
            type: integer
            default: 10
      responses:
        '200':
          description: Search results
  /speeches/{doc_id}:
    get:
      operationId: getSpeech
      summary: Get a specific speech
      parameters:
        - name: doc_id
          in: path
          required: true
          schema:
            type: string
      responses:
        '200':
          description: Speech details
  /speeches/refresh:
    post:
      operationId: refreshSpeeches
      summary: Fetch new speeches from Fed website
      responses:
        '200':
          description: Refresh result

Step 5: Save and Use

Save your Custom GPT. Now you can ask it questions about Fed speeches!


Step-by-Step: Google Gemini

Google Gemini can use the HTTP API via Google AI Studio or API.

Step 1: Start the HTTP API Server

cd fed-speech-mcp
uv sync
uv run fed-speech-http

Step 2: Expose to Internet

ngrok http 8000

Step 3: Use with Google AI Studio

  1. Go to Google AI Studio
  2. Create a new prompt or chat
  3. In your system instructions, include:
You have access to a Fed Speech API at https://your-ngrok-url.ngrok.io

Available endpoints:
- GET /speeches/latest?limit=10 - Get latest speeches
- GET /speeches/search?query=inflation - Search speeches
- GET /speeches/{doc_id} - Get specific speech
- POST /speeches/refresh - Fetch new speeches
- GET /speeches/by-speaker?name=Powell - Filter by speaker
- GET /speeches/by-type?doc_type=testimony - Filter by type

When users ask about Fed speeches, use these endpoints to fetch data.
Format responses clearly with speaker names, dates, and key points.

Step 4: Use Function Calling (Advanced)

For programmatic use with Gemini API:

import google.generativeai as genai
import requests

# Configure Gemini
genai.configure(api_key="YOUR_API_KEY")

# Define tools for Gemini
tools = [
    {
        "function_declarations": [
            {
                "name": "get_latest_speeches",
                "description": "Get the latest Federal Reserve speeches",
                "parameters": {
                    "type": "object",
                    "properties": {
                        "limit": {"type": "integer", "description": "Max speeches to return"}
                    }
                }
            },
            {
                "name": "search_speeches",
                "description": "Search Fed speeches by keyword",
                "parameters": {
                    "type": "object",
                    "properties": {
                        "query": {"type": "string", "description": "Search query"}
                    },
                    "required": ["query"]
                }
            }
        ]
    }
]

model = genai.GenerativeModel('gemini-pro', tools=tools)

# Handle function calls
def handle_function_call(fn_name, args):
    base_url = "http://localhost:8000"
    if fn_name == "get_latest_speeches":
        resp = requests.get(f"{base_url}/speeches/latest", params=args)
    elif fn_name == "search_speeches":
        resp = requests.get(f"{base_url}/speeches/search", params=args)
    return resp.json()

# Chat with function calling
chat = model.start_chat()
response = chat.send_message("What are the latest Fed speeches about inflation?")

# Process function calls in response
for part in response.parts:
    if hasattr(part, 'function_call'):
        fn = part.function_call
        result = handle_function_call(fn.name, dict(fn.args))
        # Send result back to model
        response = chat.send_message(str(result))

HTTP API Reference

When using the HTTP API wrapper, these endpoints are available:

Endpoint Method Description
/speeches/latest GET Get latest speeches
/speeches/search GET Search by keyword
/speeches/{doc_id} GET Get specific speech
/speeches/by-speaker GET Filter by speaker
/speeches/by-type GET Filter by doc type
/speeches/refresh POST Fetch new speeches
/speeches/stats GET Get statistics

Query Parameters

  • limit - Max results (default: 10, max: 50)
  • since_date - ISO 8601 date filter
  • start_date / end_date - Date range
  • name - Speaker name (partial match)
  • role - "Chair", "Vice Chair", or "Governor"
  • doc_type - "speech", "testimony", or "prepared_remarks"
  • query - Search keywords

Running the MCP Server Directly

For native MCP clients:

# Run the MCP server
uv run fed-speech-mcp

# Run the HTTP API server
uv run fed-speech-http

Available Tools

get_latest_speeches

Get the latest Federal Reserve speeches, sorted by publication date.

Parameters:

  • limit (optional): Maximum number of speeches (default: 10, max: 50)
  • since_date (optional): Only return speeches after this date (ISO 8601)

get_speeches_by_speaker

Filter speeches by speaker name and/or role.

Parameters:

  • name (optional): Speaker name (partial match, e.g., "Powell")
  • role (optional): "Chair", "Vice Chair", or "Governor"
  • start_date (optional): Start date filter
  • end_date (optional): End date filter

get_speeches_by_type

Get speeches by document type.

Parameters:

  • doc_type (required): "speech", "testimony", or "prepared_remarks"
  • start_date (optional): Start date filter
  • end_date (optional): End date filter

get_speech

Get full content and metadata for a specific speech.

Parameters:

  • doc_id (required): The unique document identifier

refresh_speeches

Fetch new speeches from the Federal Reserve website.

Parameters:

  • include_index (optional): Also scan index pages (slower but thorough)
  • years (optional): Years to scan for index pages

search_speeches

Search speeches by keyword.

Parameters:

  • query (required): Search query
  • limit (optional): Maximum results (default: 10)

get_speech_stats

Get statistics about stored speeches.

Output Format

Each speech document contains:

{
  "doc_id": "fed-speech-abc123def456",
  "source": {
    "publisher": "Board of Governors of the Federal Reserve System",
    "collection": "speeches",
    "url": "https://www.federalreserve.gov/...",
    "retrieved_at": "2024-01-15T10:30:00Z"
  },
  "published_at": "2024-01-15T00:00:00Z",
  "title": "Speech Title",
  "speaker": {
    "name": "Jerome H. Powell",
    "role": "Chair",
    "organization": "Board of Governors of the Federal Reserve System"
  },
  "doc_type": "speech",
  "event": {
    "name": "Economic Club of New York",
    "location": "New York, NY"
  },
  "text": {
    "raw": "...",
    "clean": "..."
  },
  "features": {
    "word_count": 2500,
    "language": "en",
    "has_qa": false,
    "topics": {
      "inflation": true,
      "labor_market": true,
      "rates": true,
      "balance_sheet": false,
      "growth": true,
      "financial_stability": false
    }
  },
  "importance": {
    "tier": "high",
    "score": 0.85,
    "reasons": [
      "Speaker is Chair (Jerome H. Powell)",
      "Discusses rates in context of inflation"
    ]
  }
}

Importance Scoring

The importance score is calculated using these rules:

Factor Adjustment
Chair or Vice Chair speaker Base: High
Governor speaker Base: Medium
Testimony +1 tier
Contains Q&A +1 tier
Discusses rates + (inflation or labor market) +1 tier
Word count < 300 -1 tier

Topic Detection

Topics are detected by keyword matching:

  • Inflation: inflation, prices, CPI, PCE, price stability
  • Labor Market: employment, unemployment, wages, jobs
  • Rates: interest rate, fed funds, hike, cut, monetary policy
  • Balance Sheet: QE, QT, runoff, asset purchases
  • Growth: GDP, demand, recession, economic activity
  • Financial Stability: banking, liquidity, stress, systemic risk

Environment Variables

Variable Description Default
FED_SPEECH_DATA_DIR Data storage directory ./data
FED_SPEECH_HTTP_TIMEOUT HTTP request timeout (seconds) 30
FED_SPEECH_MAX_RETRIES Max retry attempts 3
FED_SPEECH_HTTP_PORT HTTP API server port 8000

Data Storage

data/
ā”œā”€ā”€ speeches/           # Processed JSON documents
│   ā”œā”€ā”€ fed-speech-xxx.json
│   └── ...
└── raw/               # Raw HTML content (for traceability)
    ā”œā”€ā”€ 20240115_abc123.html
    └── ...

Development

Running Unit Tests

# Install with dev dependencies
uv sync --dev

# Run all tests
uv run pytest

# Run with verbose output
uv run pytest -v

# Run specific test file
uv run pytest tests/test_models.py

# Run with coverage
uv run pytest --cov=fed_speech_mcp

Running Local Integration Tests

# Test all MCP functionality end-to-end
uv run python scripts/test_local.py all

# Test specific functionality
uv run python scripts/test_local.py refresh --limit 3
uv run python scripts/test_local.py search --query "rates"

Project Structure

fed-speech-mcp/
ā”œā”€ā”€ src/fed_speech_mcp/
│   ā”œā”€ā”€ __init__.py
│   ā”œā”€ā”€ server.py          # MCP server entry point
│   ā”œā”€ā”€ http_server.py     # HTTP API wrapper
│   ā”œā”€ā”€ config.py          # Configuration
│   ā”œā”€ā”€ models/            # Pydantic data models
│   ā”œā”€ā”€ ingestion/         # RSS/index discovery & fetching
│   ā”œā”€ā”€ parsing/           # HTML parsing & normalization
│   ā”œā”€ā”€ features/          # Feature extraction & scoring
│   └── storage/           # JSON storage layer
ā”œā”€ā”€ data/                  # Data directory
ā”œā”€ā”€ pyproject.toml
└── README.md

License

MIT

Acknowledgments

Data sourced from the Federal Reserve Board.

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