MCP Medical Appointments Demo
Enables users to manage medical appointments by searching for doctors, checking availability, and booking sessions through a natural language interface. It serves as a reference implementation for advanced MCP features like symptom-based specialist recommendations and multi-step scheduling workflows.
README
MCP Medical Appointments Demo
A working reference for the Model Context Protocol — tools, resources, prompts, elicitation, sampling, and completion — built around a medical appointment scheduling domain.
Built with TypeScript, Hono, MCP SDK, and Zod.
Table of Contents
- Features
- Quick Start
- Architecture
- REST API Endpoints
- Project Structure
- Scripts
- Domain Model
- Configuration
- Contributing
- License
Features
MCP Server Primitives
| Primitive | Name | Description |
|---|---|---|
| Tool | search_doctors |
Search doctors by name or specialty |
| Tool | get_available_slots |
Get available time slots for a doctor on a date |
| Tool | book_appointment |
Book an appointment (uses elicitation for confirmation) |
| Tool | cancel_appointment |
Cancel an appointment (uses elicitation for confirmation) |
| Tool | list_appointments |
List appointments with filters |
| Tool | recommend_specialist |
Symptom-based specialist recommendation (uses sampling) |
| Resource | specialties://list |
Static list of all medical specialties |
| Resource | doctor://{doctorId}/profile |
Dynamic doctor profile with template |
| Resource | patient://{patientId}/summary |
Patient info + appointment history |
| Resource | appointment://{appointmentId} |
Full appointment details |
| Prompt | schedule-appointment |
Guided appointment scheduling workflow (with completion) |
| Prompt | patient-history |
Patient history review (with completion) |
| Prompt | triage-symptoms |
Symptom triage and specialist recommendation |
MCP Client Features
| Feature | How It's Used |
|---|---|
| Elicitation | book_appointment and cancel_appointment ask the user to confirm before proceeding |
| Sampling | recommend_specialist uses LLM sampling to match symptoms to specialties |
| Roots | Server registers a root for the medical appointments workspace |
| Completion | Prompts use completable() for auto-completing specialty names and patient IDs |
Quick Start
Prerequisites
- Node.js >= 22.0.0
- VS Code with GitHub Copilot (for MCP integration)
1. Install and start the REST API
npm install
npm run dev:service
You should see:
Bootstrapped: 8 specialties, 12 doctors, 5 patients
Medical Appointment Service running on http://localhost:3000
2. Connect the MCP Server in VS Code
The .vscode/mcp.json file is already configured. VS Code will automatically detect and offer to start the MCP server. Alternatively, run it manually:
npm run dev:mcp
3. Try it out
In VS Code's Copilot Chat (Agent mode), try:
- "Search for cardiologists"
- "What slots does Dr. Sarah Chen have available next Monday?"
- "Book an appointment with doc-3 for patient pat-1"
- "Show me Alice Johnson's appointment history"
- "I've been having severe headaches and dizziness — what specialist should I see?"
Or use the prompts from the prompt picker:
- Schedule Appointment — guided scheduling workflow
- Patient History — review a patient's visits
- Triage Symptoms — symptom-based specialist matching
Architecture
┌─────────────────┐ stdio ┌───────────────────┐ HTTP ┌──────────────────┐
│ VS Code / │◄──────────────►│ MCP Server │─────────────►│ Hono REST API │
│ MCP Client │ │ (TypeScript) │ localhost │ (localhost:3000) │
└─────────────────┘ └───────────────────┘ └──────────────────┘
Tools, Resources, In-memory store
Prompts + JSON bootstrap
The project uses a two-process design:
- Hono REST API — HTTP service with an in-memory data store, bootstrapped from JSON seed files in
data/. - MCP Server — Connects via stdio and exposes the REST API through MCP primitives (tools, resources, prompts).
The MCP server never touches the data store directly — it calls the REST API through an HTTP client, keeping the two layers cleanly separated.
REST API Endpoints
| Method | Endpoint | Description |
|---|---|---|
GET |
/api/specialties |
List all specialties |
GET |
/api/specialties/:id |
Get specialty by ID |
GET |
/api/doctors |
List doctors (filters: ?specialtyId=, ?name=) |
GET |
/api/doctors/:id |
Get doctor by ID |
GET |
/api/doctors/:id/slots?date=YYYY-MM-DD |
Get available slots |
GET |
/api/patients |
List all patients |
GET |
/api/patients/:id |
Get patient by ID |
POST |
/api/patients |
Create a patient |
GET |
/api/appointments |
List appointments (filters: ?patientId=, ?doctorId=, ?status=, ?date=) |
GET |
/api/appointments/:id |
Get appointment by ID |
POST |
/api/appointments |
Book an appointment |
PATCH |
/api/appointments/:id/cancel |
Cancel an appointment |
PATCH |
/api/appointments/:id/complete |
Complete an appointment |
Project Structure
mcp-demo/
├── data/
│ ├── specialties.json # 8 medical specialties
│ ├── doctors.json # 12 doctors across specialties
│ └── patients.json # 5 sample patients
├── src/
│ ├── types.ts # Shared domain types
│ ├── service/
│ │ ├── store.ts # In-memory data store
│ │ ├── app.ts # Hono app composition
│ │ ├── main.ts # Service entry point
│ │ └── routes/ # REST route handlers
│ └── mcp/
│ ├── api-client.ts # HTTP client for the REST API
│ ├── tools.ts # MCP tool registrations
│ ├── resources.ts # MCP resource registrations
│ ├── prompts.ts # MCP prompt registrations
│ └── server.ts # MCP server entry point
├── .vscode/
│ └── mcp.json # VS Code MCP server config
├── package.json
└── tsconfig.json
Scripts
| Command | Description |
|---|---|
npm run dev:service |
Start the Hono REST API with hot reload |
npm run dev:mcp |
Start MCP server in stdio mode |
npm run build |
Compile TypeScript to dist/ |
npm run typecheck |
Type-check without emitting files |
Domain Model
| Entity | Description |
|---|---|
| Specialty | Medical specialty (Cardiology, Dermatology, etc.) |
| Doctor | Has a specialty, available days, working hours, and slot duration |
| Patient | Name, email, phone, date of birth |
| Appointment | Links a patient to a doctor at a specific date/time with a reason and status |
| TimeSlot | Available or booked time window for a doctor on a given day |
Configuration
The REST API listens on port 3000 by default. The MCP server communicates with the API over http://localhost:3000 and connects to VS Code via stdio.
Seed data (specialties, doctors, patients) is loaded from the data/ directory on startup. Edit those JSON files to customize the demo dataset.
Contributing
Contributions are welcome. Fork the repo, create a feature branch, and open a pull request.
License
MIT
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.