jcafazzo/fhir-mcp
If you are the rightful owner of fhir-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 henry@mcphub.com.
A comprehensive Model Context Protocol (MCP) server that provides FHIR (Fast Healthcare Interoperability Resources) functionality with advanced data quality assessment and error handling capabilities.
FHIR MCP Server
A comprehensive Model Context Protocol (MCP) server that provides FHIR (Fast Healthcare Interoperability Resources) functionality with advanced data quality assessment and error handling capabilities.
๐ฏ Overview
This MCP server bridges the gap between AI applications and FHIR healthcare data systems, providing robust tools for accessing patient information, clinical data, and assessing data quality across different FHIR servers. Perfect for healthcare AI development, clinical research, and testing FHIR implementations.
โจ Key Features
๐ฅ Comprehensive FHIR Resource Access
- Patient Management: Search, retrieve, and analyze patient demographics
- Clinical Data: Access observations, conditions, medications, diagnostic reports
- Care Coordination: Retrieve care plans and treatment information
- Server Capabilities: Query FHIR server metadata and supported features
๐ Advanced Data Quality Assessment
- Quality Scoring: 0-100 data quality scores for FHIR servers
- Integrity Checks: Detect orphaned references and disconnected data
- Validation: Comprehensive FHIR response validation
- Issue Detection: Identify data consistency problems automatically
๐ก๏ธ Enhanced Error Handling
- HTTP Status Handling: Proper 404, 401, 403, timeout responses
- FHIR OperationOutcome: Standards-compliant error reporting
- Detailed Logging: Request/response debugging information
- Graceful Degradation: Continues operation despite server issues
๐งฐ Developer-Friendly Tools
- Async Architecture: High-performance async/await implementation
- Pagination Support: Handle large datasets efficiently
- Flexible Configuration: Environment-based server configuration
- MCP Integration: Seamless Claude Desktop integration
๐ Quick Start
Prerequisites
- Python 3.11 or newer
- Claude Desktop (for MCP integration)
Installation
-
Clone the repository
git clone https://github.com/jcafazzo/fhir-mcp.git cd fhir-mcp
-
Install dependencies
pip install -r requirements.txt
-
Configure Claude Desktop
Add to your
claude_desktop_config.json
:{ "mcpServers": { "fhir-server": { "command": "python3", "args": ["/path/to/fhir-mcp/fhir_mcp_server.py"], "env": { "FHIR_BASE_URL": "https://r4.smarthealthit.org" } } } }
-
Restart Claude Desktop
๐ง Configuration
Environment Variables
Variable | Description | Default |
---|---|---|
FHIR_BASE_URL | FHIR server endpoint | https://hapi.fhir.org/baseR4 |
FHIR_AUTH_TOKEN | Bearer token for authentication | None |
Recommended FHIR Servers
Server | URL | Quality | Use Case |
---|---|---|---|
SMART Health IT | https://r4.smarthealthit.org | โญโญโญโญโญ | Production testing |
Firely Server | https://server.fire.ly | โญโญโญโญ | Development |
HAPI Test | https://hapi.fhir.org/baseR4 | โญโญ | Basic testing |
๐ ๏ธ Available Tools
Core Patient Tools
get_patient
- Retrieve specific patient by IDsearch_patients
- Search patients by name/familysearch_all_patients
- Get all patients (paginated)
Clinical Data Tools
search_observations
- Find lab results, vital signs, measurementssearch_conditions
- Access diagnoses and medical conditionssearch_medication_requests
- Retrieve prescriptions and medicationssearch_diagnostic_reports
- Get lab reports and diagnostic studiessearch_care_plans
- Access treatment and care plans
Quality & Diagnostics
assess_data_quality
- Comprehensive server quality assessmentfind_patients_with_conditions
- Identify patients with clinical dataget_capability_statement
- Query server capabilities
๐ Usage Examples
Basic Patient Search
"Search for patients named 'Smith' and show their demographics"
Diabetes Management Workflow
"Find all patients with diabetes conditions, then show their:
- Current medications
- Recent glucose observations
- Active care plans
- Latest diagnostic reports"
Data Quality Assessment
"Assess the data quality of this FHIR server and identify any issues"
Research Query
"Find patients with conditions containing 'diabetes' and analyze their
medication patterns over time"
๐ฅ Healthcare Use Cases
Clinical Research
- Population Studies: Analyze patient cohorts across multiple conditions
- Treatment Outcomes: Track medication effectiveness and care plan adherence
- Data Quality: Validate FHIR implementations before production use
AI Development
- Training Data: Access clean, validated healthcare datasets
- Model Testing: Evaluate AI models against real clinical scenarios
- Integration Testing: Verify FHIR API compatibility
Quality Assurance
- Server Validation: Assess FHIR server implementations
- Data Integrity: Identify orphaned records and missing references
- Compliance Testing: Verify standards adherence
๐ Security & Privacy
- No PHI Storage: Server operates read-only, no data retention
- Configurable Auth: Support for Bearer token authentication
- Audit Logging: Comprehensive request/response logging
- Error Handling: Secure error responses without data leakage
๐งช Testing
Test Server Quality
# Test different FHIR servers
python3 fhir_mcp_server.py
Use the assess_data_quality
tool to evaluate:
- Data completeness (0-100 score)
- Reference integrity
- Resource availability
- Error rates
Synthetic Data Testing
Works excellently with:
- Synthea: Realistic synthetic patient data
- MIMIC-IV FHIR: Real anonymized hospital data
- Custom datasets: Load your own test data
๐ค Contributing
We welcome contributions! Please see our for details.
Development Setup
# Clone and setup development environment
git clone https://github.com/jcafazzo/fhir-mcp.git
cd fhir-mcp
pip install -r requirements.txt
python3 fhir_mcp_server.py # Test locally
Roadmap
- Bulk FHIR operations support
- Temporal data analysis tools
- Enhanced MIMIC-IV integration
- Performance optimization
- Additional FHIR resource types
๐ Documentation
- - Claude Code integration guide
- FHIR R4 Specification - Official FHIR documentation
- MCP Protocol - Model Context Protocol specification
๐ License
This project is licensed under the MIT License - see the file for details.
๐ Acknowledgments
- HL7 FHIR Community for the FHIR specification
- Anthropic for the Model Context Protocol
- SMART Health IT for excellent test servers
- Synthea Project for realistic synthetic data
๐ Support
- Issues: GitHub Issues
- Discussions: GitHub Discussions
- Documentation: Check for detailed setup
Built with โค๏ธ for the healthcare AI community