NINSAÚDE MCP Server
A comprehensive MCP server for integrating with the NINSAÚDE Clinic API, providing 45+ tools for healthcare management including patient records, appointments, medical records, billing, reporting, and patient surveys.
README
NINSAÚDE MCP Server
A comprehensive MCP (Model Context Protocol) server for integrating with the NINSAÚDE Clinic API, providing 45+ tools for healthcare management including patient records, appointments, medical records, billing, reporting, and patient surveys.
Features
- Secure Authentication: Refresh-token-first OAuth2 authentication with maximum security
- One-time credential usage: Credentials used only once to obtain refresh_token
- Persistent storage: Refresh token stored securely in ~/.ninsaude/tokens.json (0o600 permissions)
- No credential storage: Credentials never stored or transmitted after initialization
- Automatic renewal: All authentications use refresh_token only
- In-memory caching: Access tokens cached temporarily (15min expiry, 1min safety buffer)
- Rate Limiting: Automatic request throttling with configurable minimum intervals (default 60s between requests)
- Patient Management: Complete CRUD operations for patient records
- Appointment System: Schedule, reschedule, and manage appointments
- Medical Records: Create and manage electronic health records
- Financial Management: Track revenue, expenses, and payment status
- Reporting: Generate various reports for appointments, finances, and patients
- Professional & Service Management: Manage healthcare providers and services
- Insurance Integration: Handle insurance companies and plans
- Alert System: Create patient alerts and blocks
- Survey System: Create and send patient surveys, collect responses, and analyze results
Installation
Quick Installation for Claude Desktop
macOS/Linux
# Clone the repository
git clone <repository-url>
cd MCP-NIN
# Run the installation script
./install-claude-desktop.sh
Windows
# Clone the repository
git clone <repository-url>
cd MCP-NIN
# Run the installation script
powershell -ExecutionPolicy Bypass -File install-claude-desktop.ps1
Manual Installation
# Clone the repository
git clone <repository-url>
cd MCP-NIN
# Install dependencies
npm install
# Build the TypeScript code
npm run build
Configuration
1. Environment Setup
Create a .env file with your NINSAÚDE API credentials:
cp .env.example .env
Edit .env with your credentials:
NINSAUDE_API_URL=https://api.ninsaude.com/v1
NINSAUDE_ACCOUNT=your_account_here
NINSAUDE_USERNAME=your_username_here
NINSAUDE_PASSWORD=your_password_here
NINSAUDE_ACCOUNT_UNIT=your_unit_id_here
# Optional: Configure rate limiting (default is 60 seconds)
NINSAUDE_RATE_LIMIT_SECONDS=60
Important: Credentials are only used once during initialization. After that, they are never used or stored again.
2. Authentication Initialization
Initialize authentication to generate and store the refresh token:
npm run token:init
This command will:
- ✓ Authenticate with your credentials (one-time only)
- ✓ Obtain and store refresh_token securely in
~/.ninsaude/tokens.json - ✓ Set file permissions to 0o600 (owner read/write only)
- ✓ Clear credentials from memory after obtaining token
Security Note: After initialization, your credentials are never used or transmitted again. All future authentications use only the refresh_token.
3. Token Management Commands
# Check authentication status
npm run token:status
# Revoke token and clear storage (logout)
npm run token:revoke
# Get help
npm run token:help
Rate Limiting Configuration
The MCP server includes built-in rate limiting to prevent overwhelming the NINSAÚDE API:
- Default Interval: 60 seconds between requests
- Configurable: Set
NINSAUDE_RATE_LIMIT_SECONDSin.env - Automatic: All API requests automatically respect the configured interval
- Transparent: Requests are queued and delayed as needed
- Monitoring: Check rate limiter statistics for debugging
The rate limiter ensures compliance with API usage policies and prevents service disruptions due to excessive requests.
Claude Desktop Integration
The installation scripts automatically configure Claude Desktop. If you need to configure manually:
-
Locate Claude Desktop config file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
- macOS:
-
Add the NINSAÚDE MCP server configuration:
{
"mcpServers": {
"ninsaude-mcp-server": {
"command": "node",
"args": ["/path/to/MCP-NIN/dist/index.js"],
"env": {
"NODE_ENV": "production"
}
}
}
}
- Restart Claude Desktop to load the new server
Usage
Starting the Server
# Production mode
npm start
# Development mode
npm run dev
Available Tools
Authentication Tools
ninsaude_get_token- Get OAuth2 access tokenninsaude_revoke_token- Revoke current refresh token
Unit Management
ninsaude_list_units- List healthcare unitsninsaude_get_unit- Get specific unit details
Patient Management
ninsaude_list_patients- List patients with filteringninsaude_get_patient- Get patient by IDninsaude_create_patient- Create new patientninsaude_update_patient- Update patient informationninsaude_delete_patient- Delete patient record
Appointment Management
ninsaude_list_appointments- List appointments with filtersninsaude_get_appointment- Get appointment detailsninsaude_create_appointment- Create new appointmentninsaude_update_appointment_status- Update appointment statusninsaude_reschedule_appointment- Reschedule appointmentninsaude_list_available_slots- Check available time slots
Professional & Service Management
ninsaude_list_professionals- List healthcare professionalsninsaude_get_professional- Get professional detailsninsaude_list_services- List available servicesninsaude_get_service- Get service details
Medical Records
ninsaude_list_medical_records- List medical recordsninsaude_get_medical_record- Get specific medical recordninsaude_create_medical_record- Create new medical recordninsaude_list_prescriptions- List prescriptions
Financial Management
ninsaude_list_financial_records- List financial recordsninsaude_get_financial_record- Get financial record detailsninsaude_create_financial_record- Create financial entryninsaude_update_financial_status- Update payment status
Insurance Management
ninsaude_list_insurances- List insurance companiesninsaude_get_insurance- Get insurance details
Reporting Tools
ninsaude_appointment_report- Generate appointment reportsninsaude_financial_report- Generate financial reportsninsaude_patient_report- Generate patient reports
Additional Tools
ninsaude_list_documents- List document templatesninsaude_list_patient_alerts- List patient alertsninsaude_create_patient_alert- Create patient alert
Examples
Creating a Patient
{
"tool": "ninsaude_create_patient",
"arguments": {
"nome": "João Silva",
"cpf": "12345678901",
"dataNascimento": "1990-05-15",
"sexo": "M",
"email": "joao.silva@email.com",
"celular": "11999999999",
"endereco": {
"cep": "01310-100",
"logradouro": "Av. Paulista",
"numero": "1000",
"bairro": "Bela Vista",
"cidade": "São Paulo",
"estado": "SP"
}
}
}
Scheduling an Appointment
{
"tool": "ninsaude_create_appointment",
"arguments": {
"pacienteId": 123,
"profissionalId": 45,
"unidadeId": 1,
"servicoId": 10,
"dataHora": "2024-01-20 14:00:00",
"duracao": 30,
"observacoes": "First consultation"
}
}
Listing Appointments with Filters
{
"tool": "ninsaude_list_appointments",
"arguments": {
"filter": {
"dataInicio": "2024-01-01",
"dataFim": "2024-01-31",
"status": "AGENDADO",
"profissionalId": 45
},
"limit": 20,
"order": "-dataHora"
}
}
Creating a Medical Record
{
"tool": "ninsaude_create_medical_record",
"arguments": {
"pacienteId": 123,
"profissionalId": 45,
"agendamentoId": 789,
"anamnese": "Patient reports headaches for the past week",
"exameFisico": "Blood pressure: 120/80, Temperature: 36.5°C",
"hipoteseDiagnostica": "Tension headache",
"conduta": "Rest and hydration recommended",
"prescricao": [
{
"medicamento": "Paracetamol 500mg",
"dosagem": "1 tablet",
"frequencia": "Every 8 hours",
"duracao": "3 days",
"observacoes": "Take with food"
}
]
}
}
Development
Running Tests
# Run all tests
npm test
# Run tests in watch mode
npm run test:watch
# Generate coverage report
npm test -- --coverage
Linting and Formatting
# Run ESLint
npm run lint
# Format code with Prettier
npm run format
API Rate Limits and Best Practices
- Automatic Rate Limiting: The server enforces a minimum interval between requests (default 60s). All requests are automatically delayed if needed
- Configuration: Adjust
NINSAUDE_RATE_LIMIT_SECONDSin.envto change the minimum interval (not recommended to go below 30s) - Monitoring: Rate limiting is logged to stderr for debugging and monitoring
- Pagination: Use pagination parameters (
limit,offset) for large datasets - Caching: Cache frequently accessed data when possible to reduce API calls
- Error Handling: Handle errors gracefully and check error responses
- Token Lifecycle:
- Refresh tokens stored persistently (no expiration until revoked)
- Access tokens cached in memory for 15 minutes
- Automatic renewal using refresh_token only
- No credentials required after initial setup
Error Handling
All tools return consistent error formats:
{
"error": "Error message description"
}
For API errors, the format includes the HTTP status code:
{
"error": "404: Record not found"
}
Contributing
- Fork the repository
- Create your 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
Support
For issues and questions:
- Check the NINSAÚDE API documentation
- Review error messages for specific error codes
- Open an issue in the repository
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。