BPS MCP Server
Enables AI clients to access official Indonesian statistical data from Badan Pusat Statistik (BPS) through natural language queries. It provides over 20 tools for retrieving demographic, economic, and trade data with support for bilingual responses and fuzzy domain matching.
README
BPS MCP Server
MCP (Model Context Protocol) server untuk data statistik BPS (Badan Pusat Statistik) Indonesia. Memungkinkan AI clients seperti Claude Desktop, Claude Code, Cursor, dan lainnya untuk mengakses data statistik resmi Indonesia melalui natural language.
Fitur
- 32 tools mencakup seluruh endpoint BPS API v1
- 3 MCP Resources — domain list, kabupaten per provinsi, subjek per domain
- 5 MCP Prompts — template analisis data siap pakai
- Domain resolver dengan fuzzy matching (ketik "Jatim" → Jawa Timur)
- Data formatter yang mengubah raw BPS data menjadi format mudah dibaca
- In-memory cache dengan TTL per tipe data
- Bilingual — mendukung bahasa Indonesia dan Inggris
- Atribusi BPS otomatis di setiap response (sesuai ToU)
- BYOK (Bring Your Own Key) — setiap user menggunakan API key BPS sendiri
Prasyarat
- Node.js ≥ 18
- API key BPS (gratis, daftar di webapi.bps.go.id)
Instalasi & Penggunaan
Via npx (recommended)
BPS_API_KEY=your_key npx bps-mcp-server
Clone & Run
git clone https://github.com/murphi/bps-mcp-server
cd bps-mcp-server
npm install
npm run build
BPS_API_KEY=your_key npm start
Akses Remote via Cloudflare Workers
Server ini tersedia secara publik di:
https://bps-mcp-server.murphi.my.id/mcp
Tambahkan ke MCP client manapun (Claude Desktop, Cursor, dll.) via remote transport:
{
"mcpServers": {
"bps-statistics": {
"type": "http",
"url": "https://bps-mcp-server.murphi.my.id/mcp",
"headers": {
"X-BPS-API-Key": "your_api_key_here"
}
}
}
}
Self-hosted
Ingin deploy sendiri? Deploy sebagai serverless worker di akun Cloudflare kamu:
Lihat panduan lengkap di docs/DEPLOY-WORKERS.md.
Konfigurasi MCP Client
Claude Desktop
File: ~/Library/Application Support/Claude/claude_desktop_config.json (macOS)
{
"mcpServers": {
"bps-statistics": {
"command": "npx",
"args": ["-y", "bps-mcp-server"],
"env": {
"BPS_API_KEY": "your_api_key_here"
}
}
}
}
Claude Code
claude mcp add bps -- npx -y bps-mcp-server
Atau file .mcp.json di project root:
{
"mcpServers": {
"bps": {
"command": "npx",
"args": ["-y", "bps-mcp-server"],
"env": {
"BPS_API_KEY": "${BPS_API_KEY}"
}
}
}
}
Cursor / VS Code
File ~/.cursor/mcp.json atau .vscode/mcp.json:
{
"mcpServers": {
"bps-statistics": {
"command": "npx",
"args": ["-y", "bps-mcp-server"],
"env": {
"BPS_API_KEY": "your_api_key_here"
}
}
}
}
Tools (32)
| Tool | Deskripsi |
|---|---|
list_domains |
Daftar wilayah (provinsi, kab/kota) |
resolve_domain |
Konversi nama wilayah → kode domain (fuzzy matching) |
list_subjects |
Daftar subjek data statistik |
list_subject_categories |
Kategori subjek |
list_variables |
Daftar variabel tabel dinamis |
list_vertical_variables |
Variabel vertikal (disagregasi) |
list_derived_variables |
Turunan variabel |
list_periods |
Periode data tersedia |
list_derived_periods |
Turunan periode |
list_units |
Satuan data |
get_dynamic_data |
Core — Ambil data tabel dinamis |
list_static_tables |
Daftar tabel statis |
get_static_table |
Detail tabel statis (HTML) |
list_press_releases |
Daftar Berita Resmi Statistik (BRS) |
get_press_release |
Detail BRS |
list_publications |
Daftar publikasi |
get_publication |
Detail publikasi |
list_strategic_indicators |
Indikator strategis |
get_trade_data |
Data ekspor/impor berdasarkan kode HS |
list_infographics |
Daftar infografis BPS |
get_infographic |
Detail infografis |
list_news |
Daftar berita BPS |
get_news |
Detail berita |
list_census_events |
Daftar kegiatan sensus |
list_census_topics |
Topik data per kegiatan sensus |
list_csa_categories |
Kategori CSA |
list_csa_subjects |
Subjek CSA per domain |
list_csa_tables |
Tabel CSA per subjek |
get_csa_table |
Detail tabel CSA (HTML) |
list_glossary |
Glosarium istilah statistik |
search |
Pencarian lintas tipe |
cache_clear |
Bersihkan cache |
Resources (3)
| URI | Deskripsi |
|---|---|
bps://domains/provinces |
Daftar seluruh provinsi Indonesia (cached) |
bps://domains/regencies/{prov_id} |
Kabupaten/kota per provinsi |
bps://subjects/{domain} |
Subjek statistik per domain |
Prompts (5)
| Prompt | Deskripsi |
|---|---|
compare_regions |
Bandingkan data antara dua wilayah |
trend_analysis |
Analisis tren data multi-tahun |
poverty_profile |
Profil kemiskinan suatu wilayah |
economic_overview |
Ringkasan ekonomi wilayah |
population_stats |
Statistik kependudukan |
Contoh Query
"Berapa jumlah penduduk Indonesia tahun 2023?"
"Bandingkan angka kemiskinan Jawa Timur vs Jawa Barat 2020-2023"
"Cari BRS terbaru tentang inflasi"
"Data ekspor kopi Indonesia tahun 2024"
Environment Variables
| Variable | Default | Deskripsi |
|---|---|---|
BPS_API_KEY |
(required) | API key dari webapi.bps.go.id |
BPS_API_BASE_URL |
https://webapi.bps.go.id/v1 |
Base URL API |
BPS_DEFAULT_LANG |
ind |
Bahasa default: ind / eng |
BPS_DEFAULT_DOMAIN |
0000 |
Domain default (0000 = Nasional) |
BPS_CACHE_ENABLED |
true |
Aktifkan cache |
BPS_CACHE_MAX_ENTRIES |
500 |
Maks entri cache |
BPS_LOG_LEVEL |
info |
Level log: debug/info/warn/error |
Development
git clone https://github.com/murphi/bps-mcp-server
cd bps-mcp-server
npm install
npm run build
npm run test:unit
Atribusi
Sumber: Badan Pusat Statistik (BPS) — https://www.bps.go.id Layanan ini menggunakan API Badan Pusat Statistik (BPS).
Lisensi
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.