Server data from the Official MCP Registry
Community-built server providing real-time London transport data via the TfL Unified API
Community-built server providing real-time London transport data via the TfL Unified API
Valid MCP server (4 strong, 4 medium validity signals). No known CVEs in dependencies. Imported from the Official MCP Registry.
5 files analyzed · No issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: TFL_APP_KEY
From the project's GitHub README.
Disclaimer: This is a community-built project. It is not affiliated with, endorsed by, or connected to Transport for London (TfL). This project consumes the publicly available TfL Unified API.
A MCP server that exposes the TfL (Transport for London) Unified API as tools, allowing AI assistants like Claude to query live London transport data.
Available in two implementations:
Step 1 — Add to Claude Desktop
Open your Claude Desktop config file:
~/Library/Application Support/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.json~/.config/Claude/claude_desktop_config.jsonOption A: Node.js MCPB (recommended)
Download tfl.mcpb from GitHub Releases and install it in Claude Desktop, or add manually:
{
"mcpServers": {
"tfl": {
"command": "npx",
"args": ["-y", "@oneill9/mcp-server-tfl"]
}
}
}
Option B: Docker
{
"mcpServers": {
"tfl": {
"command": "docker",
"args": ["run", "-i", "--rm", "ghcr.io/oneill9/mcp-server-tfl:latest"]
}
}
}
Step 2 — Add a TfL API key (recommended)
Without a key, TfL applies strict rate limits that will impact most real-world usage. Register a free key and pass it via the TFL_APP_KEY environment variable:
"env": { "TFL_APP_KEY": "your_key_here" }
Step 3 — Restart Claude Desktop and start asking questions
Example: "Is the Central line running normally?", "When is the next bus from Oxford Circus?"
For full setup details (Java direct, Docker options), see docs/installation.md.
| Tool | Description | TfL Endpoint |
|---|---|---|
service_status | Current status and disruptions by mode | GET /Line/Mode/{modes}/Status |
arrivals | Live arrivals at a stop by name | GET /StopPoint/{naptan}/Arrivals |
journey | Plan a journey between two points | GET /Journey/JourneyResults/{from}/to/{to} |
bike_points | List Santander Cycles docking stations | GET /BikePoint |
crowding | Live station crowding level by name | GET /Crowding/{naptan}/Live |
fares | Fare information between two named stops | GET /StopPoint/{id}/FareTo/{targetId} |
Note: The server uses the
/StopPoint/Search/{query}endpoint internally to automatically resolve stop names to NaPTAN IDs for thearrivals,crowding, andfarestools.
This server is distributed as a Desktop extension (MCPB) using stdio transport. It does not implement OAuth or any server-side authentication.
The TfL API uses a simple API key (TFL_APP_KEY) that you supply as an environment variable. A key is strongly recommended — without one, TfL applies strict rate limits that will impact most real-world usage. Registration is free. No OAuth flow, login, or account beyond the TfL portal is required to use this MCP server.
| Environment Variable | Default | Description |
|---|---|---|
TFL_APP_KEY | (none) | TfL API key — register at api-portal.tfl.gov.uk |
TFL_APP_ID | (none) | TfL App ID — only needed for older API registrations that issued both an ID and key |
An API key is strongly recommended — without one, TfL's strict rate limits will impact most real-world usage. Registration is free at api-portal.tfl.gov.uk.
Both implementations use stdio transport — JSON-RPC over stdin/stdout, the standard MCP transport for Claude Desktop.
# Node.js
cd node && npm run build && node dist/index.js
# Java
./gradlew run
For use with Claude Desktop, see docs/installation.md.
Unit tests use a mock HTTP server — no network access or API key required:
cd node && npm test
Contract tests call the live TfL API:
cd node && TFL_APP_KEY=your_key_here npm run contractTest
Unit tests use WireMock to stub the TfL API — no network access or API key required:
./gradlew test
Contract tests spin up the server as a real subprocess and call the live TfL API:
TFL_APP_KEY=your_key_here ./gradlew contractTest
For questions, bug reports, or feature requests, please open an issue on GitHub Issues.
This MCP server acts as a local proxy between your AI assistant and the TfL Unified API. It does not collect, store, or transmit any personal data beyond what is required to forward your queries to TfL.
api.tfl.gov.uk). See TfL's privacy policy for how TfL handles API usage data.The full privacy policy is available at PRIVACY.md.
This server has been reviewed for compliance with the Anthropic Software Directory Terms and Anthropic Software Directory Policy. See COMPLIANCE.md for the full compliance statement and maintainer commitments.
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Read, search, and manipulate Git repositories programmatically
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.
by Microsoft · Content & Media
Convert files (PDF, Word, Excel, images, audio) to Markdown for LLM consumption
by mcp-marketplace · Developer Tools
Scaffold, build, and publish TypeScript MCP servers to npm — conversationally
by mcp-marketplace · Finance
Free stock data and market news for any MCP-compatible AI assistant.