VEPmcp
Enables variant annotation and effect prediction using the Ensembl VEP API, with support for batch and single queries.
README
VEPmcp
VEPmcp is a Model Context Protocol (MCP) server for the Ensembl Variant Effect Predictor (VEP) API. It enables annotation and effect prediction of genetic variants, with full support for batch and single queries, and is designed for seamless integration with MCP-compatible clients (e.g., Claude Desktop, VS Code MCP extension).
Features
- Annotate variants using Ensembl VEP (HGVS, variant ID, or genomic region)
- Batch and single variant support
- Retrieve available species, consequence types, and assembly info
- Fast, robust, and rate-limited HTTP client
- JSON-RPC 2.0 over stdio for easy integration with AI tools and editors
Installation
pip install -e .
# or via pypi
pip install VEPmcp
Usage
Command Line
VEPmcp --help
VEPmcp --test-connection # Test Ensembl API connectivity
VEPmcp --test-mode # Run server in test mode with sample requests
As an MCP Server
Run the server (for use with MCP clients):
VEPmcp
The server communicates via stdio using JSON-RPC 2.0.
Supported Tools
vep_hgvs_single/vep_hgvs_batch: Annotate by HGVS notationvep_id_single/vep_id_batch: Annotate by variant ID (e.g., rsID)vep_region_single/vep_region_batch: Annotate by genomic regionget_vep_species: List available speciesget_consequence_types: List consequence typesget_assembly_info: Get assembly info for a species
Example MCP Client Configurations
Claude Desktop
{
"mcp_servers": {
"vepmcp": {
"command": "VEPmcp",
"args": [],
"env": {}
}
}
}
VS Code MCP Extension
{
"mcp.servers": {
"vepmcp": {
"command": "VEPmcp",
"args": [],
"env": {},
"cwd": "${workspaceFolder}"
}
}
}
Example Usage
Prompt your MCP client with:
"Annotate the variant rs56116432 in humans using VEP"
Testing
VEPmcp --test-connection— check API connectivityVEPmcp --test-mode— run server in test modepython run_tests.py --mode all --verbose— run all unit/integration testspython run_tests.py --mode ci— run CI pipeline (linting + type checking + unit tests)
Continuous Integration
This project uses GitHub Actions for automated testing on every pull request. The CI pipeline includes:
- Linting with Ruff
- Type checking with MyPy
- Unit and integration tests across Python 3.9-3.13
- Security scanning
- Code coverage reporting
Troubleshooting
- Ensure VEPmcp is installed and in your PATH
- Check internet connectivity for Ensembl API access
- Use
--verbosefor detailed logs
Development
pip install -e .[dev]
python run_tests.py --mode ci # Run linting, type checking, and unit tests
python run_tests.py --mode all --verbose # Run all tests including integration
Local Testing Commands
# Linting and formatting
python run_tests.py --mode lint
# Type checking
python run_tests.py --mode type
# Unit tests only
python run_tests.py --mode unit --verbose
# Integration tests (requires internet)
python run_tests.py --mode integration --verbose
License
MIT License — see LICENSE
Contributing
- Fork and branch
- Make changes and add tests
- Run the test suite
- Submit a pull request
Support
For issues and questions, use the GitHub issue tracker.
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.