Switzerland MCP ๐จ๐ญ
Swiss open data โ trains, weather, hydrology, geodata, companies. 23 tools, zero API keys.
Ask AI about Switzerland MCP ๐จ๐ญ
Powered by Claude ยท Grounded in docs
I know everything about Switzerland MCP ๐จ๐ญ. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
mcp-swiss
Swiss open data for AI โ zero config, zero API keys
Install ยท Tools ยท Demo ยท Data Sources
mcp-swiss is a Model Context Protocol server that gives any AI assistant direct access to Swiss open data โ trains, weather, rivers, maps, and companies.
68 tools. No API keys. No registration. No server to run. Just npx mcp-swiss.
๐ Transport โ SBB, PostBus, trams, live departures, journey planning
๐ค๏ธ Weather โ MeteoSwiss live conditions + historical data
๐ Hydrology โ BAFU river & lake levels (great for Aare swimming!)
๐บ๏ธ Geodata โ swisstopo geocoding, solar potential, geographic layers
๐ข Companies โ ZEFIX federal registry, all 700K+ Swiss companies
๐ Holidays โ Swiss public & school holidays by canton
๐๏ธ Parliament โ Bills, votes, councillors, session schedule
๐๏ธ Avalanche โ SLF danger bulletins and warning regions
๐จ Air Quality โ NABEL stations, Swiss legal limits (LRV)
๐ฎ Swiss Post โ Postcode lookup and parcel tracking
โก Energy โ Electricity tariffs by municipality (ElCom)
๐ Statistics โ Population, demographics, BFS datasets
๐ฆ SNB Rates โ Swiss National Bank CHF exchange rates, historical data
โป๏ธ Recycling โ Zurich city waste collection calendar (OpenERZ)
๐ฐ Swiss News โ SRF news headlines and keyword search
๐ณ๏ธ Voting โ Swiss popular vote results (Basel-Stadt open data)
๐ Dams โ Swiss federal dam registry (SFOE/swisstopo)
๐ฅพ Hiking โ Swiss trail closures and hiking alerts (swisstopo)
๐ Real Estate โ Swiss property prices, rent index, housing data (BFS)
๐ Traffic โ ASTRA counting stations, daily volumes
๐ Earthquakes โ Swiss Seismological Service (SED/ETH Zรผrich), FDSN API
Installation
Quick Start
npx mcp-swiss
That's it. No API keys, no .env files, no accounts. Pick your client below and paste the config.
One-Click Install (.mcpb)
.mcpb bundles work with Claude Desktop and any MCP Bundle-compatible app.
Open the downloaded file โ your app handles the rest. No config editing, no terminal, no API keys.
Claude Desktop
Edit your config file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
{
"mcpServers": {
"swiss": {
"command": "npx",
"args": ["-y", "mcp-swiss"]
}
}
}
Restart Claude Desktop after saving.
Claude Code (CLI)
claude mcp add swiss -- npx -y mcp-swiss
That's it โ Claude Code will use it in your next session.
Cursor
Requires Cursor 0.45.6+
Option A: Project config โ create .cursor/mcp.json in your project root:
{
"mcpServers": {
"swiss": {
"command": "npx",
"args": ["-y", "mcp-swiss"]
}
}
}
Option B: Global config โ create ~/.cursor/mcp.json:
{
"mcpServers": {
"swiss": {
"command": "npx",
"args": ["-y", "mcp-swiss"]
}
}
}
Option C: Via Cursor Settings UI
- Open Cursor Settings
- Go to Features โ MCP Servers
- Click + Add new global MCP server
- Paste the JSON config above
VS Code (GitHub Copilot)
One-click Install
CLI Install
# VS Code
code --add-mcp '{"name":"swiss","command":"npx","args":["-y","mcp-swiss"]}'
# VS Code Insiders
code-insiders --add-mcp '{"name":"swiss","command":"npx","args":["-y","mcp-swiss"]}'
Manual Config
Add to your VS Code User Settings (JSON) โ press Ctrl+Shift+P โ Preferences: Open User Settings (JSON):
{
"mcp": {
"servers": {
"swiss": {
"command": "npx",
"args": ["-y", "mcp-swiss"]
}
}
}
}
Or add to .vscode/mcp.json in your workspace (shareable with your team):
{
"servers": {
"swiss": {
"command": "npx",
"args": ["-y", "mcp-swiss"]
}
}
}
Windsurf
Add to ~/.codeium/windsurf/model_config.json:
{
"mcpServers": {
"swiss": {
"command": "npx",
"args": ["-y", "mcp-swiss"]
}
}
}
Cline (VS Code)
Open VS Code settings.json and add:
{
"cline.mcpServers": {
"swiss": {
"command": "npx",
"args": ["-y", "mcp-swiss"]
}
}
}
Any MCP Client
mcp-swiss uses stdio transport and requires no environment variables. The universal config:
{
"command": "npx",
"args": ["-y", "mcp-swiss"]
}
This works with any MCP-compatible client โ just plug it in.
Docker
docker pull vikramgorla/mcp-swiss
Use with any MCP client that supports Docker-based servers. The container uses stdio transport:
# Run directly (stdio)
docker run -i vikramgorla/mcp-swiss
# Use with Claude Desktop
For Claude Desktop, update your config to use Docker:
{
"mcpServers": {
"swiss": {
"command": "docker",
"args": ["run", "-i", "--rm", "vikramgorla/mcp-swiss"]
}
}
}
Also available on GitHub Container Registry:
docker pull ghcr.io/vikramgorla/mcp-swiss
Demo Prompts
Once connected, try asking your AI:
| Prompt | What it uses |
|---|---|
| "Next 5 trains from Zรผrich HB to Geneva" | get_connections |
| "Is the Aare in Bern warm enough to swim?" | get_water_level |
| "Weather in Lugano vs Zรผrich today" | get_weather |
| "Find blockchain companies registered in Zug" | search_companies |
| "Solar potential of Bundesplatz 3, Bern" | geocode + get_solar_potential |
| "Live departures from Bern HB" | get_departures |
| "What rivers are near Thun?" | list_hydro_stations + get_water_level |
| "Plan my Saturday: train to Interlaken, check weather" | Multiple tools chained |
| "Is next Monday a holiday in Zรผrich?" | get_public_holidays |
| "What did the Swiss parliament vote on recently?" | get_latest_votes |
| "What's the avalanche danger level in the Bernese Alps?" | get_avalanche_bulletin |
| "What's the postcode for Zermatt?" | search_postcode |
| "Track my Swiss Post parcel 99.12.345678.12345678" | track_parcel |
| "How much does electricity cost in Zรผrich vs Basel?" | search_municipality_energy + compare_electricity_tariffs |
| "What's the population of canton Zug?" | get_population |
Tools
68 tools across 20 modules. Full specifications:
docs/tool-specs.mdยท Machine-readable:docs/tools.schema.json
๐ Transport (5 tools)
| Tool | Description |
|---|---|
search_stations | Find stations/stops by name or location |
get_connections | Journey planner between any two points |
get_departures | Live departures from a station |
get_arrivals | Live arrivals at a station |
get_nearby_stations | Stations near coordinates |
๐ค๏ธ Weather & Hydrology (6 tools)
| Tool | Description |
|---|---|
get_weather | Current conditions at a MeteoSwiss station |
list_weather_stations | All ~160 MeteoSwiss stations with metadata |
get_weather_history | Historical weather data (up to 32 days) |
get_water_level | River/lake level + temperature (BAFU) |
list_hydro_stations | All 400+ hydrological monitoring stations |
get_water_history | Historical hydrology data |
๐บ๏ธ Geodata / swisstopo (6 tools)
| Tool | Description |
|---|---|
geocode | Swiss address โ coordinates |
reverse_geocode | Coordinates โ Swiss address |
search_places | Swiss place names, mountains, lakes, features |
get_solar_potential | Rooftop solar irradiation at a location |
identify_location | All geographic data layers at a point |
get_municipality | Municipality info by name |
๐ข Companies / ZEFIX (5 tools)
| Tool | Description |
|---|---|
search_companies | Search by name, canton, legal form |
get_company | Full company details by ZEFIX ehraid |
search_companies_by_address | Companies registered at an address |
list_cantons | All 26 Swiss cantons |
list_legal_forms | AG, GmbH, and all Swiss legal forms |
๐ Holidays (3 tools)
| Tool | Description |
|---|---|
get_public_holidays | Swiss public holidays by year, optionally filtered by canton |
get_school_holidays | School holiday periods by year and canton |
is_holiday_today | Quick check if today is a public holiday |
๐๏ธ Parliament (4 tools)
| Tool | Description |
|---|---|
search_parliament_business | Search bills, motions, interpellations |
get_latest_votes | Recent parliamentary vote results |
search_councillors | Find members of the National/States Council |
get_sessions | Parliamentary session schedule |
๐๏ธ Avalanche (2 tools)
| Tool | Description |
|---|---|
get_avalanche_bulletin | Current avalanche bulletin with danger levels and PDF links |
list_avalanche_regions | All 22 Swiss avalanche warning regions |
๐จ Air Quality (2 tools)
| Tool | Description |
|---|---|
list_air_quality_stations | All 14 NABEL monitoring stations |
get_air_quality | Station info, Swiss legal limits (LRV), and BAFU data links |
๐ฎ Swiss Post (4 tools)
| Tool | Description |
|---|---|
lookup_postcode | PLZ โ locality, canton, coordinates |
search_postcode | City name โ matching postcodes |
list_postcodes_in_canton | All postcodes in a canton |
track_parcel | Generate Swiss Post tracking URL for a parcel |
โก Energy Prices (3 tools)
| Tool | Description |
|---|---|
get_electricity_tariff | Electricity tariff by municipality with component breakdown |
compare_electricity_tariffs | Compare electricity prices across municipalities |
search_municipality_energy | Find municipality ID for tariff lookup |
๐ Statistics / BFS (3 tools)
| Tool | Description |
|---|---|
get_population | Population by canton or municipality from BFS STATPOP |
search_statistics | Search BFS datasets on opendata.swiss |
get_statistic | Fetch detailed dataset information |
๐ฆ SNB Exchange Rates (3 tools)
| Tool | Description |
|---|---|
list_currencies | List all currencies available from the Swiss National Bank (SNB) |
get_exchange_rate | Get the current CHF exchange rate for any currency |
get_exchange_rate_history | Get historical monthly CHF exchange rates with date filtering |
โป๏ธ Recycling / Waste Collection (3 tools)
| Tool | Description |
|---|---|
get_waste_collection | Next waste collection dates by Zurich ZIP code and waste type |
list_waste_types | List all supported waste types with descriptions |
get_waste_calendar | Full waste collection calendar for a ZIP code (upcoming dates) |
๐ฐ Swiss News (2 tools)
| Tool | Description |
|---|---|
get_swiss_news | Latest Swiss headlines from SRF by category (Switzerland/international/economy) |
search_swiss_news | Search SRF news by keyword across all categories |
๐ณ๏ธ Voting (3 tools)
| Tool | Description |
|---|---|
get_voting_results | Swiss popular vote results from Basel-Stadt open data |
search_votes | Search popular votes by keyword (German/French/Italian) |
get_vote_details | Detailed per-district breakdown of a specific vote |
๐ Dams & Reservoirs (3 tools)
| Tool | Description |
|---|---|
search_dams | Search Swiss federal dams by name or keyword |
get_dams_by_canton | List all federal dams in a canton |
get_dam_details | Detailed info on a specific dam (height, volume, purpose) |
๐ฅพ Hiking / Trail Closures (2 tools)
| Tool | Description |
|---|---|
get_trail_closures | Swiss trail closures and hiking alerts from swisstopo |
get_trail_closures_nearby | Trail closures near given coordinates |
๐ Real Estate (3 tools)
| Tool | Description |
|---|---|
get_property_price_index | Swiss property price index (BFS Immo-Monitoring) |
search_real_estate_data | Search BFS real estate datasets on opendata.swiss |
get_rent_index | Swiss rent index and housing cost data from BFS |
๐ Traffic / ASTRA (3 tools)
| Tool | Description |
|---|---|
get_traffic_count | Traffic counting station data (ASTRA) โ daily volumes and heavy traffic share |
get_traffic_by_canton | List ASTRA traffic counting stations filtered by canton |
get_traffic_nearby | Find traffic counting stations near given coordinates |
๐ Earthquakes / SED (3 tools)
| Tool | Description |
|---|---|
get_recent_earthquakes | Recent seismic events in/around Switzerland from the Swiss Seismological Service (SED) at ETH Zรผrich |
get_earthquake_details | Full details for a specific seismic event by SED event ID |
search_earthquakes_by_location | Earthquakes near given coordinates with configurable radius, time range, and limit |
Data Sources
All official Swiss open data โ no API keys required:
| Source | Data | Docs |
|---|---|---|
| transport.opendata.ch | SBB, PostBus, trams | API docs |
| api.existenz.ch | MeteoSwiss weather + BAFU hydrology | API docs |
| api3.geo.admin.ch | swisstopo federal geodata | API docs |
| zefix.admin.ch | Federal company registry | Swagger |
| openholidaysapi.org | Swiss public & school holidays | API docs |
| ws.parlament.ch | Swiss Parliament OData (bills, votes, councillors) | OData docs |
| whiterisk.ch / aws.slf.ch | SLF/WSL avalanche bulletins | SLF |
| geo.admin.ch โ BAFU/NABEL | Swiss air quality monitoring stations | BAFU NABEL |
| geo.admin.ch โ swisstopo | Swiss postcodes (Amtliches Ortschaftenverzeichnis) | geo.admin.ch |
| strompreis.elcom.admin.ch | ElCom electricity tariffs by municipality | ElCom |
| pxweb.bfs.admin.ch + opendata.swiss | BFS population statistics (STATPOP) + datasets | BFS |
| data.snb.ch | Swiss National Bank CHF exchange rates | SNB data portal |
| openerz.metaodi.ch | Zurich waste collection calendar (OpenERZ) | OpenERZ |
| srf.ch | SRF Swiss news headlines | SRF |
| data.bs.ch | Basel-Stadt popular vote results | Open Data BS |
| geo.admin.ch โ SFOE | Swiss federal dam registry | SFOE |
| geo.admin.ch โ swisstopo | Swiss trail closures and hiking alerts | swisstopo |
| pxweb.bfs.admin.ch | BFS property prices + rent index | BFS housing |
| geo.admin.ch โ ASTRA | Traffic counting stations + daily volumes | ASTRA |
| arclink.ethz.ch | Swiss Seismological Service earthquakes (SED/ETH) | SED |
Development
# Clone
git clone https://github.com/vikramgorla/mcp-swiss.git
cd mcp-swiss
# Install deps
npm install
# Build
npm run build
# Run in dev mode
npm run dev
# Test with MCP Inspector
npx @modelcontextprotocol/inspector node dist/index.js
Testing
npm test
Contributing
We welcome contributions! mcp-swiss follows a strict PR-based workflow to keep the codebase clean and CI always green.
Quick links
-
CONTRIBUTING.mdโ full contributor guide:- Development setup (clone, install, build, test)
- Branch model (develop / main / feature branches)
- Hard workflow rules (no direct pushes, always PRs, regular merge only)
- Adding a new module (step-by-step with code templates)
- Integration checklist (all files to update)
- Code standards (TypeScript, no
any, 50K response limit, zero API keys)
-
RELEASING.mdโ release process for maintainers:- Step-by-step release workflow
- Pre-release checklist
- Version strategy (minor for features, patch for fixes)
- Post-release verification
- CI/CD workflow reference (
ci.yml,release.yml,beta.yml,mcp-registry.yml)
Requirements
- Node.js 20+
- No API keys or accounts needed
License
MIT โ see LICENSE
