CCM
/MCP
SkillsMCPMarketplacesDigestLearnAdvertise

This week in Claude

Every Monday: Claude Code, Agent SDK, MCP, and the Anthropic platform moves worth your time.

Skills by Category
Frontend DevelopmentBackend & APIsTesting & QASecurityDevOps & CI/CDGit & Pull RequestsDocumentationCode Review & QualityAI & Agent BuildingSkill Development
MCP Servers by Category
Sales & MarketingWeb & Browser AutomationDatabasesAI & LLM ToolsCloud & InfrastructureCommunication & MessagingDeveloper ToolsDesign & CreativeDocuments & KnowledgeSearch & Web Crawling
Marketplaces by Category
AI Agents & OrchestrationLLM IntegrationDevelopment ToolsFrontend & UIBackend & APIsDatabasesTesting & Code QualityDevOps & CloudSecurity & ComplianceGit & Version Control

Claude Code Marketplaces

Discover Claude Code plugins, extensions, and tools. Automatically updated directory of Anthropic Claude AI marketplaces with development tools, productivity plugins, and integrations.

Resources

  • Browse Skills
  • Browse MCP Servers
  • Browse Marketplaces
  • Plugins Reference

Community

  • About
  • Learn
  • Feedback
  • Privacy Policy
  • Advertise

Built for the Claude Code community with Claude Code by @mertduzgun

Independent project, not affiliated with Anthropic

Global Education Mcp

malkreide/global-education-mcp
STDIOregistry active
Summary

Wraps UNESCO UIS and OECD Education at a Glance APIs into a single MCP interface with no authentication required. Exposes 4,000+ education indicators across all UNESCO member countries plus OECD's 38-country SDMX datasets. You get tools for indicator search, multi-country comparisons, country education profiles, and SDG-4 monitoring queries. Useful when you need to benchmark literacy rates, education expenditure as GDP percentage, enrollment ratios, or teacher salaries across countries without manually navigating two separate statistical databases. Ships with stdio transport for Claude Desktop and an SSE mode for browser deployments behind a reverse proxy.

CodeRabbit
CodeRabbit
AI writes the code. CodeRabbit catches the slop.
Try For Free →
Make your agent a DeFi expert
Make your agent a DeFi expert
Agent, run crypto. Access onchain data & trade routes via 1inch.
Install now →
AppSignal
AppSignal
Monitor with ease. Code with confidence.
Start Free Trial →
Make money from your Skills
Make money from your Skills
On Capafy, your Skill runs online 24/7 as an agent product, and you get paid every time someone uses it.
Start earning →
Put your SEO on autopilot
Put your SEO on autopilot
An agent that runs the SEO playbooks that move rankings and ships PRs you control.
Get founding access →
Vibe Prospecting MCPVibe Prospecting MCP
Vibe Prospecting MCP
Connect Claude to +800M contacts, +150M companies. Find & Enrich leads in chat.
Try For Free →
CodeRabbit
CodeRabbit
AI writes the code. CodeRabbit catches the slop.
Try For Free →
Make your agent a DeFi expert
Make your agent a DeFi expert
Agent, run crypto. Access onchain data & trade routes via 1inch.
Install now →
AppSignal
AppSignal
Monitor with ease. Code with confidence.
Start Free Trial →
Make money from your Skills
Make money from your Skills
On Capafy, your Skill runs online 24/7 as an agent product, and you get paid every time someone uses it.
Start earning →
Put your SEO on autopilot
Put your SEO on autopilot
An agent that runs the SEO playbooks that move rankings and ships PRs you control.
Get founding access →
Vibe Prospecting MCPVibe Prospecting MCP
Vibe Prospecting MCP
Connect Claude to +800M contacts, +150M companies. Find & Enrich leads in chat.
Try For Free →
Featured
CodeRabbit
CodeRabbit
AI writes the code. CodeRabbit catches the slop.
Try For Free →
Make your agent a DeFi expert
Make your agent a DeFi expert
Agent, run crypto. Access onchain data & trade routes via 1inch.
Install now →
AppSignal
AppSignal
Monitor with ease. Code with confidence.
Start Free Trial →
Make money from your Skills
Make money from your Skills
On Capafy, your Skill runs online 24/7 as an agent product, and you get paid every time someone uses it.
Start earning →
Put your SEO on autopilot
Put your SEO on autopilot
An agent that runs the SEO playbooks that move rankings and ships PRs you control.
Get founding access →
Vibe Prospecting MCPVibe Prospecting MCP
Vibe Prospecting MCP
Connect Claude to +800M contacts, +150M companies. Find & Enrich leads in chat.
Try For Free →
Registryactive
Packageglobal-education-mcp
TransportSTDIO
UpdatedJun 7, 2026
View on GitHub

