Datadis MCP Server
Integrates the Datadis energy data API, allowing GitHub Copilot agents to retrieve and analyze electricity supply, consumption, contract details, and generate executive reports.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Datadis MCP Servershow me my electricity consumption for the last month"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Datadis MCP Server
Servidor MCP de producción que integra la API de Datadis con agentes IA (Claude, Copilot, Cursor, Open WebUI, etc.) mediante el Model Context Protocol.
Arquitectura
Agente IA (Claude / Copilot / Cursor)
│
│ MCP (stdio o SSE)
▼
Datadis MCP Server (FastMCP 3.x)
├── Auth Layer — ciclo de vida del token, nunca persiste en disco
├── Datadis Client — httpx async, retry exponencial, excepciones tipadas
├── EnergyService — cache-aside por namespace (supplies 24h, consumo 1h…)
├── AnalysisService — análisis semántico, detención de anomalías, informes
├── MCP Tools (13) — wrappers delgados sin lógica de negocio
├── MCP Resources (3) — datos de catálogo en tiempo real
└── MCP Prompts (3) — plantillas de prompts para análisis energético
│
│ HTTPS
▼
Datadis API V2Related MCP server: PVPC MCP Server
Estructura del proyecto
datadis-mcp/
├── server.py ← punto de entrada FastMCP
├── config.py ← Pydantic Settings (variables de entorno)
├── auth.py ← gestor del ciclo de vida del token
├── datadis_client.py ← cliente HTTP async para todos los endpoints V2
├── exceptions.py ← jerarquía de excepciones tipadas
├── models/ ← modelos de dominio Pydantic v2
├── cache/ ← abstracción de cache TTL por namespace
├── utils/ ← utilidades transversales (seguridad, logging)
├── services/
│ ├── energy_service.py ← wrapper con cache sobre DatadisClient
│ └── analysis_service.py ← análisis semántico de alto nivel
├── tools/ ← 13 tools MCP (sin lógica de negocio)
├── resources/ ← 3 resources MCP (status, distributors, groups)
├── prompts/ ← 3 prompts MCP (analyse_supply, executive_report, compare_years)
├── tests/ ← 150 tests pytest (83.61% cobertura)
├── pyproject.toml
├── requirements.txt
├── Dockerfile
└── .env.exampleQuick Start
Requisitos
Python 3.12+
Cuenta en Datadis con credenciales válidas
Instalación local
cd datadis-mcp
# Instalar dependencias
pip install -r requirements-dev.txt
# Configurar credenciales
copy .env.example .env # Windows
# cp .env.example .env # Linux/macOS
# Editar .env: rellenar DATADIS_USERNAME y DATADIS_PASSWORD
# Iniciar el servidor (transporte stdio — para Claude Desktop / Cursor)
python server.py
# O con transporte SSE (HTTP — para clientes web)
$env:MCP_TRANSPORT="sse"; python server.py # Windows
MCP_TRANSPORT=sse python server.py # Linux/macOSRedes corporativas con proxy SSL
Si aparece CERTIFICATE_VERIFY_FAILED, añade esto a tu .env:
HTTP_SSL_VERIFY=falseConectar un agente IA
VS Code (GitHub Copilot Agent)
El fichero .vscode/mcp.json ya está incluido en el repositorio. VS Code lo detecta automáticamente — abre el proyecto y el servidor aparecerá en Copilot Chat → Agent mode → herramientas disponibles.
Las credenciales se leen del fichero .env del proyecto.
Claude Desktop
Edita %APPDATA%\Claude\claude_desktop_config.json (créalo si no existe):
{
"mcpServers": {
"datadis": {
"command": "python",
"args": ["C:\\ruta\\completa\\a\\datadis-mcp\\server.py"],
"env": {
"DATADIS_USERNAME": "TU_NIF",
"DATADIS_PASSWORD": "TU_PASSWORD",
"HTTP_SSL_VERIFY": "false"
}
}
}
}Reinicia Claude Desktop. Verás el ícono del servidor en la barra de herramientas.
Cursor
Edita %USERPROFILE%\.cursor\mcp.json (créalo si no existe):
{
"mcpServers": {
"datadis": {
"command": "python",
"args": ["C:\\ruta\\completa\\a\\datadis-mcp\\server.py"],
"env": {
"DATADIS_USERNAME": "TU_NIF",
"DATADIS_PASSWORD": "TU_PASSWORD",
"HTTP_SSL_VERIFY": "false"
}
}
}
}Ve a Cursor Settings → MCP para verificar que el servidor aparece activo.
Docker
# 1. Build
docker build -t datadis-mcp .
# 2. Verificar que la imagen se construyó correctamente
docker images datadis-mcp
docker inspect datadis-mcp --format "Usuario: {{.Config.User}} | Puerto: {{.Config.ExposedPorts}}"
# 3. Arrancar en modo SSE (HTTP, puerto 8000)
docker run -d \
--name datadis \
-p 8000:8000 \
-e DATADIS_USERNAME=TU_NIF \
-e DATADIS_PASSWORD=TU_PASSWORD \
-e HTTP_SSL_VERIFY=false \
-e MCP_TRANSPORT=sse \
datadis-mcp
# 4. Ver logs de arranque
docker logs datadis
# 5. Smoke test — el endpoint SSE debe responder
curl http://localhost:8000/sse # Linux/macOS
Invoke-RestMethod http://localhost:8000/sse # PowerShell
# 6. Verificar healthcheck
docker inspect datadis --format "Health: {{.State.Health.Status}}"
# 7. Parar y eliminar el contenedor
docker stop datadis && docker rm datadisVariables de entorno disponibles:
Variable | Descripción | Requerida |
| NIF de la cuenta Datadis | Sí |
| Contraseña de Datadis | Sí |
|
| No |
|
| No |
| Host de escucha (defecto | No |
| Puerto de escucha (defecto | No |
|
| No |
Desarrollo
# Tests con cobertura
pytest
# Linter
ruff check .
# Tipos
mypy .
# Formateo
ruff format .Tools MCP disponibles
Técnicas (acceso directo a la API)
Tool | Descripción |
| Listado de puntos de suministro (CUPS) |
| Detalle del contrato de un CUPS |
| Curva de carga horaria/cuarto-horaria |
| Potencia máxima registrada por periodo |
| Energía reactiva por periodo (P1–P6) |
| Códigos de distribuidora vinculados a la cuenta |
| Grupos de suministros definidos |
Semánticas (análisis de alto nivel)
Tool | Descripción |
| Resumen consolidado: suministro + contrato (auto-descubre distribuidor) |
| Perfil estadístico: total, media, máx, mín, desv. estándar |
| Comparación entre dos periodos: Δ kWh + % variación + tendencia |
| Detección de picos anómalos mediante Z-score configurable |
| Ratios de autoconsumo/excedentes para instalaciones CAU |
| Informe ejecutivo anual con recomendaciones autogeneradas |
Resources MCP
URI | Contenido |
| Estado del servidor: autenticación, cache, versión |
| Catálogo de distribuidoras (cacheado 24h) |
| Grupos de suministro (cacheado 24h) |
Prompts MCP
Prompt | Descripción |
| Guía al agente: overview → perfil → potencia máx → informe |
| Plantilla de informe ejecutivo anual estructurado |
| Comparación interanual con interpretación de tendencia |
Seguridad
Credenciales exclusivamente desde variables de entorno — nunca en código.
Token bearer en memoria únicamente — nunca en disco ni en logs.
NIF/NIE enmascarado en todos los logs (
4******0A).TLS obligatorio para todas las comunicaciones con la API.
Usuario non-root en Docker.
HTTP_SSL_VERIFY=falsedisponible para proxies corporativos con inspección SSL.
Licencia
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/Jaimegruiz/datadis-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server