MCP Hub
Back to servers

Federal Register MCP Server

Searches and retrieves United States executive orders, presidential documents, and agency rules directly from the Federal Register API.

Tools
12
Updated
Dec 4, 2025
Validated
Jan 9, 2026

Federal Register MCP Server

A Model Context Protocol (MCP) server that provides AI assistants with access to the Federal Register API. This enables searching and retrieving executive orders, presidential documents, rules, and agency information.

What is MCP?

MCP is a protocol that allows AI assistants like Claude to interact with external tools and data sources. This server exposes Federal Register data as a set of tools that can be called by AI assistants.

Features

  • Executive Orders: Search, retrieve, and get full text of executive orders by president, year, date range, or keyword
  • Presidential Documents: Search memoranda and proclamations
  • Federal Register Documents: Search and retrieve any document type (rules, proposed rules, notices)
  • Agency Information: List all federal agencies or get details about specific agencies
  • Public Inspection: View documents before official publication

Roadmap

  • Hosted version - Deploy a public instance so users can connect without running locally
  • Legislation tracking - Integrate Congress.gov API and Open States for federal and state legislation
  • Enriched metadata - Add categories, correlations between executive orders and legislation, impacted populations, and other analytical data
  • UI experience - Leverage OpenAI Apps to provide a visual interface for exploring executive and legislative data

Installation

# Clone the repository
git clone https://github.com/yourusername/federal-register-mcp.git
cd federal-register-mcp

# Install dependencies
npm install

# Build TypeScript
npm run build

Usage

This server supports two transport modes:

ModeTransportUse Case
stdio (default)Standard I/OClaude Desktop (local)
httpStreamable HTTPClaude Code, ChatGPT, remote clients

Claude Desktop (stdio mode)

Add this to your Claude Desktop configuration file:

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

{
  "mcpServers": {
    "federal-register": {
      "command": "node",
      "args": ["/path/to/federal-register-mcp/dist/server.js"]
    }
  }
}

Claude Code (stdio or HTTP mode)

Option 1: stdio (local)

{
  "mcpServers": {
    "federal-register": {
      "command": "node",
      "args": ["/path/to/federal-register-mcp/dist/server.js"]
    }
  }
}

Option 2: HTTP (local or remote)

Start the server in HTTP mode:

npm run start:http

Then configure Claude Code to connect to the HTTP endpoint:

{
  "mcpServers": {
    "federal-register": {
      "url": "http://localhost:3000/mcp"
    }
  }
}

ChatGPT (HTTP mode, requires public URL)

ChatGPT cannot connect to localhost. You need to expose the server publicly:

Option 1: ngrok (for development)

# Terminal 1: Start the server
npm run start:http

# Terminal 2: Create a tunnel
ngrok http 3000

Then use the ngrok URL (e.g., https://abc123.ngrok.io/mcp) in ChatGPT.

Option 2: Deploy to a cloud host (for production)

Deploy to any HTTPS-capable host:

  • Cloudflare Workers
  • Fly.io
  • Railway
  • Vercel
  • AWS / GCP / Azure

The MCP endpoint will be at https://your-host.com/mcp.

Running Directly

# stdio mode (default) - for Claude Desktop
npm start

# HTTP mode - for Claude Code, ChatGPT
npm run start:http

# HTTP mode with custom port
node dist/server.js --http --port 8080

# Or use environment variable
MCP_PORT=8080 npm run start:http

Development

# Edit files in src/*.ts, then build
npm run build

# Or use watch mode for auto-recompile
npm run dev

Health Check (HTTP mode)

When running in HTTP mode, a health endpoint is available:

curl http://localhost:3000/health
# {"status":"ok","mode":"http","sessions":0}

Available Tools

ToolDescription
search_executive_ordersSearch for executive orders by president, year, date range, or keyword
get_executive_orderGet a specific executive order by its EO number
get_executive_order_full_textFetch the complete full text of an executive order
get_recent_executive_ordersGet executive orders signed in the last 30 days
search_documentsSearch all Federal Register documents with flexible filtering
get_documentFetch a Federal Register document by its document number
get_document_textFetch the full plain text content of a document
search_presidential_memorandaSearch for presidential memoranda
search_proclamationsSearch for presidential proclamations
get_public_inspection_documentsGet documents currently on public inspection
get_agenciesGet a list of all federal agencies
get_agencyGet detailed information about a specific agency

Example Queries

Once configured, you can ask Claude questions like:

  • "What executive orders has Joe Biden signed about climate change?"
  • "Show me Trump's executive orders from his second term (2025)"
  • "Get the full text of Executive Order 14067"
  • "What documents are on public inspection today?"
  • "Find all proposed rules from the EPA in 2024"

API Reference

This server uses the Federal Register API v1. The API is free and requires no authentication.

Project Structure

federal-register-mcp/
├── src/
│   ├── server.ts              # MCP server implementation
│   └── federal-register-api.ts # Federal Register API client
├── dist/                      # Compiled JavaScript (generated)
├── tsconfig.json
├── package.json
└── README.md

License

MIT License - see LICENSE for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Reviews

No reviews yet

Sign in to write a review