🇨🇭 Part of the Swiss Public Data MCP Portfolio

🎓 global-education-mcp

Version License: MIT Python 3.11+ MCP Data: UNESCO UIS Data: OECD Tests No API Key CI

MCP server for international education data – UNESCO UIS (4,000+ indicators across all member countries) and OECD Education at a Glance via SDMX. No API keys required.

🇩🇪 Deutsche Version

global-education-mcp demo flow


Overview

global-education-mcp gives AI assistants like Claude a complete international education intelligence system – literacy rates, enrolment ratios, education expenditure, teacher salaries, gender parity and SDG-4 monitoring, all accessible through a single standardised MCP interface.

The server bridges two of the most authoritative sources for internationally comparable education statistics: UNESCO UIS (global coverage, 4,000+ indicators) and the OECD's annual Education at a Glance (38 OECD countries, SDMX REST API). Both are open and require no API key.

Anchor demo query: "Compare Switzerland's education expenditure as a percentage of GDP with Finland, Singapore and South Korea over the last 10 years – and flag any SDG-4 gaps."


Features

  • 🌍 UNESCO UIS – 4,000+ indicators, all UNESCO member countries, no API key
  • 📊 OECD Education at a Glance – 38 OECD countries + partners via SDMX REST
  • 🔍 Indicator search – browse and filter the full UNESCO indicator catalogue
  • 🗺️ Multi-country comparison – benchmark any indicator across multiple countries
  • 🏫 Country education profiles – 10 core indicators in one call
  • 🎯 SDG-4 monitoring – structured reporting on Education for All targets
  • 📈 OECD dataset search – discover and retrieve Education at a Glance dataflows
  • 🔑 No API keys required – fully open data, zero setup friction
  • ☁️ Dual transport – stdio for Claude Desktop, Streamable HTTP/SSE for cloud deployment
  • 🛡️ Graceful degradation – API failures return helpful messages with local reference fallback

Prerequisites

  • Python 3.11+
  • uv (recommended) or pip
  • No API keys needed

Installation

# Clone the repository
git clone https://github.com/malkreide/global-education-mcp.git
cd global-education-mcp

# Install
pip install -e ".[dev]"

Or with uvx (no permanent installation):

uvx global-education-mcp

Quickstart

# Start the server (stdio mode for Claude Desktop)
global-education-mcp

Try it immediately in Claude Desktop:

"What is Switzerland's literacy rate compared to Finland and Singapore?" "Show me education expenditure as % of GDP for CHE, DEU and AUT over the last 10 years."


Configuration

Claude Desktop Configuration

Windows (%APPDATA%\Claude\claude_desktop_config.json):

{
  "mcpServers": {
    "global-education": {
      "command": "uvx",
      "args": ["global-education-mcp"]
    }
  }
}

macOS (~/Library/Application Support/Claude/claude_desktop_config.json):

{
  "mcpServers": {
    "global-education": {
      "command": "uvx",
      "args": ["global-education-mcp"]
    }
  }
}

A ready-to-use claude_desktop_config.json is included in the repository root.

Cloud Deployment (SSE for browser access)

For use via claude.ai in the browser (e.g. on managed workstations without local software).

⚠️ Security note: Since v0.3, MCP_HOST defaults to 127.0.0.1. The SSE transport must always run behind a reverse proxy that adds TLS, authentication, and rate-limiting. Never expose the raw port to the internet — MCP_HOST=0.0.0.0 is only safe inside an isolated container network.

Docker (recommended):

The repository ships a hardened multi-stage Dockerfile and a docker-compose.yml that applies read_only: true, cap_drop: [ALL], security_opt: [no-new-privileges:true], and runs as non-root user uid 10001. The compose file binds the port to 127.0.0.1 so a host-level reverse proxy is required for any external access.

docker compose up --build
# then point nginx/caddy at 127.0.0.1:8000/sse with TLS + auth

Plain docker run (without compose):

docker build -t global-education-mcp .
docker run --rm \
  --read-only --cap-drop ALL --security-opt no-new-privileges \
  --tmpfs /tmp:size=16M,mode=1777 \
  -p 127.0.0.1:8000:8000 \
  global-education-mcp

Render.com:

  1. Push/fork the repository to GitHub
  2. On render.com: New Web Service → connect GitHub repo
  3. Set environment variables in the Render dashboard:
    MCP_TRANSPORT=sse
    MCP_HOST=0.0.0.0      # Render needs 0.0.0.0; their edge layer provides TLS + auth.
    PORT=8000
    
  4. In claude.ai under Settings → MCP Servers, add: https://your-app.onrender.com/sse

💡 "stdio for the developer laptop, sandboxed SSE container for the browser."


Available Tools

UNESCO UIS Tools

