Skip to main content

MCP server for Estonian public transport timetables, trip planning, and real-time vehicle tracking

Project description

Estonian Transport MCP

An MCP server for Estonian public transport — timetables, trip planning, stop search, and real-time vehicle tracking.

Tools

Tool Description
search_stops Search for stops by name (e.g. "Viru", "Balti jaam")
get_departures Get upcoming departures from a stop, with real-time predictions
plan_trip Plan a trip between two coordinates with date/time options
nearby_stops Find stops within a radius of a location
get_route Get route details including all stop patterns
tallinn_vehicles Real-time GPS positions of Tallinn buses, trams, and trolleybuses

Prerequisites

This server runs via uvx, a zero-install Python package runner. Install uv first:

# macOS / Linux
curl -LsSf https://astral.sh/uv/install.sh | sh

# Windows
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"

# or via Homebrew
brew install uv

No other setup needed — uvx automatically downloads dependencies on first run.

Usage

Claude Code

Add to your MCP settings (.claude/settings.json or project-level .mcp.json):

{
  "mcpServers": {
    "estonian-transport": {
      "command": "uvx",
      "args": ["estonian-transport-mcp"]
    }
  }
}

Claude Desktop

Config file location:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json

Add to the mcpServers section:

{
  "mcpServers": {
    "estonian-transport": {
      "command": "uvx",
      "args": ["estonian-transport-mcp"]
    }
  }
}

Note: Claude Desktop may not find uvx in its PATH. If the server fails to start, replace "uvx" with the full path. Find it by running which uvx in your terminal, then use that path:

{
  "mcpServers": {
    "estonian-transport": {
      "command": "/Users/yourname/.local/bin/uvx",
      "args": ["estonian-transport-mcp"]
    }
  }
}

Restart Claude Desktop after saving the config.

Manual testing

uvx estonian-transport-mcp

Or test interactively with the MCP Inspector:

npx @modelcontextprotocol/inspector uvx estonian-transport-mcp

Data Sources & APIs

Peatus.ee — OpenTripPlanner GraphQL API

  • Endpoint: https://api.peatus.ee/routing/v1/routers/estonia/index/graphql
  • Protocol: GraphQL over HTTP POST
  • Authentication: None (open access)
  • Maintained by: Transpordiamet (Estonian Transport Administration)
  • Coverage: All Estonian public transport — buses, trams, trolleybuses, trains, and ferries nationwide
  • Data: Stop search, departure times, trip planning, route patterns, real-time arrival predictions
  • Based on: OpenTripPlanner with Digitransit
  • Underlying data: National GTFS feed consolidated from all Estonian transport operators

Used by tools: search_stops, get_departures, plan_trip, nearby_stops, get_route

Tallinn Transport — Real-Time Vehicle GPS

  • Endpoint: https://transport.tallinn.ee/gps.txt
  • Protocol: Plain-text CSV over HTTP GET
  • Authentication: None (open access)
  • Update frequency: ~10 seconds
  • Coverage: Tallinn city only — buses, trams, and trolleybuses operated by TLT (Tallinna Linnatransport)
  • Data: Vehicle type, line number, GPS coordinates (WGS84 microdegrees), heading, vehicle ID, destination
  • Format: Each line is one vehicle: type,line,lon,lat,,heading,vehicle_id,status,unknown,destination
    • Vehicle types: 1 = trolleybus, 2 = bus, 3 = tram
    • Coordinates: integer microdegrees (divide by 1,000,000 for decimal degrees)
    • Heading 999 = unknown

Used by tools: tallinn_vehicles

Tech Stack

  • Python with FastMCP (mcp[cli])
  • httpx for async HTTP requests
  • Transport: stdio (standard MCP transport for local integrations)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

estonian_transport_mcp-1.0.1.tar.gz (64.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

estonian_transport_mcp-1.0.1-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file estonian_transport_mcp-1.0.1.tar.gz.

File metadata

  • Download URL: estonian_transport_mcp-1.0.1.tar.gz
  • Upload date:
  • Size: 64.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for estonian_transport_mcp-1.0.1.tar.gz
Algorithm Hash digest
SHA256 c976d6d998cfc1664e1fb8d660c2161e5bc04bdbbd3ffcef06679f8199a69748
MD5 57686e92399723b8ccbb6b6ba953a7d4
BLAKE2b-256 3949f9f6825b1c1f9064b54d6e53b3b17822a6515fc65456d3b439696861739d

See more details on using hashes here.

File details

Details for the file estonian_transport_mcp-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: estonian_transport_mcp-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for estonian_transport_mcp-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 961a70727858c32ec77e61564fa7606abfa95b458123568d48ccceacd707a47c
MD5 883210899120cc0780bdd3ad850b0039
BLAKE2b-256 10fa0615933ef41f0418f8f183aa57bf675c39f8a705754e0af6c39135272fec

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page