DB Timetable MCP Server
Provides access to Deutsche Bahn's timetable data through MCP, enabling real-time train schedules, station search, and change tracking for German railway stations.
README
DB Timetable MCP Server
A standardized Model Context Protocol (MCP) server that provides seamless access to Deutsche Bahn's timetable data through MCP tools and resources. This server enables AI assistants and applications to query real-time train schedules, station information, and timetable changes for German railway stations.
Overview
This MCP server bridges the gap between AI applications and Deutsche Bahn's timetable API, offering:
- Real-time timetable access - Get current train schedules and platform information
- Change tracking - Monitor real-time updates, delays, and platform changes
- Station search - Find stations by name or EVA number
- Planned schedules - Access future timetable data for trip planning
Built with the standard @modelcontextprotocol/sdk, this server supports both stdio and SSE (Server-Sent Events) transport modes, making it compatible with various MCP clients including Cursor IDE.
Data Source & License
This project provides timetable data from Deutsche Bahn, which is publicly available under the Creative Commons Attribution 4.0 International License (CC BY 4.0).
For more information about the API and license terms, visit developers.deutschebahn.com. All API requests are subject to the license terms.
Key Features
- Real-time Timetables - Get current train schedules with platform assignments, delays, and real-time updates
- Change Tracking - Monitor live timetable changes including delays, cancellations, and platform modifications
- Planned Schedules - Access future timetable data for specific dates and times
- Station Discovery - Search and find German railway stations by name, code, or pattern matching
- Dual Transport Modes - Support for both stdio (CLI) and SSE (HTTP) transport protocols
- Cursor IDE Integration - Ready-to-use configuration for seamless Cursor IDE integration
Prerequisites
- Node.js 18 or higher
- API credentials for the DB Timetable API (Client ID and Client Secret)
Installation
-
Clone the repository:
git clone <repository-url> cd db-timetable-mcp -
Install dependencies:
npm install -
Compile TypeScript code:
npm run build
Configuration
Create a .env file in the project root directory with the following environment variables:
DB_TIMETABLE_CLIENT_ID=your-client-id
DB_TIMETABLE_CLIENT_SECRET=your-client-secret
TRANSPORT_TYPE=sse
PORT=3000
SSE_ENDPOINT=/sse
LOG_LEVEL=info
Configuration Options
DB_TIMETABLE_CLIENT_ID: Client ID for the DB API (required)DB_TIMETABLE_CLIENT_SECRET: Client Secret for the DB API (required)TRANSPORT_TYPE: Transport type for the MCP server (stdioorsse, default:stdio)PORT: Port for the SSE server (default:3000)SSE_ENDPOINT: Endpoint for SSE connections (default:/sse)LOG_LEVEL: Logging level (debug,info,warn,error, default:info)
Usage
Starting the Server
In stdio mode (for CLI tests and debugging):
npm start
In SSE mode (for web clients):
TRANSPORT_TYPE=sse npm start
Or use the dev script:
npm run dev:sse
MCP Tools
The server provides the following tools:
-
getCurrentTimetable: Retrieves current timetable data for a station
- Parameters:
evaNo- EVA number of the station (e.g., 8000105 for Frankfurt Hbf)
- Parameters:
-
getRecentChanges: Retrieves recent changes for a station
- Parameters:
evaNo- EVA number of the station (e.g., 8000105 for Frankfurt Hbf)
- Parameters:
-
getPlannedTimetable: Retrieves planned timetable data for a station
- Parameters:
evaNo- EVA number of the station (e.g., 8000105 for Frankfurt Hbf)date- Date in YYMMDD format (e.g., 230401 for April 1, 2023)hour- Hour in HH format (e.g., 14 for 2 PM)
- Parameters:
-
findStations: Searches for stations by pattern
- Parameters:
pattern- Search pattern (e.g., "Frankfurt" or "BLS")
- Parameters:
MCP Resources
The server provides the following resources:
- Current Timetable:
db-api:timetable/current/{evaNo} - Recent Changes:
db-api:timetable/changes/{evaNo} - Planned Timetable:
db-api:timetable/planned/{evaNo}/{date}/{hour} - Station Search:
db-api:station/{pattern}
Development
Project Structure
db-timetable-mcp/
├── src/
│ ├── api/ # API client and types
│ ├── tools/ # MCP tools
│ ├── resources/ # MCP resources
│ ├── utils/ # Utility functions
│ ├── config.ts # Configuration
│ └── index.ts # Main entry point
├── dist/ # Compiled files
├── .env # Environment variables
├── package.json
├── tsconfig.json
└── README.md
NPM Scripts
npm run build: Compiles TypeScript codenpm start: Starts the servernpm run dev: Starts the server in development modenpm run dev:sse: Starts the server in SSE mode (development)npm test: Runs testsnpm run check-env: Checks environment variable configuration
Cursor Integration
This server can be integrated with Cursor IDE. See CURSOR_CONFIG.md for detailed configuration instructions.
Quick Setup
-
Start the server in SSE mode:
npm run dev:sse -
Add to Cursor's MCP configuration:
{ "mcpServers": { "db-timetable": { "url": "http://localhost:3000/sse", "transport": "sse" } } }
REST API Endpoints
The server also provides REST API endpoints for testing:
GET /health- Health checkGET /tools- List all toolsGET /resources- List all resourcesPOST /tools/call- Call a tool (REST API)GET /sse- SSE connection endpointPOST /sse- Send MCP messages via SSE (JSON-RPC 2.0)
Extensibility
Potential extensions:
-
Data Processing and Enrichment
- Semantic timetable data processing: XML to structured JSON with semantic enrichment
- Historical data analysis for delays and operational disruptions
- Integration of multimodal transport connections
-
Advanced MCP Tools
- Route planning between stations
- AI-based delay and capacity forecasts
- Travel disruption analysis
- Accessibility check for stations and connections
License
MCP Server: MIT License
DB Timetable API: Creative Commons Attribution 4.0 International License
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.