ToolDescription
uis_list_indicatorsSearch and list available indicators (4,000+)
uis_list_countriesList countries and regions with ISO codes
uis_get_education_dataRetrieve data for a specific indicator
uis_compare_countriesMulti-country comparison for one indicator
uis_country_education_profileFull education profile (10 core indicators)
uis_list_versionsList available database versions

OECD Tools

ToolDescription
oecd_list_education_datasetsList Education at a Glance datasets
oecd_get_education_indicatorRetrieve OECD education data via SDMX
oecd_search_datasetsSearch OECD dataflows by keyword

Cross-Source Tools

ToolDescription
education_benchmark_countriesBenchmark multiple countries across 5 focus themes (UNESCO UIS)

Resources & Prompts

Resources:

  • education://indicators/unesco – Quick reference for core UNESCO indicators
  • education://datasets/oecd – Quick reference for OECD Education at a Glance dataflows

Prompts:

  • bildungsvergleich_schweiz – Switzerland vs. Finland, Singapore, Japan
  • sdg4_monitoring – SDG-4 report for CH/DE/AT

Country Codes

ISO 3166-1 Alpha-3 standard:

CodeCountryCodeCountry
CHESwitzerlandFINFinland
DEUGermanySGPSingapore
AUTAustriaKORSouth Korea
FRAFranceJPNJapan
SWESwedenUSAUnited States

Example Use Cases

QueryTool
"What is Switzerland's literacy rate vs. Finland and Singapore?"uis_compare_countries
"Education expenditure as % of GDP for CHE, DEU, AUT over 10 years"uis_get_education_data
"Create a full education profile for South Korea"uis_country_education_profile
"Which OECD datasets cover teacher salaries?"oecd_search_datasets
"Compare secondary graduation rates across 5 European countries"education_benchmark_countries
"Create an SDG-4 monitoring report for Switzerland"sdg4_monitoring (prompt)

→ More use cases by audience →


Architecture

┌─────────────────┐     ┌──────────────────────────────┐     ┌────────────────────┐
│   Claude / AI   │────▶│   Global Education MCP       │────▶│   UNESCO UIS API   │
│   (MCP Host)    │◀────│   (MCP Server)               │◀────│   uis.unesco.org   │
└─────────────────┘     │                              │     └────────────────────┘
                        │  10 Tools · 2 Resources      │
                        │   · 2 Prompts                │     ┌────────────────────┐
                        │  Stdio | SSE                 │────▶│   OECD SDMX API    │
                        │                              │◀────│   sdmx.oecd.org    │
                        │  server.py                   │     └────────────────────┘
                        │   + api_client.py            │
                        └──────────────────────────────┘

Infrastructure Components

ComponentMetaphorFunction
HTTPClientPostal serviceHandles all outbound HTTP requests, retries and timeouts
SimpleCacheWhiteboardIn-memory TTL cache for repeated queries
GracefulFallbackSafety netReturns local reference data when APIs are unavailable
SDMXParserTranslatorConverts OECD SDMX/XML responses to clean JSON

Caching Strategy

Data SourceCache TTLRationale
UNESCO UIS indicators3600sCatalogue is stable; updated annually
UNESCO UIS country data1800sFigures update yearly, not intraday
OECD dataset list3600sEducation at a Glance is an annual publication
OECD indicator data1800sSame annual update cycle
Country/region list86400sISO codes and country lists are highly stable

Project Structure

global-education-mcp/
├── src/global_education_mcp/       # Main package
│   ├── __init__.py                 # Package metadata, version
│   ├── server.py                   # FastMCP server, 10 tools, 2 resources, 2 prompts
│   └── api_client.py               # HTTP client, UNESCO UIS + OECD wrappers, formatters
├── tests/
│   ├── test_server.py              # 39 tests (basic / intermediate / advanced)
│   └── test_extended_scenarios.py  # 74 tests across 8 categories
├── claude_desktop_config.json      # Ready-to-use Claude Desktop config
├── pyproject.toml                  # Build configuration (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
├── README.md                       # This file (English)
└── README.de.md                    # German version

Known Limitations

  • UNESCO UIS: Some indicators have sparse coverage for low-income countries or recent years
  • OECD SDMX: Occasional API timeouts on large multi-country, multi-year requests; reduce the year range if needed
  • OECD coverage: 38 OECD members + select partners – does not cover all UNESCO member states
  • Historical depth: UNESCO UIS data availability varies by indicator; not all series go back to 1970
  • Language: UNESCO UIS returns indicator labels in English only; OECD labels may vary by dataflow
  • No real-time data: Both sources publish annually – figures reflect the latest published edition, not live school statistics

Compliance & Data Classification (City of Zurich)

Verbindliche Klassifikation für den Einsatz im Schulamt der Stadt Zürich (German section follows in README.de.md).

