Server data from the Official MCP Registry
Single MCP server for Belgian public transport, statistics, open data, and geospatial services.
Single MCP server for Belgian public transport, statistics, open data, and geospatial services.
Valid MCP server (2 strong, 2 medium validity signals). No known CVEs in dependencies. ⚠️ Package registry links to a different repository than scanned source. Imported from the Official MCP Registry. 1 finding(s) downgraded by scanner intelligence.
14 files analyzed · 1 issue 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: STIB_API_KEY
Environment variable: CBEAPI_KEY
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-lacausecrypto-mcp-belgium": {
"env": {
"CBEAPI_KEY": "your-cbeapi-key-here",
"STIB_API_KEY": "your-stib-api-key-here"
},
"args": [
"-y",
"mcp-belgium"
],
"command": "npx"
}
}
}From the project's GitHub README.
One MCP server for Belgian public APIs.
mcp-belgium is the public entry point. It exposes a single aggregated MCP server that bundles Belgian transport, official statistics, open data, addresses, weather, air quality, and geospatial services behind one install and one client config entry.
The package is also prepared for publication to the official MCP Registry under io.github.lacausecrypto/mcp-belgium.
irail_*, statbel_*, best_*, kmi_*, urban_*, and urbis_*Run directly:
npx -y mcp-belgium
With pnpm:
pnpm dlx mcp-belgium
Global install:
pnpm add -g mcp-belgium
mcp-belgium
Default transport is stdio, which is what desktop MCP clients expect.
{
"mcpServers": {
"belgium": {
"command": "npx",
"args": [
"-y",
"mcp-belgium"
],
"env": {
"LOG_LEVEL": "silent"
}
}
}
}
Optional env vars:
STIB_API_KEY: enables live STIB/MIVB toolsCBEAPI_KEY: enables live KBO/BCE company registry toolsMCP_TRANSPORT=http: runs the server over Streamable HTTPPORT_BELGIUM=3017: sets the HTTP port for the aggregated serverAlongside the domain tools, mcp-belgium exposes a discovery layer:
belgium_catalog_overviewbelgium_list_domainsbelgium_describe_domainbelgium://catalogbelgium://catalog.jsonbelgium://domain/{domain}belgium_capability_guideThat means the LLM can:
| Prefix | Domain | Status | Auth | Main data |
|---|---|---|---|---|
irail_* | Belgian rail / iRail | Live | None | stations, connections, liveboards, vehicles, disruptions |
mobility_* | Belgian mobility / SMOP | Live | None | intermodal trip planning, operators, GTFS references |
stib_* | STIB/MIVB Brussels transit | Live | API key | waiting times, stops, routes, service messages |
infrabel_* | Infrabel Open Data | Live | None | rail infrastructure datasets and records |
kbo_* | Belgian company registry | Live | API key | enterprise search and company details |
best_* | BeST Belgian addresses | Live | None | addresses, municipalities, streets, postal infos |
statbel_* | Statbel | Live | None | population, CPI, employment, dataset search |
airquality_* | IRCELINE air quality | Live | None | stations, live measurements, BelAQI, timeseries |
brussels_* | Brussels Region open data | Live | None | datasets and records |
wallonia_* | Wallonia open data | Live | None | datasets and records |
kmi_* | KMI / IRM GeoServer | Live | None | stations, hourly observations, WFS discovery |
wallonia_geo_* | Wallonia GeoServices | Live | None | ArcGIS folders, services, layer queries |
urban_* | urban.brussels WFS | Live | None | feature types, schemas, GeoJSON features |
urbis_* | URBIS public WMS | Live | None | WMS layer discovery and map URL generation |
datagov_* | data.gov.be compatibility layer | Limited | None | explicit upstream-changed error surface |
flanders_* | Datavindplaats compatibility layer | Limited | API key | explicit upstream limitation surface |
The repo now includes a docs/ tree that works as a lightweight public wiki:
Requirements:
Setup:
pnpm install
pnpm run build
pnpm run test
pnpm run typecheck
Run the aggregated server over stdio:
pnpm --filter mcp-belgium start:stdio
Run it over Streamable HTTP:
MCP_TRANSPORT=http PORT_BELGIUM=3017 pnpm --filter mcp-belgium start
Run the whole workspace:
docker compose up --build
packages/core: shared HTTP, retry, cache, rate limiting, XML helpers, and MCP response helperspackages/mcp-belgium: public aggregated entry pointpackages/mcp-*: domain-specific packages kept modular for maintenance, testing, and isolated validationThe public consumer path is mcp-belgium. Internal workspace packages stay modular for development, but the published mcp-belgium package bundles them so end users install only one npm package.
This project wraps public upstream APIs. Some Belgian portals change authentication or endpoint contracts over time. When an upstream is no longer publicly compatible, this project prefers explicit, machine-readable limitation errors over silent failure.
Current examples:
mcp-stib requires STIB_API_KEYmcp-kbo requires CBEAPI_KEYmcp-data-gov-be preserves the old tool contract but returns an explicit upstream-changed errormcp-opendata-flanders preserves the old tool contract but returns an explicit API-key limitationCurrent workspace checks:
pnpm run buildpnpm run testpnpm run typecheckpnpm audit --prodMIT. See LICENSE.
Be the first to review this server!
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.
by Taylorwilsdon · Productivity
Control Gmail, Calendar, Docs, Sheets, Drive, and more from your AI