mcp-belgium
Provides access to Wallonia GeoServices, including ArcGIS folder enumeration, service discovery, and layer queries for spatial data.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-belgiumfind trains from Brussels to Antwerp at 10am"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
mcp-belgium
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.
Why use it
one npm package
one MCP server entry in your client config
namespaced tools like
irail_*,statbel_*,best_*,kmi_*,urban_*, andurbis_*built-in catalog tools, resources, and a prompt so the LLM can discover the right Belgian domain before calling tools
explicit limitation surfaces when an upstream requires a key or has changed contract
Install
Run directly:
npx -y mcp-belgiumWith pnpm:
pnpm dlx mcp-belgiumGlobal install:
pnpm add -g mcp-belgium
mcp-belgiumDefault transport is stdio, which is what desktop MCP clients expect.
Claude Desktop
{
"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 server
What the LLM gets
Alongside the domain tools, mcp-belgium exposes a discovery layer:
belgium_catalog_overviewbelgium_list_domainsbelgium_describe_domainbelgium://catalogbelgium://catalog.jsonbelgium://domain/{domain}belgium_capability_guide
That means the LLM can:
inspect the Belgian domains available from this single MCP
see which domains are live, limited, or key-gated
understand what kind of data each domain provides
pick the right namespaced tool without guessing
Main domains
Prefix | Domain | Status | Auth | Main data |
| Belgian rail / iRail | Live | None | stations, connections, liveboards, vehicles, disruptions |
| Belgian mobility / SMOP | Live | None | intermodal trip planning, operators, GTFS references |
| STIB/MIVB Brussels transit | Live | API key | waiting times, stops, routes, service messages |
| Infrabel Open Data | Live | None | rail infrastructure datasets and records |
| Belgian company registry | Live | API key | enterprise search and company details |
| BeST Belgian addresses | Live | None | addresses, municipalities, streets, postal infos |
| Statbel | Live | None | population, CPI, employment, dataset search |
| IRCELINE air quality | Live | None | stations, live measurements, BelAQI, timeseries |
| Brussels Region open data | Live | None | datasets and records |
| Wallonia open data | Live | None | datasets and records |
| KMI / IRM GeoServer | Live | None | stations, hourly observations, WFS discovery |
| Wallonia GeoServices | Live | None | ArcGIS folders, services, layer queries |
| urban.brussels WFS | Live | None | feature types, schemas, GeoJSON features |
| URBIS public WMS | Live | None | WMS layer discovery and map URL generation |
| data.gov.be compatibility layer | Limited | None | explicit upstream-changed error surface |
| Datavindplaats compatibility layer | Limited | API key | explicit upstream limitation surface |
Docs / Wiki
The repo now includes a docs/ tree that works as a lightweight public wiki:
Local development
Requirements:
Node.js >= 22
pnpm >= 9
Setup:
pnpm install
pnpm run build
pnpm run test
pnpm run typecheckRun the aggregated server over stdio:
pnpm --filter mcp-belgium start:stdioRun it over Streamable HTTP:
MCP_TRANSPORT=http PORT_BELGIUM=3017 pnpm --filter mcp-belgium startRun the whole workspace:
docker compose up --buildMonorepo shape
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 validation
The 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.
Upstream caveats
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-stibrequiresSTIB_API_KEYmcp-kborequiresCBEAPI_KEYmcp-data-gov-bepreserves the old tool contract but returns an explicit upstream-changed errormcp-opendata-flanderspreserves the old tool contract but returns an explicit API-key limitation
Validation
Current workspace checks:
pnpm run buildpnpm run testpnpm run typecheckpnpm audit --prod
License
MIT. See LICENSE.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/lacausecrypto/mcp-belgium'
If you have feedback or need assistance with the MCP directory API, please join our Discord server