ISDS Protection Class (Stadt Zürich Schutzbedarfsklassen)

DimensionClassReasoning
ConfidentialitypublicUNESCO UIS data licensed under CC BY-SA 3.0 IGO; OECD EaG under public OECD Terms
IntegritynormalUpstream is authoritative; local in-memory cache is TTL-bounded and never written to disk
AvailabilitynormalGraceful fallback to bundled static reference data when an API is unreachable
Overall protection classG1 — public (öffentlich)lowest tier per ISDS Stadt Zürich
  • Data owner: UNESCO UIS / OECD (external)
  • System owner: Schulamt der Stadt Zürich
  • Processes personal data: no
  • DSG / EDÖB relevance: none (only anonymized country-level aggregates)

Schulamt Classification (BUI / Vertraulich / Streng Vertraulich)

AspectClassification
Tool output (Markdown tables, summaries)BUI (betrieblich unkritische Information)
In-memory TTL cacheBUI (same tier as source)
Structured logs (JSON on stderr, see OBS-003)BUI — only tool name, params, duration; no PII
tools.lock.json, audits/ artefactsBUI

→ The server is approved for any Schulamt use case without additional clearance from the data protection officer.

Compatibility

ComponentSupported version
MCP Protocol2024-11-05
MCP Python SDK>=1.0.0,<2.0.0
Python3.11, 3.12, 3.13
httpx>=0.27.0,<1.0.0
pydantic>=2.0.0,<3.0.0

Major-version upgrades are deliberate decisions — the upper bounds in pyproject.toml exist so a transitive bump does not silently break the server. See CHANGELOG.md for the upgrade trail.


🛡️ Safety & Limits

AspectDetails
AccessRead-only (readOnlyHint: true) — the server cannot modify, write or delete any data
Personal dataNo personal data — UNESCO UIS and OECD EaG publish only aggregated, country-level statistics
Rate limitsBuilt-in per-query caps (max 50 indicators per search, max 10 countries per comparison, conservative year ranges)
CachingIn-memory TTL cache (1800–86400s) reduces upstream load and respects publisher capacity
Timeout30 seconds per upstream API call, with graceful fallback to local reference data
AuthenticationNo API keys required — both UNESCO UIS and OECD SDMX are publicly accessible
LicensesUNESCO UIS data under CC BY-SA 3.0 IGO; OECD data under OECD Terms and Conditions
Terms of ServiceSubject to ToS of the respective sources: UNESCO UIS, OECD — please cite the source when redistributing
AttributionAll tool responses include source attribution (Source: UNESCO UIS / Source: OECD Education at a Glance)

Testing

# Unit tests (no API key required, no network)
PYTHONPATH=src pytest tests/ -v -m "not integration"

# Full suite including live API smoke tests
PYTHONPATH=src pytest tests/ -v

113 tests across two files and three complexity levels:

CategoryTestsDescription
Edge cases & boundary values19Year limits, string lengths, null/zero values
Security & adversarial inputs14Injection attempts, HTTP error codes, whitespace
Output quality11Markdown structure, source attribution, sort order
Resilience & error cascades9Full API outage, partial results, timeouts
Subject-matter correctness10SDG-4 coverage, correct indicators per focus theme
Performance & concurrency4Concurrent requests, time limits
Schulamt scenarios7DACH comparison, PISA, teacher shortage
Live API smoke tests4Real endpoints (via --integration flag)

Contributing

Contributions are welcome. Please open an issue first to discuss what you would like to change.

  • Follow the existing code style (Ruff linting, Black formatting)
  • Add tests for new tools (tests/test_server.py or test_extended_scenarios.py)
  • Use the @pytest.mark.integration marker for tests that call live APIs
  • Update CHANGELOG.md and the tool table in this README
  • See CONTRIBUTING.md for the full contribution guide

Changelog

See CHANGELOG.md


Security

To report a vulnerability, see SECURITY.md (🇩🇪 Deutsche Version). Please use the private channels described there rather than public issues.


License

MIT License — see LICENSE


Author

Hayal Oezkan · github.com/malkreide


Credits & Related Projects

  • Data: UNESCO Institute for Statistics (UIS) – open education data for all UNESCO member states
  • Data: OECD Education at a Glance – annual OECD education statistics via SDMX
  • Protocol: Model Context Protocol – Anthropic / Linux Foundation
  • Related: swiss-transport-mcp – MCP server for Swiss public transport
  • Related: zurich-opendata-mcp – MCP server for Zurich city open data
  • Portfolio: Swiss Public Data MCP Portfolio

Installation

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": {
    "global-education-mcp": {
      "command": "uvx",
      "args": [
        "global-education-mcp"
      ]
    }
  }
}