MCP server exposing live Deutsche Bahn data: journeys, delays, disruptions, strikes, and alternative routes.
Project description
mcp-deutsche-bahn
An MCP server that gives any MCP-compatible AI assistant (Claude Desktop, Claude Code, Cursor, etc.) live access to Deutsche Bahn data: journey planning, real-time delays, disruptions, construction works, strikes, and alternative routes.
What it does
Six tools, available to your LLM:
| Tool | Answers |
|---|---|
search_journeys |
"How do I get from Berlin Hbf to München Hbf tomorrow at 9am?" |
station_departures |
"What's leaving Hamburg Hbf in the next hour?" |
journey_status |
"Has my booked journey been delayed?" |
get_disruptions |
"Any construction on the Köln–Frankfurt corridor?" |
detect_strike |
"Is there a strike going on right now?" |
find_alternatives |
"Route me around Hannover Hbf if it's blocked." |
Quickstart (1 minute, no clone)
You need uv (one-line install):
curl -LsSf https://astral.sh/uv/install.sh | sh
That's the only prereq. The MCP server itself installs on demand — pick your client:
Claude Desktop
Open ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows). Add:
{
"mcpServers": {
"deutsche-bahn": {
"command": "uvx",
"args": ["mcp-deutsche-bahn"]
}
}
}
Restart Claude Desktop (⌘Q + reopen — closing the window isn't enough). A plug icon appears in the input bar → click it → confirm deutsche-bahn lists 6 tools.
Claude Code
claude mcp add deutsche-bahn -- uvx mcp-deutsche-bahn
Cursor / other MCP clients
Same shape — command: uvx, args: ["mcp-deutsche-bahn"].
Try it
Ask your assistant:
What are my options getting from Berlin Hbf to Munich tomorrow at 8am, and is there any construction on that route?
It will call search_journeys and get_disruptions and stitch a human answer.
Optional: standalone CLI agent
If you want a plain-English REPL without Claude Desktop, the package ships an anthropic-powered front-end that drives the MCP server directly:
export ANTHROPIC_API_KEY=sk-ant-...
uvx --from mcp-deutsche-bahn mcp-deutsche-bahn-agent # interactive
uvx --from mcp-deutsche-bahn mcp-deutsche-bahn-agent "next trains out of Hamburg" # one-shot
Local development
git clone https://github.com/heykay/mcp-deutsche-bahn.git
cd mcp-deutsche-bahn
uv sync --extra dev
uv run pytest -m live # smoke tests, hit the real API
uv run ruff check .
Run the server in inspector mode to poke individual tools without an MCP client:
npx @modelcontextprotocol/inspector uv run mcp-deutsche-bahn
To point Claude Desktop at your local checkout (instead of the published package), use uv --directory /path/to/clone run mcp-deutsche-bahn as the command.
Roadmap
- v0.2: hosted/remote MCP variant (HTTP + SSE) for non-CLI users
- v0.2: richer strike signal — wire to a real news API
- v0.3: ticket-price comparison via DB API Marketplace
Contributing
PRs welcome. File issues with the query that broke and the JSON the tool returned.
License
MIT — see LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mcp_deutsche_bahn-0.1.1.tar.gz.
File metadata
- Download URL: mcp_deutsche_bahn-0.1.1.tar.gz
- Upload date:
- Size: 80.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
839aea71ad58473045d3c3d66e6b93eec2685a59ac33b9238e6a61a149a06d9a
|
|
| MD5 |
9b1838009cab54ad00cb097df78a37b1
|
|
| BLAKE2b-256 |
1e5afa6d567fdaa4c815560e500be5b8605d8d68867c1fcbfe9fc645990825ed
|
File details
Details for the file mcp_deutsche_bahn-0.1.1-py3-none-any.whl.
File metadata
- Download URL: mcp_deutsche_bahn-0.1.1-py3-none-any.whl
- Upload date:
- Size: 20.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ac34c2e278f80758197d54c6e3e5ca6759c3f502310235d8660f41d82ba8e66f
|
|
| MD5 |
93d988b38b7770ff698d1dd4185455da
|
|
| BLAKE2b-256 |
c02aaf54515e2e95b5bc0994965cbcb7e20b903a3ef1791423f9a74692c21a0b
|