France Data MCP
This server provides a unified interface to cross-reference 13 French public data sources (INSEE, FINESS, RPPS, Ameli, CNAM, IGN, DVF, Sit@del, and more) for healthcare analytics, territorial studies, real estate assessment, and business intelligence.
Territory & Geocoding
Autocomplete and look up communes by name, postal code, or INSEE code
Geocode addresses to GPS coordinates (IGN Géoplateforme) and reverse geocode coordinates to addresses
Business / Enterprise Data (SIRENE)
Search companies by geography (radius), NAF code, or postal code
Look up a company by SIREN or establishment by SIRET (status, address, open/closed dates)
Healthcare Facilities (FINESS / DREES)
Search facilities (hospitals, labs, pharmacies, EHPADs, etc.) by radius or category
Get full facility details by FINESS number
Healthcare Professionals
Search liberal professionals (Ameli) or all practitioners (RPPS/ANS) by location, specialty, or department
List professionals attached to a specific FINESS establishment or search by name (fuzzy matching)
Get a professional's full record by RPPS ID
Health Centers (CNAM)
Search Centres de Santé by location or FINESS, filtered by specialty or carte Vitale acceptance
Demographics & Density (INSEE)
Get population data for a commune, department, or IRIS neighborhood
Get demographic profiles (age, CSP, income) at IRIS level (RP 2022 + FILOSOFI 2021)
Compute healthcare professional/facility density per 100k inhabitants with national comparison
Real Estate / Site Potential
Assess land costs (median €/m² from DVF transactions), building permits (Sit@del), and PLU urban zoning (IGN)
Composite Aggregators (single-call)
Territorial health panorama: population, PS densities, FINESS counts, and IRIS demographic profile
360° site inspection: FINESS identification + SIRENE status + attached professionals + INSEE history
Complete implantation study: territory, demographics, competitors, prescribers, health centers, and referential quality
Competitor deep-dive: activity status, team size, M&A signals, and parent group for up to 3 competitors
Cross-Source Reconciliation
Verify if a FINESS site is still active (FINESS ↔ RPPS ↔ SIRENE cross-check)
Compare legal names and addresses across FINESS, RPPS, and CNAM to detect rebranding or relocations
Reconstruct establishment history (openings, closures, NAF/name changes)
Reconcile FINESS with SIRENE using Sørensen-Dice scoring
Audit FINESS vs. SIRENE coverage within a radius to detect over/under-declaration
Geocodes addresses and performs reverse geocoding using IGN's Géoplateforme.
france-data-mcp
MCP TypeScript qui croise et réconcilie 13 référentiels publics français (INSEE SIRENE, IRIS & Melodi, FINESS DREES, RPPS / Annuaire Santé ANS, Annuaire Santé Ameli, Centres de Santé CNAM, DVF / DGFiP, Sit@del / SDES, PLU via apicarto, IGN Géoplateforme, geo.api.gouv.fr & Recherche Entreprises DINUM). Détecte les SIRET fermés invisibles côté DREES, distingue site vs groupe, croise l'offre de soins avec la démographie au quartier, évalue le potentiel immobilier d'un site (prix DVF €/m², permis de construire, zones AU du PLU), expose la fraîcheur de chaque source.
🇫🇷 Documentation principale en français. English version →
Installation
Option 1 — URL distante (claude.ai, Claude Code, Cursor)
https://france-data-mcp.vercel.app/mcp
Client | Config |
claude.ai | Settings → Connectors → Add custom connector → URL ci-dessus |
Claude Code |
|
Cursor |
|
Option 2 — Wrapper npm stdio (Claude Desktop natif, autres clients)
{
"mcpServers": {
"france-data": {
"command": "npx",
"args": ["-y", "france-data-mcp"]
}
}
}Le wrapper forwarde stdio → endpoint HTTPS distant. Aucune DB locale à provisionner. Override possible : FRANCE_DATA_MCP_URL=https://mon-miroir.example/mcp.
Détails par client + self-hosting : docs/installation-claude.md.
Related MCP server: datagouv-mcp
Pourquoi ce projet
Les APIs officielles (INSEE, FINESS DREES, RPPS ANS, Annuaire Ameli, Centres de Santé CNAM, IGN, DINUM) existent mais sont éclatées, sous-documentées et pleines de pièges : rate limits, formats CSV propriétaires, latence DREES de 1-2 mois, diffusion partielle INSEE, mappings inconsistants Ameli ↔ RPPS.
france-data-mcp est le premier MCP qui croise factuellement ces sources pour répondre à des questions concrètes — cartographie d'offre de soins, étude de marché territoriale, journalisme local, civic-tech.
Périmètre — 13 sources publiques croisées
🗺️ Territoire (2) : geo.api.gouv.fr (DINUM, communes), IGN Géoplateforme (géocodage)
🏥 Santé (3) : FINESS / DREES (~95 K établissements), Annuaire Santé Ameli (~462 K libéraux), RPPS / ANS (~2,2 M PS actifs)
🩺 Centres de Santé (1) : Annuaire santé CNAM (~3 K structures L.6323-1 CSP, sync hebdomadaire)
📊 Démographie infracommunale (2) : INSEE IRIS (~48,6 K quartiers — RP 2022, FILOSOFI 2021 revenu, contours IGN) + INSEE Melodi (population de référence)
🏢 Entreprises (2) : DINUM Recherche Entreprises + INSEE SIRENE V3.11
🏗️ Immobilier (3) : ventes foncières DVF / DGFiP (€/m², cache paresseux PostGIS), permis de construire Sit@del via API DiDo / SDES (live), zones AU du PLU via apicarto / IGN (live)
Cross-source : réconciliation FINESS ↔ RPPS ↔ SIRENE pour détecter SIRET fermés, rebrandings, raisons sociales périmées.
Outils MCP (36 tools)
🗺️ Territoire (4)
autocomplete_commune · get_commune_by_code · geocode_adresse · reverse_geocode
🏢 Entreprises (3)
entreprises_in_radius · entreprise_by_siren (+ fallback INSEE SIRENE V3.11) · etablissement_by_siret
🏥 Établissements santé FINESS (3)
etablissements_finess_in_radius · etablissements_finess_by_categorie · etablissement_by_finess
24 familles couvrant ~92 % du volume. Source DREES rafraîchie bimestriellement.
👨⚕️ Professionnels libéraux Ameli (2)
professionnels_in_radius · professionnels_par_specialite_dept
Libéraux conventionnés uniquement (~462 K). Découverte des codes spécialité/type_ps :
lister_nomenclature(voir ci-dessous).
🩺 Tous les PS — RPPS / Annuaire Santé ANS (5)
professionnels_rpps_in_radius · professionnels_rpps_par_dept · rpps_dans_etablissement · rpps_search_by_name (fuzzy) · professionnel_by_rpps (+ fallback FHIR ANS)
~2,2 M PS actifs (libéraux + salariés privés + hospitaliers contractuels + agents publics). Par défaut : Civils uniquement.
🩺 Centres de Santé — Annuaire CNAM (2)
centres_sante_in_radius · centres_sante_by_finess
Structures de soins ambulatoires non lucratives (L.6323-1 CSP, ~3 K). Différenciateur vs FINESS famille=124 : expose carte Vitale, APCV et spécialités exercées sur place (Annexe A CNAM, ~70 codes). Coords = centroïde commune. Sync hebdomadaire.
📊 Démographie & densités — INSEE Melodi + IRIS (3)
Population de référence INSEE croisée avec RPPS / FINESS — méthodologie DREES (ratios pour 100 k hab.). Maille IRIS (quartier, ~48,6K zones) pour la DEMANDE, à croiser avec l'offre de soins.
population (IRIS 9 car., commune 5 car. ou département 2-3 car. — granularité auto-détectée par la longueur du code) · densite_sante (cible: professionnels RPPS ou etablissements FINESS — labos, pharmacies, EHPAD, hôpitaux ; + comparaison nationale matview <50 ms) · profil_iris (point ou code_iris, rayon_km?) — profil démo d'un îlot ou d'un bassin (âge, CSP, familles, revenu) au RP 2022 + FILOSOFI 2021
🔎 Découverte des nomenclatures (1)
lister_nomenclature (referentiel: ameli_specialites | ameli_types_ps | rpps_savoir_faire) — codes spécialité/type_ps Ameli et savoir_faire RPPS dans un seul tool (remplace les 3 anciens lister_*).
🧭 Agrégateurs & études composites (4)
panorama_sante_territoire(V0.9) — 1 call : population + densités médecins/infirmiers/pharmaciens vs national + count FINESS par famille (labo, pharmacie, EHPAD, MCO, MSP/CPTS) + bloc demande IRIS (profil démo commune : âge, CSP, familles, revenu). Granularité explicite (niveau: commune,niveauEtablissements: departement | indisponible).inspect_site(V0.10) — vue 360 d'un établissement en 1 call : identification FINESS + statut administratif SIRENE (resolver SIRET) + PS rattachés + historique INSEE.panorama_implantation_complet(V0.23) — étude d'implantation labo en 1 call : 7 sections (territoire, demande IRIS du bassin, concurrents, pourvoyeurs MCO/EHPAD/SSR, prescripteurs RPPS+IDEL, centres de santé, qualité référentiels). Résumés, jamais de listes brutes ; dégradation par section.enrichir_concurrents(V0.23) — enquête sur le top concurrents (statut actif + équipe + signal M&A + groupe parent), cap durmax=3.
🏗️ Immobilier — potentiel d'un site (2)
dynamique_immobiliere (V0.26) — composite en 1 call : permis de construire (Sit@del / DiDo SDES, live) + zones AU du PLU (apicarto / IGN, live) + ventes de terrains DVF. Sortie 2 registres : note (volume → scoring) / info (quartiers AU + prix → contexte) ; geojson = polygones des zones AU. · cout_foncier (V0.26) — prix médian €/m² DVF (P25/P75, n_ventes, période), info seule.
Source DVF / DGFiP (cache paresseux PostGIS, anon lit / service écrit). Permis et zones AU = live (pas d'ingestion). Pensé pour les rapports d'implantation.
🔀 Croisement multi-source (7)
Réconciliation FINESS ↔ RPPS ↔ SIRENE ↔ CNAM — faits bruts sans interprétation métier.
data_freshness · verifier_site_actif · compare_raison_sociale_finess_vs_rpps · compare_adresse_cnam_vs_finess · historique_etablissement · reconcilier_finess_sirene · finess_sirene_coverage_in_radius
Garde-fous publics
Rate limit : 60 req/min par IP sur
tools/call(les méthodes meta restent libres). Au-delà : erreur-32000avecdata.retryAfterSeconds.Logs JSON structurés par requête :
ts,method,tool,ip_hash(SHA-256 salé),duration_ms,outcome. Aucune IP en clair, aucun argument tool persisté.Sentry error monitoring sur les 500 internes (tags
mcp.method,mcp.tool,mcp.outcome).RGPD : rétention 30j sur Axiom, hash IP salé, droits d'accès / effacement. Politique complète dans PRIVACY.md.
Usage intensif : throttler côté client ou self-héberger.
État du projet
✅ V0.26.2 — en production. Sur le registry MCP officiel. Détail : CHANGELOG.
Dernier patch (V0.26.2) : un point sans adresse proche (site industriel isolé / littoral, ex. Orano La Hague) est désormais rattaché à sa commune par ses frontières (point-dans-polygone), ce qui restaure les permis Sit@del (
dynamique_immobiliere) et la couverture FINESS↔SIRENE (finess_sirene_coverage_in_radius) sur ces sites. Surface inchangée (13 référentiels / 36 outils).
Roadmap
V1.0+ : DOM-COM (IRIS + santé), DPC.
Historique des versions livrées : CHANGELOG.
Contribuer
Ouvrir une issue pour discuter avant d'envoyer une PR.
Licence
MIT — voir LICENSE. Les données restent sous leurs licences respectives :
Source | Licence | Mention obligatoire |
FINESS | Licence Ouverte (Etalab) | « Source : FINESS, ANS/DREES » |
Annuaire Santé Ameli | Art. L.1461-2 CSP | « Source : Annuaire santé Ameli, Assurance Maladie » |
DINUM Recherche Entreprises | Licence Ouverte | « Source : Annuaire des Entreprises, DINUM » |
INSEE | Licence Ouverte | « Source : Insee » |
IGN Géoplateforme / apicarto | Licence Ouverte | « © IGN/Géoplateforme », « GPU — apicarto IGN » |
geo.api.gouv.fr | Licence Ouverte | « Source : geo.api.gouv.fr (Etalab) » |
DVF (Demandes de Valeurs Foncières) | Licence Ouverte | « Source : DVF, DGFiP / Etalab » |
Sit@del (permis de construire) | Licence Ouverte | « Source : Sit@del, SDES (API DiDo) » |
Remerciements
DINUM, Etalab, Atlasanté, ANS, INSEE, IGN pour la qualité de leurs APIs. data.gouv.fr pour l'animation civic-tech. Anthropic pour le protocole MCP.
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/cturkieh/france-data-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server