Unofficial HPO MCP Server

Unofficial HPO MCP Server

Provides access to the Human Phenotype Ontology (HPO) API with tools for searching, browsing hierarchy, and analyzing phenotypic terms used in genetic research.

Category
Visit Server

README

Logo

Unofficial HPO MCP Server

An MCP (Model Context Protocol) server that provides access to the Human Phenotype Ontology (HPO) API. The HPO contains over 18,000 terms describing human phenotypic abnormalities and is widely used in genetic research and clinical diagnostics.

Developed by Augmented Nature

Features

This MCP server provides 12 comprehensive tools to interact with the HPO API:

Core Search & Information Tools

  • search_hpo_terms - Search for HPO terms by keyword, ID, or synonym with pagination support
  • get_hpo_term - Get detailed information about a specific HPO term by its ID
  • get_all_hpo_terms - List all HPO terms with pagination
  • batch_get_hpo_terms - Retrieve multiple HPO terms in a single request (up to 20 terms)

Hierarchical Navigation Tools

  • get_hpo_ancestors - Get all ancestor terms (all terms higher in the hierarchy)
  • get_hpo_parents - Get direct parent terms (one level up)
  • get_hpo_children - Get direct child terms (one level down)
  • get_hpo_descendants - Get all descendant terms (all terms lower in the hierarchy)

Analysis & Utility Tools

  • validate_hpo_id - Validate HPO ID format and verify term exists
  • get_hpo_term_path - Get the full hierarchical path from root to a specific term
  • compare_hpo_terms - Compare two terms and find their relationship and common ancestors
  • get_hpo_term_stats - Get comprehensive statistics and analysis for an HPO term

Prerequisites

  • Node.js: Version 18 or higher
  • Internet connection: Required for accessing the HPO API

Installation

  1. Clone or download this server:
cd hpo-server
npm install
  1. Build the server:
npm run build

Usage

Running the Server

npm start
# or
node build/index.js

Configuration

Add the server to your MCP settings file:

{
  "mcpServers": {
    "hpo-server": {
      "command": "node",
      "args": ["/path/to/hpo-server/build/index.js"]
    }
  }
}

Usage Examples

Search and Discovery

  1. Search for seizure-related terms:

    Search for HPO terms related to "seizure" using search_hpo_terms
    
  2. Search with pagination:

    Search for "heart defect" terms with 20 results per page using search_hpo_terms
    
  3. Get detailed term information:

    Get detailed information about seizure (HP:0001250) using get_hpo_term
    

Hierarchical Navigation

  1. Explore term hierarchy:

    Get all ancestors of seizure term using get_hpo_ancestors
    
  2. Find related terms:

    Get direct children of nervous system abnormality using get_hpo_children
    
  3. Browse term descendants:

    Get all descendant terms of seizure using get_hpo_descendants
    

Analysis and Utilities

  1. Validate HPO IDs:

    Validate if "HP:0001250" is a correct HPO ID using validate_hpo_id
    
  2. Get hierarchical path:

    Show the complete path from root to seizure term using get_hpo_term_path
    
  3. Compare two terms:

    Compare seizure and nervous system abnormality terms using compare_hpo_terms
    
  4. Get term statistics:

    Get comprehensive statistics for seizure term using get_hpo_term_stats
    
  5. Batch processing:

    Get information for multiple terms (HP:0001250, HP:0000707, HP:0001626) using batch_get_hpo_terms
    
  6. List all terms:

    Browse all HPO terms with pagination using get_all_hpo_terms
    

API Features

HPO ID Format Support

HPO IDs can be provided in multiple formats:

  • Full format: HP:0001250
  • Short format: 0001250
  • The server automatically handles format conversion

Pagination Support

Search and listing tools support pagination:

  • max - Maximum results per page (varies by tool)
  • offset - Number of results to skip (default: 0)

Parameter Details

  • id (string, required for most tools): HPO term ID
  • query (string, required for search): Search query - keyword, HPO ID, or synonym
  • category (array, optional): Filter by specific HPO categories
  • max (number, optional): Maximum results to return
  • offset (number, optional): Pagination offset

API Details

  • Base URL: https://ontology.jax.org/api/hp/
  • Authentication: None required (public API)
  • Rate Limiting: Managed by client with 30-second timeout
  • Error Handling: Comprehensive error messages and graceful degradation

Project Structure

hpo-server/
├── src/
│   ├── index.ts              # Main MCP server implementation
│   ├── types/
│   │   └── hpo.ts           # TypeScript interfaces for HPO data
│   ├── utils/
│   │   └── api-client.ts    # HPO API HTTP client
│   └── handlers/
│       └── hpo-handlers.ts  # MCP tool implementations
├── build/                   # Compiled JavaScript output
├── package.json
├── tsconfig.json
└── README.md

Development

Building the Server

cd hpo-server
npm run build

Dependencies

  • @modelcontextprotocol/sdk - MCP SDK for server implementation
  • axios - HTTP client for HPO API requests

About the Human Phenotype Ontology

The HPO provides a standardized vocabulary of phenotypic abnormalities encountered in human disease. Each term describes a phenotypic abnormality, such as "Atrial septal defect" or "Intellectual disability". The HPO is:

Error Handling

The server includes comprehensive error handling:

  • Invalid HPO IDs are properly formatted when possible
  • Network errors provide clear user-friendly messages
  • API errors are passed through with context
  • Parameter validation with helpful error messages

Limitations

  • Maximum result limits are enforced to prevent overwhelming responses
  • Network timeouts are set to 30 seconds for stability
  • Some HPO API endpoints may have their own rate limiting (handled gracefully)

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