BAKOM telecommunications and media open data
Valid MCP server (1 strong, 4 medium validity signals). No known CVEs in dependencies. Package registry verified. Imported from the Official MCP Registry.
3 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.
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-malkreide-bakom-mcp": {
"args": [
"bakom-mcp"
],
"command": "uvx"
}
}
}From the project's GitHub README.
๐จ๐ญ Part of the Swiss Public Data MCP Portfolio
MCP server for BAKOM open data โ broadband, mobile coverage, media and Swiss telecom statistics.
bakom-mcp connects AI assistants like Claude to the Swiss Federal Office of Communications (BAKOM) open data infrastructure. It enables natural-language queries about broadband availability, 5G/4G coverage, mobile antenna locations, licensed broadcasters (RTV database), and telecommunications statistics โ all without API keys.
All data is published as Open Government Data (OGD) on opendata.swiss / geo.admin.ch under CC BY 4.0 โ see the Data Licence section below for attribution requirements.
Anchor demo query: "Which school buildings in district 7 do not yet have fibre optic connectivity?"
bakom_multi_standort_konnektivitaetdelivers the comparison table automatically.
โ More use cases by audience โ
โ Read-only queries against three public BAKOM/Confederation APIs:
api3.geo.admin.ch / wms.geo.admin.ch (broadband, mobile coverage, antennas)ckan.opendata.swiss (telecom statistics, dataset metadata)rtvdb.ofcomnet.ch (licensed radio/TV broadcasters)โ Returns aggregated, anonymous data โ no personal data, no household-level identification.
โ Bound to Swiss WGS84 coordinates (lat 45.8โ47.9, lon 5.9โ10.6) via Pydantic input validation.
โ Egress is locked to a code-layer allow-list of the six known data-source hosts.
โ Send data anywhere (read-only, no write tools).
โ Access the local filesystem (no path-traversal surface).
โ Use authentication tokens (none required โ all sources are public OGD).
โ Cache or persist user inputs across calls.
โ Execute shell commands or arbitrary code (no subprocess/os.system/eval).
uv or pip for installation# Recommended: uvx (no permanent installation required)
uvx bakom-mcp
# Or install with pip
pip install bakom-mcp
# Development install
git clone https://github.com/malkreide/bakom-mcp
cd bakom-mcp
pip install -e ".[dev]"
Add to claude_desktop_config.json:
{
"mcpServers": {
"bakom": {
"command": "uvx",
"args": ["bakom-mcp"]
}
}
}
Config file locations:
~/Library/Application Support/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.jsonpython -m bakom_mcp.server --http
# Server running at http://localhost:8050/mcp
Configuration via environment variables (see .env.example):
| Variable | Default | Purpose |
|---|---|---|
BAKOM_MCP_HOST | 127.0.0.1 | Bind address. Set to 0.0.0.0 only on trusted networks (warning logged). |
BAKOM_MCP_PORT | 8050 | TCP port. |
BAKOM_MCP_CORS_ORIGINS | (empty) | Comma-separated allowed origins for browser clients. Empty = CORS disabled. |
A hardened container image is provided. Suitable for cloud deployments behind a reverse proxy (Caddy, Traefik, nginx).
# Build & run via compose (recommended)
docker compose up --build
# Or via docker run
docker build -t bakom-mcp:latest .
docker run --rm \
--read-only \
--cap-drop=ALL \
--security-opt=no-new-privileges \
--tmpfs /tmp:rw,size=16M \
-p 127.0.0.1:8050:8050 \
bakom-mcp:latest
The image runs as non-root (UID 10001), uses a read-only filesystem, drops all Linux capabilities and refuses privilege escalation. Resource limits are configured in docker-compose.yml (256 MB memory, 0.5 CPU, 64 PIDs). The default port mapping binds to 127.0.0.1 only โ for public exposure, terminate TLS and CORS at a reverse proxy.
{
"bakom": {
"command": "uvx",
"args": ["bakom-mcp"],
"transport": "stdio"
}
}
๐ก "stdio for the developer laptop, HTTP/SSE for the browser."
| Tool | Description |
|---|---|
bakom_broadband_coverage | Fixed-line coverage at a coordinate (30โ1000 Mbit/s) |
bakom_glasfaser_verfuegbarkeit | FTTB/FTTH fibre availability |
bakom_multi_standort_konnektivitaet | Connectivity comparison for up to 20 locations |
| Tool | Description |
|---|---|
bakom_mobilfunk_abdeckung | 5G/4G/3G outdoor coverage |
bakom_sendeanlagen_suche | Mobile antennas within a configurable radius |
bakom_frequenzdaten | Radio/TV transmitter sites near a location |
| Tool | Description |
|---|---|
bakom_rtv_suche | Search licensed broadcasters (RTV database) |
bakom_medienstruktur_info | Swiss media landscape datasets |
bakom_aktuell | Current BAKOM topics (5G, media, AI, postal) |
| Tool | Description |
|---|---|
bakom_telekomstatistik_uebersicht | Telecom statistics from opendata.swiss |
bakom_breitbandatlas_datensaetze | Full catalogue of Broadband Atlas layers |
bakom_check_api_status | ๐ Health check for all configured data sources |
What is the broadband situation at Schulhaus Leutschenbach (47.4148, 8.5654)?
Compare 5G and fibre coverage for these three school buildings: [coordinates]
Which radio stations are licensed in canton Zurich?
Show me the current BAKOM position on 5G frequency allocation.
List all Broadband Atlas datasets available via geo.admin.ch.
| Aspect | Details |
|---|---|
| Access | Read-only (readOnlyHint: true) โ the server cannot modify or delete any data |
| Personal data | No personal data โ all sources are aggregated, public open data |
| Rate limits | Built-in per-query caps (max 50 antennas, max 20 locations, max 50 RTV results) |
| Timeout | 20 seconds per API call |
| Authentication | No API keys required โ all 3 APIs are publicly accessible |
| Licences | All data under CC0 / open licences (Open Government Data) |
| Terms of Service | Subject to ToS of the respective data sources: geo.admin.ch, opendata.swiss, rtvdb.ofcomnet.ch |
| Source | Data | Authentication |
|---|---|---|
| geo.admin.ch | Broadband Atlas, mobile coverage, antenna locations | None |
| opendata.swiss | BAKOM datasets, telecom statistics | None |
| rtvdb.ofcomnet.ch | Licensed radio/TV broadcasters | None |
All data is published under open licences (CC0 / OGD).
bakom-mcp can be combined with other servers in the portfolio for multi-dimensional queries:
zurich-opendata-mcp โ school building addresses
+
bakom-mcp โ fibre and 5G status
=
"Digital equity" dashboard for all school districts
Further combinations:
srgssr-mcp + bakom-mcp โ Media coverage and broadcast networkswiss-statistics-mcp + bakom-mcp โ Telecom market developmentfedlex-mcp + bakom-mcp โ Regulatory context (RTVG, FMG)bakom-mcp/
โโโ src/bakom_mcp/
โ โโโ __init__.py # Package
โ โโโ server.py # MCP server (12 tools, 2 resources)
โ โโโ py.typed # PEP 561 type marker
โโโ tests/
โ โโโ test_integration.py # Integration tests (live APIs)
โโโ assets/
โ โโโ demo.svg # Demo flow diagram
โโโ .github/workflows/
โ โโโ ci.yml # CI: lint, syntax, import, tests
โ โโโ publish.yml # PyPI publish on release
โโโ .gitignore
โโโ pyproject.toml # Build config (hatchling)
โโโ CHANGELOG.md
โโโ CONTRIBUTING.md # Contribution guide (English)
โโโ CONTRIBUTING.de.md # Contribution guide (German)
โโโ SECURITY.md # Security policy (English)
โโโ SECURITY.de.md # Security policy (German)
โโโ LICENSE # MIT License
โโโ README.md # This file (English)
โโโ README.de.md # German version
# Unit tests (no network required)
PYTHONPATH=src pytest tests/ -m "not live"
# Integration tests (live APIs, internet required)
PYTHONPATH=src pytest tests/ -m "live"
See CHANGELOG.md
Contributions are welcome! See CONTRIBUTING.md (๐ฉ๐ช Deutsch) for guidelines on reporting bugs, suggesting features, and submitting pull requests.
To report a vulnerability, see the Security Policy (๐ฉ๐ช Deutsch). Please report security issues privately via GitHub Security Advisories rather than public issues.
MIT License โ see LICENSE.
The BAKOM open data delivered through this server is published under CC BY 4.0. When using or redistributing tool outputs, attribute the source as:
Source: Federal Office of Communications (BAKOM) via opendata.swiss / geo.admin.ch ยท Licence: CC BY 4.0
Tool outputs already include this footer automatically. The Markdown response format ends with the attribution line; downstream applications that consume the JSON format should propagate the source/licence metadata to their end users.
Hayal Oezkan ยท github.com/malkreide
Part of the Swiss Open Data MCP portfolio โ public data deserves public interfaces.
Run via uv's uvx โ no clone or manual install needed. Add to your MCP client config (mcpServers for Claude Desktop, Cursor and Windsurf; use a top-level servers key for VS Code in .vscode/mcp.json):
{
"mcpServers": {
"bakom-mcp": {
"command": "uvx",
"args": [
"bakom-mcp"
]
}
}
}
Be the first to review this server!
by Modelcontextprotocol ยท Developer Tools
Web content fetching and conversion for efficient LLM usage
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.