Diabetes:M MCP Server
Integrates Diabetes:M data with Claude Desktop to access glucose readings, insulin data, food diary, and health metrics through natural language conversations.
README
Diabetes:M MCP Server
Server MCP (Model Context Protocol) per integrare i dati di Diabetes:M con Claude Desktop. Accedi alle tue letture glicemiche, dati insulina, diario alimentare e metriche di salute attraverso conversazioni in linguaggio naturale.
β¨ FunzionalitΓ
- 11 Strumenti MCP per accesso completo ai dati del diabete
- Sicurezza multi-livello con crittografia AES-256-GCM
- Integrazione keyring di sistema per archiviazione sicura della chiave master (Windows Credential Vault, macOS Keychain, Linux Secret Service)
- Credenziali criptate nel profilo utente (mai nei file di configurazione)
- Autenticazione basata su cookie (reverse-engineered da analytics.diabetes-m.com)
- Ricerca cibi intelligente dalle voci del tuo diario
- Logging di audit completo
π§ Strumenti Disponibili
Gestione Credenziali
| Strumento | Descrizione |
|---|---|
setup_credentials |
Configura il login Diabetes:M in modo sicuro |
check_credentials |
Verifica se le credenziali sono configurate |
clear_credentials |
Rimuovi le credenziali memorizzate |
Strumenti Dati Salute
| Strumento | Descrizione |
|---|---|
get_logbook_entries |
Recupera voci del diario (glicemia, insulina, carboidrati, note) |
get_glucose_statistics |
Ottieni distribuzione glucosio, media, HbA1c stimata |
get_insulin_analysis |
Analizza utilizzo insulina e rapporti carboidrati |
get_iob |
Calcola l'Insulina Attiva (IOB) - insulina ancora in azione nel corpo |
get_ic_ratios |
Ottieni i rapporti IC (insulina/carboidrati) e ISF configurati per fascia oraria |
get_personal_metrics |
Ottieni peso, BMI, pressione sanguigna, HbA1c |
search_foods |
Cerca nel database cibi (include i tuoi cibi personalizzati dal diario) |
generate_health_report |
Genera report salute completo |
Prerequisiti
- Node.js 18.0 o superiore
- npm 8.0 o superiore
- Claude Desktop installato
- Account Diabetes-M Connect con credenziali valide
π Installazione Rapida (Bundle Precompilato)
Passaggi:
1. Installa Keytar (Raccomandato per sicurezza massima)
Per utilizzare il vault nativo del sistema operativo (Windows Credential Manager, macOS Keychain, Linux Secret Service), installa keytar:
npm install keytar
Nota: Se
keytarnon puΓ² essere installato, il sistema userΓ automaticamente un file criptato come fallback.
2. Scarica il bundle
Usa il browser oppure:
wget https://github.com/sedoglia/diabetes-m-mcp/releases/download/v1.1.0/diabetes-m-mcp.mcpb
3. Verifica l'integritΓ
Verifica l'integritΓ (opzionale ma consigliato):
wget https://github.com/sedoglia/diabetes-m-mcp/releases/download/v1.1.0/diabetes-m-mcp.mcpb.sha256
sha256sum -c diabetes-m-mcp.mcpb.sha256
4. Installa l'estensione in Claude Desktop (Metodo Consigliato)
Installazione tramite Custom Desktop Extensions:
- Apri Claude Desktop
- Vai su Impostazioni (Settings)
- Seleziona la scheda Estensioni (Extensions)
- Clicca su Impostazioni Avanzate (Advanced settings) e trova la sezione Extension Developer
- Clicca su "Installa Estensione..." (Install Extensionβ¦)
- Seleziona il file
.mcpb(diabetes-m-mcp.mcpbscaricato al passaggio 2) - Segui le indicazioni a schermo per completare l'installazione
Nota: Questo Γ¨ il metodo piΓΉ semplice e consigliato. L'estensione sarΓ automaticamente integrata in Claude Desktop senza necessitΓ di configurazione manuale.
5. Configura le Credenziali Diabetes-M (Metodo Sicuro - Raccomandato)
Apri una nuova chat su Claude Desktop e scrivi il seguente prompt:
Configura le credenziali di accesso per Diabetes-M
Rispondi al messaggio fornendo:
- Utente: la tua email Diabetes-M
- Password: la tua password Diabetes-M
L'estensione provvederΓ automaticamente a criptare e salvare le credenziali in modo sicuro nel vault nativo del sistema operativo (Windows Credential Manager, macOS Keychain, Linux Secret Service).
Nota: Le credenziali NON verranno salvate in file di testo. Saranno sempre crittografate e gestite dal vault nativo del SO.
6. Riavvia Claude Desktop
- Chiudi completamente l'applicazione
- Riapri Claude Desktop
- Verifica in Impostazioni β Sviluppatore lo stato della connessione β
π Installazione (clonando il repository con GIT)
1. Clona il Repository
git clone https://github.com/sedoglia/diabetes-m-mcp
cd diabetes-m-mcp
2. Installa le Dipendenze
npm install
3. Installa Keytar (Raccomandato per sicurezza massima)
Per utilizzare il vault nativo del sistema operativo (Windows Credential Manager, macOS Keychain, Linux Secret Service), installa keytar:
npm install keytar
Nota: Se
keytarnon puΓ² essere installato, il sistema userΓ automaticamente un file criptato come fallback.
4. Compila il Progetto
npm run build
5. Configura le Credenziali Diabetes-M (Metodo Sicuro - Raccomandato)
Esegui lo script di setup per configurare le credenziali in modo sicuro:
npm run setup-encryption
Questo script:
- Crea una directory sicura nella home dell'utente
- Genera una chiave di encryption e la salva nel vault nativo del SO
- Chiede email e password Diabetes-M
- Cripta e salva le credenziali in modo sicuro
Per verificare la configurazione:
npm run check-encryption
Nota sulla Sicurezza: Non commitare mai il file
.envnel controllo versione. Γ giΓ incluso in.gitignore. Si consiglia di usare il metodo sicuro sopra descritto.
6. Configurazione di Claude Desktop
Posizione del File di Configurazione
Il file di configurazione di Claude Desktop si trova in:
- Windows:
%APPDATA%\Claude\claude_desktop_config.json - macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
Esempio di Configurazione
Aggiungi il server MCP Diabetes-M al tuo claude_desktop_config.json:
{
"mcpServers": {
"Diabetes-M": {
"command": "node",
"args": ["C:\\percorso\\a\\diabetes-M-mcp\\dist\\index.js"]
}
}
}
Per macOS/Linux:
{
"mcpServers": {
"Diabetes-M": {
"command": "node",
"args": ["/percorso/a/diabetes-m-mcp/dist/index.js"]
}
}
}
Verifica della Configurazione
- Riavvia Claude Desktop dopo aver salvato la configurazione
- Cerca gli strumenti Diabetes-M tra quelli disponibili (icona martello)
- Prova a chiedere: "Quali sono le mie attivitΓ recenti su Diabetes-M?"
π¬ Esempi d'Uso
Configurazione Credenziali
"Configura le mie credenziali Diabetes:M con username mioutente e password miapassword"
Verifica Stato Credenziali
"Verifica lo stato delle mie credenziali Diabetes:M"
Ottieni Voci Diario
"Mostrami le voci del diario degli ultimi 7 giorni"
"Quali erano le mie letture glicemiche ieri?"
Ottieni Statistiche Glucosio
"Mostrami le statistiche glucosio degli ultimi 30 giorni"
"Qual Γ¨ la mia HbA1c stimata?"
"Com'Γ¨ il mio tempo nel range questo mese?"
Analizza Uso Insulina
"Analizza il mio uso di insulina nelle ultime 2 settimane"
"Qual Γ¨ la mia dose media giornaliera di insulina?"
Ottieni Insulina Attiva (IOB)
"Quanta insulina attiva ho in questo momento?"
"Calcola il mio IOB con DIA di 4 ore"
"Mostrami l'insulina on board attuale"
Ottieni Rapporti IC e ISF
"Quali sono i miei rapporti insulina/carboidrati?"
"Mostrami i rapporti IC per colazione, pranzo e cena"
"Qual Γ¨ il mio fattore di sensibilitΓ insulinica?"
Ottieni Metriche Personali
"Quali sono le mie metriche di salute attuali?"
"Mostrami la cronologia di peso e pressione sanguigna"
Cerca Cibi
"Cerca 'polenta' nel database cibi"
"Trova le info nutrizionali per la pasta"
Genera Report Salute
"Genera un report dettagliato sulla salute per gli ultimi 90 giorni"
π Architettura di Sicurezza
Protezione Multi-Livello
βββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β Livello 1: OS Keyring β
β Chiave master in Windows Vault / macOS Keychain / β
β Linux Secret Service β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
β Livello 2: Crittografia a Riposo β
β AES-256-GCM β’ IV/Salt casuali β’ PBKDF2 (100K iter) β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
β Livello 3: Storage Sicuro β
β %LOCALAPPDATA%/diabetes-m-mcp/ (Win) β
β ~/Library/Application Support/diabetes-m-mcp/ (Mac)β
β ~/.config/diabetes-m-mcp/ (Linux) β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
β Livello 4: Validazione Input β
β Schemi Zod β’ Prevenzione SQL injection β
β Rate limiting (1 req/sec) β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
β Livello 5: Audit Logging β
β Identificatori hashati β’ Log sensibili separati β
β Retention configurabile (default: 90 giorni) β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββ
Posizioni di Storage
I file di configurazione sono salvati in percorsi specifici per ogni sistema operativo:
| Sistema Operativo | Percorso |
|---|---|
| Windows | %LOCALAPPDATA%\diabetes-m-mcp\ |
| macOS | ~/Library/Application Support/diabetes-m-mcp/ |
| Linux | ~/.config/diabetes-m-mcp/ |
| File | Scopo |
|---|---|
diabetesm-credentials.enc |
Credenziali criptate |
diabetesm-tokens.enc |
Token sessione criptati |
diabetesm-audit.log |
Log audit (dati hashati) |
Nota: La chiave di crittografia master Γ¨ sempre salvata nel keyring nativo del sistema operativo (Windows Credential Vault, macOS Keychain, Linux Secret Service), non in questi file.
ποΈ Struttura Progetto
diabetes-m-mcp/
βββ src/
β βββ index.ts # Entry point
β βββ server.ts # Setup server MCP
β βββ api/
β β βββ auth.ts # Autenticazione (con gestione cookie)
β β βββ client.ts # Client HTTP
β β βββ endpoints.ts # Endpoint API (reverse-engineered)
β βββ security/
β β βββ audit.ts # Logging audit
β β βββ credentials.ts # Gestione credenziali
β β βββ encryption.ts # Crittografia AES-256-GCM
β β βββ keyring.ts # Integrazione keyring sistema
β βββ cache/
β β βββ encrypted-cache.ts # Cache criptata
β βββ tools/
β β βββ setup-credentials.ts
β β βββ get-logbook-entries.ts
β β βββ get-glucose-statistics.ts
β β βββ get-insulin-analysis.ts
β β βββ get-iob.ts # Calcolo IOB (Insulin on Board)
β β βββ get-ic-ratios.ts # Rapporti IC e ISF per fascia oraria
β β βββ get-personal-metrics.ts
β β βββ search-foods.ts # Cerca in API + voci diario
β β βββ generate-health-report.ts
β βββ types/
β βββ api.ts # Tipi API
β βββ security.ts # Tipi sicurezza
β βββ tools.ts # Schemi strumenti
βββ package.json
βββ tsconfig.json
βββ README.md
π§ͺ Test
Il progetto include una suite di test completa per verificare il funzionamento di tutti gli strumenti MCP con dati reali.
Eseguire i Test
npm test
Prerequisiti
- Le credenziali devono essere configurate (
npm run setup-encryption) - Il progetto deve essere compilato (
npm run build)
Strumenti Testati
| Test | Descrizione |
|---|---|
check_credentials |
Verifica configurazione credenziali |
get_logbook_entries (today) |
Voci diario di oggi |
get_logbook_entries (7days) |
Voci diario ultimi 7 giorni |
get_logbook_entries (date) |
Voci diario per data specifica |
get_glucose_statistics (7 days) |
Statistiche glicemia 7 giorni |
get_glucose_statistics (30 days) |
Statistiche glicemia 30 giorni |
get_insulin_analysis |
Analisi insulina e rapporti |
get_iob |
Calcolo Insulina Attiva (IOB) |
get_ic_ratios |
Rapporti IC e ISF per fascia oraria |
get_personal_metrics |
Metriche personali |
search_foods |
Ricerca cibi (database + diario) |
generate_health_report |
Generazione report salute |
Output Esempio
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
Diabetes:M MCP Server - Test Suite
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
βΈ Prerequisites
β Credentials configured
βΈ Credential Tools
β check_credentials (5ms)
βΈ Data Tools
β get_logbook_entries (today) (2279ms)
β get_logbook_entries (7days) (147ms)
β get_glucose_statistics (7 days) (175ms)
β get_insulin_analysis (7 days) (1116ms)
β get_personal_metrics (105ms)
β search_foods ("pasta") (1265ms)
β generate_health_report (7 days) (1083ms)
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
Test Summary
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
Passed: 13
Failed: 0
All tests passed! β
π Risoluzione Problemi
Errore "No credentials configured"
Esegui lo strumento setup_credentials:
"Configura le mie credenziali Diabetes:M"
Autenticazione Fallita
- Verifica che email/username e password siano corretti
- Prova ad accedere manualmente a analytics.diabetes-m.com
- Riesegui setup_credentials con le credenziali corrette
Problemi Keyring
Se il keyring di sistema non Γ¨ disponibile:
- Il server usa automaticamente lo storage file criptato come fallback
- Le chiavi sono memorizzate in
<config-dir>/master.key.enc - La sicurezza Γ¨ mantenuta attraverso crittografia specifica per macchina
Rate Limiting
Il server implementa rate limiting (1 richiesta/secondo). Se vedi errori di rate limit:
- Attendi qualche secondo e riprova
- Evita chiamate successive rapide
Ricerca Cibi Non Trova Risultati
La ricerca cibi dell'API Diabetes:M restituisce solo cibi dal database pubblico. Se cerchi i tuoi cibi personalizzati:
- Lo strumento cerca automaticamente nelle voci del tuo diario per i cibi personalizzati
- Assicurati di aver usato il cibo in una voce pasto negli ultimi 90 giorni
π Privacy Policy
Raccolta Dati
Questo server MCP raccoglie e tratta i seguenti dati:
- Credenziali Diabetes:M (username/password): Memorizzate localmente solo in forma criptata
- Dati salute: Letture glucosio, dosi insulina, log alimentari e metriche personali recuperate dal tuo account Diabetes:M
- Log audit: Log operazioni hashati per monitoraggio sicurezza (nessun dato salute grezzo)
Archiviazione Dati
- Tutti i dati sono memorizzati localmente sul tuo dispositivo nella directory specifica del SO:
- Windows:
%LOCALAPPDATA%\diabetes-m-mcp\ - macOS:
~/Library/Application Support/diabetes-m-mcp/ - Linux:
~/.config/diabetes-m-mcp/
- Windows:
- Le credenziali sono criptate con crittografia AES-256-GCM
- La chiave master di crittografia Γ¨ memorizzata nel tuo keyring del SO (Windows Credential Vault, macOS Keychain, o Linux Secret Service)
- Nessun dato memorizzato in file di configurazione o testo semplice
Trasmissione Dati
- I dati sono trasmessi solo ai server Diabetes:M (analytics.diabetes-m.com)
- Tutte le connessioni usano crittografia HTTPS/TLS
- Nessun dato inviato ad Anthropic, terze parti o altri server
Conservazione Dati
- I dati in cache scadono automaticamente (TTL 5 minuti per dati sensibili)
- I log audit sono conservati per 90 giorni di default
- Puoi eliminare tutti i dati memorizzati in qualsiasi momento usando lo strumento
clear_credentials
I Tuoi Diritti
- Hai pieno controllo sui tuoi dati
- Usa
clear_credentialsper rimuovere tutte le credenziali e token memorizzati - Elimina la directory di configurazione del SO per rimuovere tutti i dati locali
Servizi di Terze Parti
Questo server interagisce solo con:
- Diabetes:M (analytics.diabetes-m.com): Il tuo fornitore dati salute
π Licenza
MIT License - Vedi file LICENSE
β οΈ Disclaimer
Questo strumento Γ¨ solo per gestione personale della salute e scopi informativi. Non fornisce consigli medici. Consulta sempre il tuo medico per decisioni mediche.
Non affiliato, approvato o connesso a Diabetes:M o Sirma Medical Systems.
π Crediti
- API Diabetes:M reverse-engineered da analytics.diabetes-m.com
- Costruito con @modelcontextprotocol/sdk
- Ispirato da garmin-mcp-ts
β Supporto
Se trovi questo progetto utile, considera di supportare lo sviluppo:
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.