Skip to main content
Glama

πŸš‡ Metro MCP

Model Context Protocol Server for US Transit Systems (DC Metro & NYC Subway)

MCP Cloudflare Workers OAuth 2.1 License

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?"

  • "What is the A train and where does it go?"

  • "What nearby stations can I walk to from Times Square?"

  • "How long does it take to walk between Times Square platforms?"

πŸ—ΊοΈ Station Information & Navigation

Washington DC:

  • "Where is the Smithsonian Metro station?"

  • "Show me all the stations on the Green Line"

New York City:

  • "Where is the Union Square station?"

  • "Show me all 496 stations on the NYC Subway"

  • "Which stations connect to Times Square?"

  • "Explain the difference between express and local trains"

β™Ώ 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:

  • Complete coverage: All 496 NYC Subway stations with coordinates

  • Transfer information: Walk times between connected stations (87 stations with transfers)

  • Route descriptions: Detailed service patterns for all 29 routes (express vs local, operating hours)

  • Platform clarity: Explains directional platforms (e.g., "127N" = northbound at Times Square)


Related MCP server: BVG MCP Server

Quick Start

Using the Public Server

The fastest way to get started is to use the hosted instance:

  1. Open your MCP Client

  2. Add this URL: https://metro-mcp.anuragd.me/sse

  3. Click "Connect" and authorize via GitHub

  4. Start asking questions about DC Metro!

Deploy Your Own

Want to run your own instance? See the Deployment section below.


Deployment

Prerequisites

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.anuragd.me/sse

Claude Desktop will automatically:

  1. Discover OAuth endpoints via /.well-known/oauth-authorization-server

  2. Register as a client

  3. Open your browser for GitHub authentication

  4. Receive and store the access token

  5. 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.anuragd.me/sse

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:

  1. Visit https://metro-mcp.anuragd.me/authorize in your browser

  2. Authorize via GitHub

  3. Copy the JWT token displayed

  4. Configure your client with:

    • Server URL: https://metro-mcp.anuragd.me/sse

    • Authorization Header: Bearer your-jwt-token-here

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_all_stations

Get a complete list of all stations with coordinates

DC, NYC

get_station_transfers πŸ†•

Get transfer connections and walk times between nearby stations

NYC only

get_route_info πŸ†•

Get detailed route information (express/local, service patterns, hours)

NYC only

get_elevator_incidents

Find elevator and escalator outages

DC only

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

Total: 13 MCP tools (11 core + 2 new NYC-specific tools)

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 TransitAPIClient interface enables easy addition of new cities (BART, MBTA, etc.)

  • City Routing: Single server handles all cities via city parameter in MCP tool calls

  • Normalized Responses: All transit clients return standardized TransitStation, TransitPrediction, and TransitIncident types

  • 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

A
license - permissive license
-
quality - not tested
C
maintenance

Maintenance

–Maintainers
1hResponse time
–Release cycle
–Releases (12mo)
Commit activity

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Aarekaz/metro-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server