BPS MCP Server

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.

Category
Visit Server

README

BPS MCP Server

CI License: MIT Node.js

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

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:

Deploy to Cloudflare Workers

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

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured