careflow-mcp
Enables Claude and other AI assistants to trigger HIPAA-compliant patient task management workflows through natural language.
README
CareFlow MCP š„
Production-ready healthcare workflow automation powered by n8n and the Model Context Protocol. Enables Claude and other AI assistants to trigger HIPAA-compliant patient task management workflows through natural language.
š„ Healthcare-Ready: Includes comprehensive HIPAA compliance documentation and patient task management workflows.
Features
- š Trigger Workflows - Execute n8n workflows via webhook with custom payloads
- š List Workflows - Query all active workflows from your n8n instance
- š Check Status - Monitor workflow execution status in real-time
- š„ Healthcare-Ready - Built-in support for patient task workflows
- š Type-Safe - Full TypeScript support with Zod validation
- ā” Production-Ready - Comprehensive error handling and logging
- š ļø MCP Standard - Compatible with Claude Desktop and other MCP clients
š Documentation & Examples
- [Case Studies][(./case-studies/README.md)] - 5 real-world implementation examples with ROI metrics
- HEALTHCARE.md - Comprehensive HIPAA compliance guide (our differentiator!)
- Example Workflows - Importable n8n workflow JSON files
Quick Start with Examples
# 1. Import workflow to n8n
examples/healthcare-patient-task-workflow.json
# 2. Configure credentials in n8n
# 3. Ask Claude:
"Create a patient task for ID P12345 in the Patient Care workflow"
Tools Exposed
| Tool | Description | Required Params |
|---|---|---|
trigger_workflow |
Triggers an n8n workflow by name with JSON payload | workflowName, payload |
list_workflows |
Lists all active workflows from n8n | None |
get_workflow_status |
Checks execution status by ID | executionId |
create_patient_task |
Sends structured patient task to workflow | workflowName, patientId, taskType |
Prerequisites
- Node.js >= 18.0.0
- n8n instance (cloud or self-hosted) with API access
- n8n API Key (generate in n8n Settings > API)
Installation
Option 1: Via Smithery (Easiest)
Install directly from mcp.so using Smithery:
npx @smithery/cli install careflow-mcp
This will automatically:
- Install the package
- Add to your Claude Desktop config
- Prompt for required environment variables
Option 2: NPM Installation
npm install -g careflow-mcp
Option 3: From Source
# Clone the repository
git clone https://github.com/pratapsfdc22-dev/careflow-mcp.git
cd careflow-mcp
# Install dependencies
npm install
# Build the project
npm run build
# Link globally (optional)
npm link
Configuration
1. Create Environment File
cp .env.example .env
2. Configure Environment Variables
Edit .env with your n8n credentials:
# Base URL of your n8n instance
N8N_BASE_URL=https://your-n8n-instance.com
# n8n API Key (Settings > API > Create API Key)
N8N_API_KEY=n8n_api_xxxxxxxxxxxxxxxxxxxxxxxx
# Optional: Webhook Secret
N8N_WEBHOOK_SECRET=your_webhook_secret
3. Configure Claude Desktop
Add to your claude_desktop_config.json:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%/Claude/claude_desktop_config.json
{
"mcpServers": {
"n8n-workflow": {
"command": "node",
"args": [
"/path/to/careflow-mcp/dist/index.js"
],
"env": {
"N8N_BASE_URL": "https://your-n8n-instance.com",
"N8N_API_KEY": "your_api_key_here",
"N8N_WEBHOOK_SECRET": "your_webhook_secret"
}
}
}
}
Using npm global install:
{
"mcpServers": {
"n8n-workflow": {
"command": "careflow-mcp",
"env": {
"N8N_BASE_URL": "https://your-n8n-instance.com",
"N8N_API_KEY": "your_api_key_here"
}
}
}
}
Usage Examples
1. Trigger a Workflow
// Ask Claude:
"Trigger the 'Customer Onboarding' workflow with this data:
{ email: 'user@example.com', name: 'John Doe' }"
2. List All Active Workflows
// Ask Claude:
"Show me all active n8n workflows"
3. Check Workflow Execution Status
// Ask Claude:
"Check the status of execution ID: abc123"
4. Create a Patient Task
// Ask Claude:
"Create a high-priority follow-up task for patient ID P12345
in the 'Patient Care' workflow, due tomorrow"
Development
Build
npm run build
Watch Mode
npm run watch
Run Locally
npm run dev
Clean Build Artifacts
npm run clean
Project Structure
careflow-mcp/
āāā src/
ā āāā index.ts # Main MCP server implementation
ā āāā types.ts # TypeScript types and Zod schemas
āāā dist/ # Compiled JavaScript (generated)
āāā .env.example # Environment variable template
āāā .gitignore # Git ignore rules
āāā package.json # NPM package configuration
āāā tsconfig.json # TypeScript configuration
āāā README.md # This file
API Reference
trigger_workflow
Triggers an n8n workflow by name with optional JSON payload.
Input:
{
workflowName: string; // Name of the workflow
payload?: object; // Optional JSON data
}
Output:
{
"success": true,
"workflowId": "abc123",
"workflowName": "Customer Onboarding",
"response": { ... }
}
list_workflows
Lists all active workflows from n8n instance.
Input: None
Output:
{
"success": true,
"count": 5,
"workflows": [
{
"id": "abc123",
"name": "Customer Onboarding",
"active": true,
"createdAt": "2024-01-01T00:00:00.000Z",
"updatedAt": "2024-01-15T12:00:00.000Z"
}
]
}
get_workflow_status
Checks the execution status of a workflow run.
Input:
{
executionId: string; // Execution ID from trigger response
}
Output:
{
"success": true,
"execution": {
"id": "exec123",
"workflowId": "abc123",
"finished": true,
"status": "success",
"startedAt": "2024-01-15T12:00:00.000Z",
"stoppedAt": "2024-01-15T12:00:05.000Z"
}
}
create_patient_task
Sends a structured patient task to an n8n workflow.
Input:
{
workflowName: string; // Target workflow
patientId: string; // Patient identifier
taskType: string; // Task type
priority?: "low" | "medium" | "high" | "urgent";
description?: string;
dueDate?: string; // ISO 8601 format
assignedTo?: string;
metadata?: object;
}
Output:
{
"success": true,
"workflowId": "abc123",
"workflowName": "Patient Care",
"task": { ... },
"response": { ... }
}
Error Handling
The server implements comprehensive error handling with proper MCP error codes:
- Invalid Parameters -
ErrorCode.InvalidParams - Method Not Found -
ErrorCode.MethodNotFound - Internal Error -
ErrorCode.InternalError
All errors include descriptive messages for debugging.
Security Best Practices
- Never commit
.env- Always use.env.examplefor templates - Rotate API keys - Regularly update your n8n API keys
- Use webhook secrets - Add authentication to webhook triggers
- Restrict API access - Use n8n's API key permissions
- Monitor logs - Check server logs for suspicious activity
Troubleshooting
Server won't start
# Check Node.js version
node --version # Should be >= 18.0.0
# Verify environment variables
cat .env
# Check TypeScript compilation
npm run build
Workflow not found
- Verify the workflow name matches exactly (case-sensitive)
- Ensure the workflow is active in n8n
- Check API key has permission to access workflows
Authentication failed
- Verify
N8N_API_KEYis correct - Check
N8N_BASE_URLincludes protocol (https://) - Ensure API key hasn't expired
Webhook trigger fails
- Verify webhook node exists in workflow
- Check webhook path matches workflow ID
- Confirm
N8N_WEBHOOK_SECRETif required
Contributing
Contributions are welcome! Please:
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
MIT License - see LICENSE file for details.
Acknowledgments
- Built with Model Context Protocol SDK
- Powered by n8n workflow automation
- Type validation by Zod
Support
- š Issues: GitHub Issues
- š¬ Discussions: GitHub Discussions
- š Documentation: Full API Reference
Built with the 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.