openpharma-org/who-mcp
If you are the rightful owner of who-mcp and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to dayong@mcphub.com.
A Model Context Protocol (MCP) server providing access to WHO's Global Health Observatory data via the OData API.
Unofficial WHO MCP Server
A Model Context Protocol (MCP) server that provides access to the World Health Organization's Global Health Observatory (GHO) data via the OData API. This server enables AI assistants and applications to search, retrieve, and analyze comprehensive health indicators, country statistics, and regional data from WHO's extensive health database.
Features
- Global Health Data: Access WHO's comprehensive health indicators and statistics
- Rich Health Metrics: Life expectancy, mortality rates, disease burden, health systems data
- Advanced Search: Find health indicators by keywords and topics
- Country-Specific Data: Retrieve health data for specific countries and regions
- Time Series Data: Access historical health trends and time-based analysis
- WHO Regions: Filter data by WHO regional classifications
- OData Protocol: Built on WHO's modern OData API for efficient data access
Usage
{
"mcpServers": {
"who-mcp-server": {
"command": "node",
"args": ["/path/to/who-mcp-server/build/index.js"]
}
}
}
API Reference
The server provides a single unified tool who-health with six methods for accessing WHO health data:
1. Get Dimensions (get_dimensions)
List all available data dimensions in the WHO database.
Parameters:
method:"get_dimensions"
Example:
{
"method": "get_dimensions"
}
2. Get Dimension Codes (get_dimension_codes)
Retrieve codes for a specific dimension (countries, regions, years, etc.).
Parameters:
method:"get_dimension_codes"dimension_code(required): Dimension to retrieve (e.g., "COUNTRY", "REGION")
Example:
{
"method": "get_dimension_codes",
"dimension_code": "COUNTRY"
}
3. Search Indicators (search_indicators)
Find health indicators using keywords and natural language queries.
Parameters:
method:"search_indicators"keywords(required): Search terms for health indicators
Example:
{
"method": "search_indicators",
"keywords": "life expectancy maternal mortality"
}
4. Get Health Data (get_health_data)
Retrieve comprehensive health indicator data with filtering options.
Parameters:
method:"get_health_data"indicator_code(required): WHO health indicator codetop(optional): Maximum number of records to returnfilter(optional): OData filter expression for advanced filtering
Example:
{
"method": "get_health_data",
"indicator_code": "WHOSIS_000001",
"filter": "SpatialDim eq 'USA' and TimeDim eq 2020",
"top": 100
}
5. Get Country Data (get_country_data)
Retrieve health data for specific countries, regions, or time periods.
Parameters:
method:"get_country_data"indicator_code(required): WHO health indicator codecountry_code(optional): ISO 3-letter country coderegion_code(optional): WHO region codeyear(optional): Specific year or year rangesex(optional): Sex dimension filtertop(optional): Maximum number of records
Example:
{
"method": "get_country_data",
"indicator_code": "WHOSIS_000001",
"country_code": "USA",
"year": "2015:2020"
}
6. Get Cross Table (get_cross_table)
Generate tabular views of health data across countries and time periods.
Parameters:
method:"get_cross_table"indicator_code(required): WHO health indicator codecountries(optional): Comma-separated list of country codesyears(optional): Year range or specific yearsex(optional): Sex dimension filter
Example:
{
"method": "get_cross_table",
"indicator_code": "WHOSIS_000001",
"countries": "USA,GBR,CHN",
"years": "2015:2020"
}
Health Indicators
The WHO database contains hundreds of health indicators covering:
- Demographics: Life expectancy, population statistics, mortality rates
- Disease Burden: HIV/AIDS, tuberculosis, malaria, non-communicable diseases
- Health Systems: Health expenditure, health workforce, hospital beds
- Risk Factors: Tobacco use, alcohol consumption, obesity, air pollution
- Maternal & Child Health: Maternal mortality, infant mortality, vaccination coverage
- Mental Health: Suicide rates, mental health services
- Environmental Health: Water, sanitation, air quality
Common Indicator Codes
WHOSIS_000001: Life expectancy at birthMDG_0000000001: Maternal mortality ratioGHED_CHE_pc_PPP_INT: Current health expenditure per capitaM_Est_smk_curr_std: Smoking prevalenceSA_0000001688: Suicide mortality rate
WHO Regions
The system supports WHO's six regional classifications:
- AFR: African Region
- AMR: Region of the Americas
- SEAR: South-East Asia Region
- EUR: European Region
- EMR: Eastern Mediterranean Region
- WPR: Western Pacific Region
OData Query Examples
Basic Filtering
SpatialDim eq 'USA' and TimeDim eq 2020
Time Range Filtering
TimeDim ge 2015 and TimeDim le 2020
Sex Disaggregation
Dim1 eq 'MLE' // Male
Dim1 eq 'FMLE' // Female
Dim1 eq 'BTSX' // Both sexes
Date Functions
date(TimeDimensionBegin) ge 2011-01-01 and date(TimeDimensionBegin) lt 2012-01-01
Null Checks
Dim1 ne null // Has disaggregation data
Dim1 eq null // No disaggregation data
Data Sources
This server accesses data from:
- WHO Global Health Observatory: Primary source for health statistics
- OData API: Modern REST API with standardized querying
- Official WHO Data: Verified and quality-assured health indicators
- Real-time Updates: Data synchronized with WHO releases
Rate Limits & Guidelines
- Respect WHO's API rate limits and usage policies
- Cache responses when appropriate to reduce API calls
- Use appropriate
$topparameters to limit large data sets - Monitor API performance and adjust queries as needed