Metro MCP
A MCP server of washington DC's Metro
π Metro MCP
Model Context Protocol Server for US Transit Systems (DC Metro & NYC Subway)
A unified remote Model Context Protocol (MCP) server supporting multiple US transit systems. Currently supports Washington DC Metro (WMATA) and New York City Subway (MTA). Built for seamless integration with MCP-compatible clients like Claude Desktop.
Quick Links: Quick Start β’ What You Can Do β’ Deployment β’ Client Integration
What You Can Do
Ask natural language questions about DC Metro or NYC Subway in Claude Desktop or any MCP-compatible client:
π Real-Time Transit Information
Washington DC:
- "When is the next Red Line train at Dupont Circle?"
- "What bus routes are available?"
- "Find bus stops near Dupont Circle"
- "Where are all the 30N buses right now?"
- "When is the next bus at stop 1001195?"
- "Show me all trains currently running on the Metro system"
- "Are there any delays on the Blue Line right now?"
- "Are all the elevators working at Union Station?"
New York City:
- "When is the next 1 train at Times Square?"
- "Are there delays on the A/C line?"
- "What trains are arriving at Grand Central?"
πΊοΈ Station Information & Navigation
Washington DC:
- "Where is the Smithsonian Metro station?"
- "Show me all the stations on the Green Line"
- "How do I get from Capitol South to Bethesda?"
New York City:
- "Where is the Union Square station?"
- "Show me all stations on the 4/5/6 lines"
- "How do I get from Penn Station to Brooklyn?"
βΏ Accessibility
Washington DC (Elevator Outages):
- "Are there any elevator outages between here and National Airport?"
- "Which DC Metro stations have working elevators right now?"
π Service Monitoring
Both Cities:
- "Any transit delays right now in NYC?"
- "Is the DC Metro Orange Line running normally?"
- "Compare service quality between DC Metro and NYC Subway"
π System Information
Washington DC:
- Complete list of all Metro stations with coordinates
- Information about all six Metro lines (Red, Blue, Orange, Silver, Green, Yellow)
New York City:
- Key NYC Subway stations with coordinates
- Information about all subway lines (numbered and lettered)
Quick Start
Using the Public Server
The fastest way to get started is to use the hosted instance:
- Open Claude Desktop
- Add this URL:
https://metro-mcp.aarekaz.workers.dev - Click "Connect" and authorize via GitHub
- Start asking questions about DC Metro!
Deploy Your Own
Want to run your own instance? See the Deployment section below.
Deployment
Prerequisites
- WMATA API Key (required)
- Cloudflare Account (free tier works)
- Bun or Node.js installed
- GitHub OAuth App (for authentication)
Setup Steps
1. Install dependencies:
# Using Bun (recommended)
bun install
# Or using npm
npm install
2. Generate JWT secret:
openssl rand -hex 32
3. Create GitHub OAuth App:
- Go to github.com/settings/developers
- Click "New OAuth App"
- Set Homepage URL:
https://metro-mcp.your-subdomain.workers.dev - Set Authorization callback URL:
https://metro-mcp.your-subdomain.workers.dev/callback - Save the Client ID and Client Secret
4. Create KV Namespaces:
# Create OAuth storage namespace
bunx wrangler kv namespace create "OAUTH_CLIENTS"
bunx wrangler kv namespace create "OAUTH_CLIENTS" --preview
# Create rate limiting namespace
bunx wrangler kv namespace create "RATE_LIMIT_KV"
bunx wrangler kv namespace create "RATE_LIMIT_KV" --preview
Copy the IDs from the output and update wrangler.toml.
5. Configure environment:
Copy the example files and fill in your values:
# Copy wrangler config
cp wrangler.toml.example wrangler.toml
# Update the KV namespace IDs in wrangler.toml
# Copy local development secrets
cp .dev.vars.example .dev.vars
# Add your actual secrets to .dev.vars
6. Set production secrets:
# These are encrypted and stored securely by Cloudflare
bunx wrangler secret put WMATA_API_KEY
bunx wrangler secret put GITHUB_CLIENT_SECRET
bunx wrangler secret put JWT_SECRET
7. Deploy:
# Deploy to Cloudflare Workers
bunx wrangler deploy
MCP Client Integration
Claude Desktop (Automatic OAuth)
Simple Setup:
Just add the server URL to Claude Desktop:
https://metro-mcp.aarekaz.workers.dev
Claude Desktop will automatically:
- Discover OAuth endpoints via
/.well-known/oauth-authorization-server - Register as a client
- Open your browser for GitHub authentication
- Receive and store the access token
- Connect to the MCP server
No manual token copying required!
Other MCP Clients
For MCP clients that support OAuth 2.1 with automatic discovery:
Server URL:
https://metro-mcp.aarekaz.workers.dev
The client will handle authentication automatically via the OAuth flow.
Manual Token Authentication (Legacy)
If your MCP client doesn't support OAuth, you can still authenticate manually:
- Visit
https://metro-mcp.aarekaz.workers.dev/authorizein your browser - Authorize via GitHub
- Copy the JWT token displayed
- Configure your client with:
- Server URL:
https://metro-mcp.aarekaz.workers.dev/sse - Authorization Header:
Bearer your-jwt-token-here
- Server URL:
OAuth Endpoints
The server implements OAuth 2.1 with PKCE for secure authentication:
- Discovery:
/.well-known/oauth-authorization-server - Registration:
/register(Dynamic client registration - RFC 7591) - Authorization:
/authorize(GitHub OAuth integration) - Token:
/token(Authorization code exchange with PKCE verification) - Callback:
/callback(GitHub OAuth callback)
Security Features
- PKCE (S256) required for all authorization flows
- Persistent client registration via Cloudflare KV
- JWT tokens with 90-day expiration
- Rate limiting and origin validation
Supported Cities
The server currently supports these transit systems:
| City | System | Real-Time Data | Service Alerts | Elevator Status |
|---|---|---|---|---|
| Washington DC | WMATA (Metro) | β | β | β |
| New York City | MTA (Subway) | β | β | β |
Available MCP Tools
The server exposes the following tools through the MCP protocol:
| Tool | Description | Supported Cities |
|---|---|---|
get_station_predictions | Get real-time train arrival predictions for a station | DC, NYC |
search_stations | Search for stations by name or code | DC, NYC |
get_stations_by_line | Get all stations on a specific line | DC, NYC |
get_incidents | Check current service disruptions and advisories | DC, NYC |
get_elevator_incidents | Find elevator and escalator outages | DC only |
get_all_stations | Get a complete list of all stations with coordinates | DC, NYC |
get_bus_predictions | Get real-time bus arrival predictions (7-digit stop ID) | DC only |
get_bus_routes | Get list of all available bus routes | DC only |
get_bus_stops | Search bus stops by location or get all stops | DC only |
get_bus_positions | Get live positions of all buses (optionally filter by route) | DC only |
get_train_positions | Get live positions of all trains on the system | DC only |
Note: Most tools require a city parameter (dc or nyc). DC-only tools (get_bus_predictions, get_bus_routes, get_bus_stops, get_bus_positions, get_train_positions, get_elevator_incidents) do not require the city parameter.
Technical Details
MCP Protocol
- Version: 2025-03-26
- Transport: SSE (Server-Sent Events)
- Authentication: OAuth 2.1 with PKCE (S256)
Transit APIs
WMATA (DC Metro):
The server interfaces with the official WMATA REST APIs. Visit WMATA's developer documentation for details:
- Station predictions: Real-time train arrival information
- Station information: Station names, codes, and locations
- Incidents: Service disruptions and advisories
- Elevator/escalator outages: Accessibility information
MTA (NYC Subway):
The server uses GTFS-Realtime feeds from the MTA. Public API endpoints (no API key required):
- Real-time feeds: Protocol Buffers format with 30-second update intervals
- 8 separate feeds: Covering all subway lines (1-7, A/C/E, B/D/F/M, etc.)
- NYCT extensions: Train IDs, track assignments, and direction information
- Service alerts: Embedded in GTFS-Realtime alert entities
Hosting
- Platform: Cloudflare Workers
- Storage: Cloudflare KV (for OAuth client registration)
- Runtime: V8 isolates with global edge deployment
Source Structure
The codebase is organized for multi-city transit support with a clean separation of concerns:
src/
βββ index.ts # Cloudflare Worker entry point
βββ router.ts # Request routing (OAuth, MCP, API endpoints)
βββ types.ts # Shared TypeScript type definitions
β
βββ OAuth & Authentication
β βββ auth.ts # JWT token management and verification
β βββ oauth-handler.ts # OAuth 2.1 flow implementation with PKCE
β
βββ MCP Protocol
β βββ mcp-handler.ts # MCP request processing and tool routing
β βββ mcp-tools.ts # MCP tool definitions (11 tools)
β βββ mcp-types.ts # MCP protocol type definitions
β
βββ Error Handling
β βββ error-handler.ts # Multi-city validation and error handling
β
βββ Transit Abstraction Layer
βββ base.ts # Abstract TransitAPIClient class
βββ registry.ts # Transit client factory (city routing)
βββ wmata-client.ts # DC Metro client (WMATA REST APIs)
βββ mta-client.ts # NYC Subway client (GTFS-Realtime)
Key Architecture Decisions:
- Transit Abstraction: Common
TransitAPIClientinterface enables easy addition of new cities (BART, MBTA, etc.) - City Routing: Single server handles all cities via
cityparameter in MCP tool calls - Normalized Responses: All transit clients return standardized
TransitStation,TransitPrediction, andTransitIncidenttypes - Extensibility: Adding a new city only requires implementing the abstract client class
Contributing
Contributions are welcome! Feel free to:
- Report bugs or request features via GitHub Issues
- Submit pull requests with improvements
- Share feedback on the MCP implementation
License
MIT License - see LICENSE file for details.
Built with β€οΈ for the Washington DC Metro community
Related Servers
ChunkHound
A local-first semantic code search tool with vector and regex capabilities, designed for AI assistants.
Campertunity
Search campgrounds around the world on campertunity, check availability, and provide booking links.
mu-mcp
Query your local `mu` mail index for fast, structured mail search from MCP clients.
OSRS MCP Server
Search the Old School RuneScape (OSRS) Wiki and access game data definitions.
Wikimedia Image Search
MCP server that enables AI assistants to search Wikimedia Commons images with metadata and visual thumbnails.
Minecraft Wiki MCP
A server for browsing and searching the official Minecraft Wiki.
StatPearls
Fetches peer-reviewed medical and disease information from StatPearls.
Enhanced Documentation Search
Provides real-time access to documentation, library popularity data, and career insights using the Serper API.
PubMed MCP Server
Search and download scientific articles from PubMed's E-utilities API.
Airbnb
Search for Airbnb listings and retrieve their details.