Biomedical APIs MCP Server
Enables AI agents to query free biomedical and pharmaceutical APIs for clinical trials, drug data, molecular structures, adverse events, and research literature.
README
Biomedical APIs MCP Server
This Model Context Protocol (MCP) server exposes 14 tools to query free biomedical and pharmaceutical APIsβplus stubs for restricted/paid sourcesβenabling AI agents to access clinical trial data, drug information, molecular structures, adverse events, and research literature.
π― Available APIs
Free & Open APIs (fully functional)
- ClinicalTrials.gov β Search registered clinical trials worldwide
- ChEMBL β Small molecules, bioactivity data, drug-like compounds
- PubChem β Chemical compounds, molecular properties
- OpenFDA β FDA adverse event reports (drug, device, food)
- Europe PMC β Biomedical research articles and preprints
Restricted/Paid APIs (stubs only)
- dbGaP β NIH genomic & clinical datasets (requires NIH credentials)
- PhysioNet β Physiological signals (requires credentialed access)
- MIMIC-IV β ICU records (PhysioNet credential + CITI training)
- UK Biobank β Large-scale biomedical data (application required)
- DrugBank β Structured drug data (academic/commercial license)
- BindingDB β Protein-ligand binding affinities (bulk download)
- OpenTrials β Merged trial data & sponsors (open access)
- Crunchbase β Company & funding data (free tier limited)
π Quick Start
1. Install Dependencies
npm install
2. Configure Environment (optional)
Copy .env.example to .env and add optional API keys:
cp .env.example .env
Edit .env:
OPENFDA_API_KEY=your_key_here # Optional: increases OpenFDA rate limits
CRUNCHBASE_API_KEY=your_key_here # Optional: enables Crunchbase free tier
3. Build the Server
npm run build
4. Run in Development Mode
npm run dev
5. Use in Production
npm start
π§ͺ Testing with MCP Inspector
MCP Inspector lets you test your server interactively:
npx @modelcontextprotocol/inspector node dist/server.js
Once connected, you can:
- List all 14 available tools
- Test tool calls with custom inputs
- View structured JSON responses
- Debug errors and API rate limits
π Connecting to Clients
VS Code (Copilot Agent Mode)
The server is pre-configured in .vscode/mcp.json:
{
"servers": {
"biomed-apis": {
"type": "stdio",
"command": "node",
"args": ["dist/server.js"]
}
}
}
To connect:
- Open this workspace in VS Code
- Restart VS Code (if needed)
- Open Copilot Chat and confirm the MCP server is listed
- Ask: "Search ClinicalTrials.gov for epilepsy trials started in 2023"
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"biomed-apis": {
"command": "node",
"args": ["C:\\For Me\\Projects\\mcp with DBs\\dist\\server.js"]
}
}
}
Restart Claude Desktop. The tools will appear in the MCP panel.
Claude Code CLI
claude mcp add --transport stdio biomed-apis node "C:\\For Me\\Projects\\mcp with DBs\\dist\\server.js"
π Example Tool Calls
1. Search Clinical Trials
{
"tool": "search_clinical_trials",
"input": {
"query": "epilepsy",
"filter": "AREA[StartDate]2020-01-01+TO+2023-12-31",
"pageSize": 5
}
}
Returns: NCT IDs, titles, status, phases, conditions, interventions
2. Search ChEMBL Compounds
{
"tool": "search_chembl_compounds",
"input": {
"query": "aspirin",
"limit": 5
}
}
Returns: ChEMBL IDs, molecular formulas, weights, max clinical phase
3. Get ChEMBL Bioactivity Data
{
"tool": "get_chembl_activities",
"input": {
"targetChemblId": "CHEMBL2",
"limit": 10
}
}
Returns: Activity IDs, assay IDs, molecules, types (IC50, Ki, etc.), values, units
4. Get PubChem Compound by Name
{
"tool": "get_pubchem_compound",
"input": {
"name": "glucose"
}
}
Returns: CID, molecular formula, weight, IUPAC name, SMILES
5. Search OpenFDA Drug Adverse Events
{
"tool": "search_openfda_drug_events",
"input": {
"search": "patient.drug.medicinalproduct:\"metformin\"",
"limit": 10
}
}
Returns: Receive dates, patient ages, reactions, drug names
6. Search Europe PMC Articles
{
"tool": "search_europepmc_articles",
"input": {
"query": "CRISPR gene editing",
"pageSize": 10
}
}
Returns: Article IDs, sources, titles, authors, journals, publication years
7. Query Restricted APIs (Stubs)
{
"tool": "query_dbgap",
"input": {
"query": "GWAS cardiovascular disease"
}
}
Returns: [dbGaP stub] Querying: "GWAS cardiovascular disease". Access requires NIH credentials & dbGaP approval.
Note: Stubs for dbGaP, PhysioNet, MIMIC-IV, UK Biobank, DrugBank, BindingDB, OpenTrials, and Crunchbase return informational messages. Replace the stub functions in
src/clients/restrictedStubs.tswith real implementations once you have credentials.
π οΈ Project Structure
mcp-biomed-server/
βββ src/
β βββ server.ts # Main MCP server with all 14 tools
β βββ clients/
β βββ clinicalTrialsClient.ts # ClinicalTrials.gov
β βββ chemblClient.ts # ChEMBL
β βββ pubchemClient.ts # PubChem
β βββ openfdaClient.ts # OpenFDA
β βββ europePmcClient.ts # Europe PMC
β βββ restrictedStubs.ts # Stubs for restricted APIs
βββ dist/ # Compiled JavaScript (after build)
βββ .vscode/
β βββ mcp.json # VS Code MCP config
βββ .env.example # Environment variable template
βββ package.json
βββ tsconfig.json
βββ README.md
π§ Development
Adding a New Tool
- Create a client function in
src/clients/(or add to existing file) - Register the tool in
src/server.ts:server.registerTool( 'my_tool_name', { title: 'My Tool', description: 'What it does', inputSchema: { param: z.string().describe('Parameter description') }, outputSchema: { result: z.string() } }, async ({ param }) => { const result = await myClientFunction(param); return { content: [{ type: 'text', text: JSON.stringify({ result }) }], structuredContent: { result } }; } ); - Rebuild:
npm run build
Debugging
- Use
npm run devfor live TypeScript execution viatsx - Server logs errors to
stderr(visible in MCP Inspector or client logs) - Check rate limits if APIs return HTTP 429
βοΈ Rate Limits & Best Practices
| API | Rate Limit | Notes |
|---|---|---|
| ClinicalTrials.gov | ~1000 req/day | No key required; public access |
| ChEMBL | Unknown (generous) | No key; community-supported |
| PubChem | ~5 req/sec | No key; use delays for bulk requests |
| OpenFDA | 240 req/min (1000/day without key) | API key increases to 240 req/min |
| Europe PMC | Unknown (generous) | No key; rate-limited |
Tips:
- Use
pageSize/limitparameters to control result counts - Add exponential backoff for HTTP 429 errors
- Consider caching responses for repeated queries
π References
- Model Context Protocol Docs
- MCP TypeScript SDK
- ClinicalTrials.gov API
- ChEMBL API
- PubChem PUG REST
- OpenFDA API
- Europe PMC API
π License
MIT (adjust as needed for your project)
π€ Contributing
- Fork the repository
- Create a feature branch (
git checkout -b feature/new-api) - Add your client in
src/clients/ - Register tools in
src/server.ts - Test with MCP Inspector
- Submit a pull request
π Troubleshooting
"Cannot find module" errors
npm install # Reinstall dependencies
npm run build # Rebuild after changes
VS Code doesn't recognize the MCP server
- Ensure
.vscode/mcp.jsonexists - Rebuild:
npm run build - Restart VS Code
- Check VS Code's MCP output panel for errors
API returns 429 (Too Many Requests)
- Add delays between requests
- Use optional API keys (OpenFDA, Crunchbase)
- Reduce
pageSize/limitparameters
Stub tools return placeholder messages
- This is expected! Restricted APIs require credentials
- Replace functions in
src/clients/restrictedStubs.tswith real implementations
π Next Steps
- Test all 14 tools with MCP Inspector
- Connect to VS Code Copilot and try example queries
- Replace stubs with real API implementations (if you have access)
- Add rate limiting and caching for production use
- Extend with more APIs: BindingDB real download, OpenTrials integration, etc.
Built with π using Model Context Protocol
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.