LungMAP MCP Server
MCP server for accessing the LungMAP API, enabling AI assistants to discover and analyze lung research data such as datasets, samples, and analysis results.
README
๐ซ LungMAP MCP Server
A Model Context Protocol (MCP) server that provides AI assistants with powerful tools to access the Lung Molecular Atlas Program (LungMAP) API for lung research data discovery and analysis.
๐ Quick Start
๐ฅ Demo
โถ๏ธ Watch the LungMAP MCP walkthrough
1. Clone & Install
git clone https://github.com/pankajrajdeo/lungmap-mcp-server.git
cd lungmap-mcp-server
pip install -e .
2. Test the Server
python scripts/test_server.py
3. Use with Claude Desktop
Add to your Claude Desktop config:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"lungmap": {
"command": "python3",
"args": ["/absolute/path/to/lungmap_mcp_server.py"]
}
}
}
๐ ๏ธ Features
๐ 8 Powerful Research Tools
| Tool | Purpose | Use Case |
|---|---|---|
search_datasets |
Primary discovery tool | Find datasets, genes, analysis entities |
get_dataset_details |
Comprehensive dataset info | Deep dive into specific datasets |
get_sample_details |
Sample metadata | Donor information and demographics |
get_analysis_results |
Computational results | Gene lists and statistical analyses |
get_molecular_entities |
Gene sets & ontology | Gene sets, probes, anatomy terms |
get_infrastructure_resources |
Research infrastructure | Researchers, sites, technologies |
list_controlled_vocabulary |
Filter validation | Discover valid search parameters |
search_media |
Files & images | Find protocols, histology images |
๐ฏ 3 Workflow Prompts
search_workflow- Dataset discovery guidanceanalysis_workflow- Data analysis workflowdiscovery_workflow- Exploratory research tips
๐ 2 Resource Endpoints
lungmap://api/base_url- API base URL referencelungmap://api/documentation- Complete API documentation
๐ก Usage Examples (MCP)
Below are examples that use the MCP protocol. Tools are executed via an MCP client, not by importing Python functions directly.
1) Using Claude Desktop (No code)
- Add the server in Claude Desktop config (see Quick Start)
- Then ask natural language queries like:
- "Find human RNA-seq datasets about lung development"
- "Get details for dataset LMEX0000000661 including files and images"
- "Search everything about ACE2"
Claude will call the MCP tools (e.g., search_datasets, get_dataset_details) behind the scenes.
2) Using the MCP Python Client (stdio)
import asyncio
from mcp import ClientSession, StdioServerParameters
from mcp.client.stdio import stdio_client
async def main():
server_params = StdioServerParameters(
command="python3",
args=["/absolute/path/to/lungmap_mcp_server.py"],
)
async with stdio_client(server_params) as (read, write):
async with ClientSession(read, write) as session:
# Initialize the session
await session.initialize()
# Call a tool: search_datasets
result = await session.call_tool(
"search_datasets",
arguments={
"text_query": "lung development",
"species": "human",
"dataset_types": ["rna_seq"],
"limit": 5,
},
)
print(result.content)
# Call a tool: get_dataset_details
details = await session.call_tool(
"get_dataset_details",
arguments={
"dataset_id": "LMEX0000000661",
"include_files": True,
"include_images": True,
"include_resources": True,
},
)
print(details.content)
asyncio.run(main())
3) Using LangChain MCP Adapters
import asyncio
from mcp import ClientSession, StdioServerParameters
from mcp.client.stdio import stdio_client
from langchain_mcp_adapters.tools import load_mcp_tools
from langgraph.prebuilt import create_react_agent
async def main():
server_params = StdioServerParameters(
command="python3",
args=["/absolute/path/to/lungmap_mcp_server.py"],
)
async with stdio_client(server_params) as (read, write):
async with ClientSession(read, write) as session:
await session.initialize()
# Load all MCP tools as LangChain tools
tools = await load_mcp_tools(session)
# Create a ReAct agent and invoke it
agent = create_react_agent("openai:gpt-4o-mini", tools)
response = await agent.ainvoke({
"messages": [{"role": "user", "content": "Search everything about ACE2"}]
})
print(response)
asyncio.run(main())
๐ Project Structure
lungmap-mcp-server/
โโโ ๐ README.md # This file
โโโ ๐ LICENSE # MIT License
โโโ ๐ pyproject.toml # Python package config
โโโ ๐ lungmap_mcp_server.py # Main MCP server
โโโ ๐ docs/ # Documentation
โ โโโ ๐ quickstart.md # 5-minute setup guide
โ โโโ ๐ installation_guide.md # Detailed installation
โ โโโ ๐ deployment_checklist.md # Production checklist
โ โโโ ๐ mcp_config_examples.json # Configuration examples
โโโ ๐ scripts/ # Utility scripts
โ โโโ ๐ง setup_script.sh # Automated setup
โ โโโ ๐งช test_server.py # Server testing
โโโ ๐ tests/ # Test suite
โ โโโ ๐งช test_tools.py # Tool tests
โโโ ๐ tools/ # Tool implementations
โโโ ๐ api_client.py # API client utilities
โโโ ๐ constants.py # Constants & mappings
โโโ ๐ types.py # Type definitions
โโโ ๐ [8 lungmap tools].py # Individual tools
๐ง Installation
Prerequisites
- Python 3.10+
- pip or uv package manager
Option 1: Quick Install
git clone https://github.com/pankajrajdeo/lungmap-mcp-server.git
cd lungmap-mcp-server
pip install -e .
Option 2: With Virtual Environment
git clone https://github.com/pankajrajdeo/lungmap-mcp-server.git
cd lungmap-mcp-server
python -m venv venv
source venv/bin/activate # Windows: venv\Scripts\activate
pip install -e .
Option 3: Using uv (Faster)
git clone https://github.com/pankajrajdeo/lungmap-mcp-server.git
cd lungmap-mcp-server
uv venv
source .venv/bin/activate
uv pip install -e .
๐งช Testing
# Test server functionality
python scripts/test_server.py
# Test individual tools
python tests/test_tools.py
# Run with pytest (if installed)
pytest tests/
๐ Integration
Claude Desktop
See Claude Desktop Setup Guide
LangChain/LangGraph
from mcp import ClientSession, StdioServerParameters
from mcp.client.stdio import stdio_client
from langchain_mcp_adapters.tools import load_mcp_tools
server_params = StdioServerParameters(
command="python3",
args=["/path/to/lungmap_mcp_server.py"],
)
async with stdio_client(server_params) as (read, write):
async with ClientSession(read, write) as session:
await session.initialize()
tools = await load_mcp_tools(session)
# Use tools with your LangChain agent
๐ API Reference
๐ Remote Deployment & Auth
Environment variables:
# Transport
MCP_TRANSPORT=sse # or stdio
HOST=0.0.0.0
PORT=8000
MCP_SSE_PATH=/sse
# Auth (optional but recommended for SSE)
LUNGMAP_MCP_TOKEN=your-secret-token
# Rate limiting
MAX_REQUESTS_PER_MINUTE=60
Run with SSE locally:
MCP_TRANSPORT=sse PORT=8000 LUNGMAP_MCP_TOKEN=dev-token \
python lungmap_mcp_server.py
Health/resource checks via MCP client:
from mcp import ClientSession, StdioServerParameters
from mcp.client.stdio import stdio_client
# For SSE, use appropriate client/URL; below shows stdio example
Security & limits:
- Bearer token required if
LUNGMAP_MCP_TOKENset. - Per-tool rate limit defaults to 60 req/min; configure via env.
- Responses soft-capped at ~100KB; narrow queries or reduce limits if exceeded.
๐ค Connect Clients (ChatGPT, Claude, Cursor)
ChatGPT (MCP over SSE)
-
Start server with SSE and token (see above)
-
Use the OpenAI Responses API with MCP tools (example):
curl https://api.openai.com/v1/responses \
-H "Authorization: Bearer $OPENAI_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"model": "o4-mini",
"input": "Find human RNA-seq datasets about lung development",
"tools": [{
"type": "mcp",
"server_label": "lungmap",
"server_url": "http://localhost:8000/sse",
"allowed_tools": ["search", "search_datasets", "get_dataset_details", "get_sample_details", "get_analysis_results", "get_molecular_entities", "get_infrastructure_resources", "list_controlled_vocabulary", "search_media", "fetch"],
"require_approval": "never",
"metadata": {
"headers": {"Authorization": "Bearer dev-token"}
}
}]
}'
Notes:
search/fetchare provided for generic connectors; domain tools are also available.- Pass the same Bearer token via
metadata.headers.Authorization.
Claude Desktop (Remote via @modelcontextprotocol/client)
Add to claude_desktop_config.json:
{
"mcpServers": {
"lungmap-remote": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/client", "http://localhost:8000/sse"],
"env": {
"AUTHORIZATION": "Bearer dev-token"
}
}
}
}
Then restart Claude Desktop and verify the MCP server is connected.
Cursor / Local stdio
Add a local stdio server entry in your settings or run:
python lungmap_mcp_server.py # stdio mode
Use the domain tools directly (e.g., search_datasets) from your agent.
๐งช Testing (stdio & SSE)
- Stdio test:
python scripts/test_server.py
- SSE integration tests (optional):
MCP_TRANSPORT=sse PORT=8000 LUNGMAP_MCP_TOKEN=dev-token \
python lungmap_mcp_server.py &
TEST_SSE_BASE=http://localhost:8000 pytest -q tests/test_remote.py
Base URL
https://www.lungmap.net/api
ID Formats
- Datasets:
LMEX*(e.g.,LMEX0000000661) - Samples:
LMSP*(e.g.,LMSP0000001176) - Analyses:
LMAN*(e.g.,LMAN0000000037) - Researchers:
LMRS*(e.g.,LMRS0000000174) - Sites:
LMSI*(e.g.,LMSI0000000026)
Common Filters
- Species:
human,mouse - Dataset Types:
rna_seq,proteomics,imaging,single_cell,atac_seq,chip_seq - Age Ranges:
prenatal,newborn,infant,child,adolescent,adult,elderly - Sex:
male,female,unknown
๐ Troubleshooting
Common Issues
โ Import Errors
# Ensure you're in the project directory
cd lungmap-mcp-server
pip install -e .
โ Server Won't Start
# Check Python version
python3 --version # Must be 3.10+
# Test server manually
python lungmap_mcp_server.py
โ Claude Desktop Not Connecting
- Use absolute paths in config
- Restart Claude Desktop completely
- Check Claude Desktop logs
Getting Help
- ๐ Bug Reports: Open an issue
- ๐ก Feature Requests: Start a discussion
- ๐ LungMAP API: Official Documentation
- ๐ง MCP Protocol: MCP Documentation
๐ค Contributing
We welcome contributions! See CONTRIBUTING.md for guidelines.
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests
- Submit a pull request
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments
- LungMAP Consortium for providing the comprehensive lung research API
- Anthropic for the Model Context Protocol specification
- Open Source Community for the tools and libraries that made this possible
๐ About LungMAP
The Lung Molecular Atlas Program (LungMAP) is an NHLBI-funded consortium focused on understanding lung development and disease through molecular profiling. Learn more at lungmap.net.
โญ Star this repository if you find it useful!
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.