MCP-BOE
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., "@MCP-BOESearch for consolidated legislation on climate change"
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.
MCP BOE 🇪🇸
Model Context Protocol para el Boletín Oficial del Estado español
Un servidor MCP que permite a Claude y otros LLMs acceder a la API oficial del BOE para consultar legislación consolidada, sumarios diarios y tablas auxiliares del gobierno español.
🚀 Características
🔍 Búsqueda de Legislación: Buscar en más de 50.000 normas consolidadas con filtros por departamento, rango normativo, materia y fechas
📰 Sumarios del BOE/BORME: Acceder a publicaciones diarias, búsquedas recientes y resúmenes semanales
🏛️ Tablas Auxiliares: Consultar códigos de departamentos, materias, rangos normativos y ámbitos
📄 Lectura de PDFs: Descargar y extraer el texto de cualquier documento del BOE para analizarlo
💬 Prompts integrados: Plantillas de consulta listas para usar en Claude
📊 Datos Oficiales: Conecta directamente con la API oficial del BOE
⚙️ Configurable: Timeout, reintentos y nivel de log via variables de entorno
📋 Tabla de Contenidos
🛠️ Instalación
Prerrequisitos
Python 3.10 o superior (requerido por la librería
mcp)uv (recomendado) o pip
Opción 1: uvx — sin instalación (Recomendado)
Con uvx no necesitas clonar el repositorio ni gestionar dependencias:
uvx --from git+https://github.com/ComputingVictor/MCP-BOE.git mcp-boeOpción 2: Desde el código fuente con uv
git clone https://github.com/ComputingVictor/MCP-BOE.git
cd MCP-BOE
# Instalar dependencias y ejecutar
uv run python -m mcp_boe.serverOpción 3: Instalación con pip
git clone https://github.com/ComputingVictor/MCP-BOE.git
cd MCP-BOE
pip install -e .🖥️ Configuración con Claude Desktop
Edita el archivo de configuración de Claude Desktop:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.json
Con uv (Recomendado)
{
"mcpServers": {
"mcp-boe": {
"command": "uv",
"args": [
"run",
"--python", "3.12",
"--project", "/ruta/absoluta/a/MCP-BOE",
"python", "-m", "mcp_boe.server"
]
}
}
}Sustituye
/ruta/absoluta/a/MCP-BOEpor la ruta real donde clonaste el repositorio.
Con uvx
{
"mcpServers": {
"mcp-boe": {
"command": "uvx",
"args": ["--from", "git+https://github.com/ComputingVictor/MCP-BOE.git", "mcp-boe"]
}
}
}Reinicia Claude Desktop tras guardar los cambios.
⚡ Configuración con Claude Code
Con uvx
{
"mcpServers": {
"mcp-boe": {
"command": "uvx",
"args": ["--from", "git+https://github.com/ComputingVictor/MCP-BOE.git", "mcp-boe"],
"transport": "stdio"
}
}
}También puedes usar el archivo incluido en el repositorio:
# Desde el directorio del proyecto
claude --mcp-config claude_mcp_config_uvx.json💬 Prompts disponibles
El servidor incluye 4 prompts integrados accesibles desde el selector de prompts de Claude:
buscar_legislacion
Busca y resume normas del BOE.
Argumento | Descripción | Requerido |
| Texto o nombre de la norma a buscar | ✅ |
| Ministerio u organismo emisor | ❌ |
Ejemplos:
tema:
protección de datos→ encuentra RGPD y LOPDGDDtema:
Ley 40/2015→ Ley de Régimen Jurídico del Sector Públicotema:
tráfico, departamento:Ministerio del Interior
analizar_norma
Análisis completo de una norma: metadatos, estado de vigencia, estructura y relaciones con otras normas.
Argumento | Descripción | Requerido |
| Identificador BOE (ej: | ✅ |
Ejemplos:
BOE-A-1978-31229→ Constitución EspañolaBOE-A-2015-10566→ Ley 40/2015 de Régimen Jurídico del Sector PúblicoBOE-A-2018-16673→ Ley Orgánica de Protección de Datos
resumen_boe_dia
Resumen de las publicaciones más relevantes del BOE de una fecha concreta.
Argumento | Descripción | Requerido |
| Fecha en formato AAAAMMDD | ✅ |
| Sección del BOE: | ❌ |
Ejemplos:
fecha:
20250101→ publicaciones del 1 de enero de 2025fecha:
20240529, seccion:1→ solo disposiciones generales
comparar_normas
Compara dos normas e identifica relaciones de modificación o derogación entre ellas.
Argumento | Descripción | Requerido |
| Identificador de la primera norma | ✅ |
| Identificador de la segunda norma | ✅ |
Ejemplo:
BOE-A-2015-10566yBOE-A-2015-10565→ Ley 40/2015 y Ley 39/2015 (las dos grandes leyes administrativas)
🔧 Herramientas disponibles
31 herramientas en total organizadas en 5 grupos.
📜 Legislación Consolidada (9 herramientas)
Herramienta | Descripción | Parámetros clave |
| Busca en más de 50.000 normas consolidadas |
|
| Obtiene metadatos, análisis jurídico y texto de una norma |
|
| Índice completo de una norma (artículos, disposiciones, anexos) |
|
| Texto de un artículo o disposición específica |
|
| Normas que modifican, derogan o son modificadas por una norma |
|
| Compara el texto de una norma entre dos fechas, detectando artículos añadidos, modificados o eliminados |
|
| Busca artículos concretos dentro de una norma sin descargar el texto completo |
|
| Obtiene solo los metadatos de una norma (rango, fecha, órgano, estado, enlaces) sin cargar el texto |
|
| Lista normas relacionadas con control granular sobre qué tipos de relación incluir |
|
📰 Sumarios BOE/BORME (7 herramientas)
Herramienta | Descripción | Parámetros clave |
| Sumario completo del BOE para una fecha |
|
| Sumario del BORME (Registro Mercantil) |
|
| Busca documentos en los últimos N días |
|
| Estadísticas y resumen de una semana completa |
|
| Agrega los sumarios de un rango de fechas (máx. 31 días) con filtro de sección |
|
| Radar normativo: busca publicaciones recientes por palabras clave |
|
| Agrupa las publicaciones de un rango de fechas por departamento emisor |
|
🏛️ Tablas Auxiliares (10 herramientas)
Herramienta | Descripción | |
| Lista de departamentos oficiales con sus códigos | |
| Rangos normativos (Ley, Real Decreto, Orden, etc.) | |
| Vocabulario controlado de materias temáticas | |
| Ámbitos normativos (estatal, autonómico) | |
| Estados de consolidación | |
| Búsqueda en todas las tablas a la vez | |
| Descripción de un código específico | |
| Búsqueda avanzada de departamentos con filtro por código padre (jerarquía) |
|
| Lista las materias del vocabulario controlado de una norma concreta |
|
| Dado un texto libre, sugiere códigos de departamento, rango y materia para filtrar búsquedas |
|
🛠️ Calidad de vida para LLMs (4 herramientas)
Herramienta | Descripción | Parámetros clave |
| Resumen estructurado de una norma con el primer párrafo de cada artículo |
|
| Devuelve el texto de una norma por páginas usando un cursor opaco |
|
| Describe la estructura jerárquica de una norma con recuento de elementos por nivel |
|
| Normaliza una referencia textual a una norma o sumario en campos estructurados |
|
📄 Lectura de PDFs (1 herramienta)
Herramienta | Descripción | Parámetros clave |
| Descarga y extrae el texto de un PDF del BOE |
|
source acepta dos formatos:
URL directa: la que aparece en el campo
url_pdfde los sumarioshttps://www.boe.es/boe/dias/2025/03/28/pdfs/BOE-A-2025-6192.pdfIdentificador BOE: el servidor consulta la API para obtener la fecha y construye la URL
BOE-A-2025-6192oBOE-A-2015-10566
max_pages — páginas máximas a leer (por defecto 30, máximo 100).
Límites aplicados: PDFs de hasta 10 MB y 80.000 caracteres de texto devuelto al LLM.
Ejemplos de uso en Claude:
Lee el PDF de BOE-A-2015-10566 y explícame qué regula la Ley 40/2015Descarga https://www.boe.es/boe/dias/2025/03/28/pdfs/BOE-A-2025-6192.pdf y resume su contenidoBusca el sumario del BOE de hoy y léeme el PDF del primer real decreto que aparezca📌 Formatos y valores útiles
Secciones del BOE:
Código | Descripción |
| Disposiciones generales |
| Autoridades y personal — Nombramientos |
| Autoridades y personal — Oposiciones |
| Otras disposiciones |
| Administración de Justicia |
| Anuncios |
Departamentos frecuentes:
Código | Departamento |
| Jefatura del Estado |
| Ministerio de Justicia |
| Ministerio del Interior |
Rangos normativos frecuentes:
Código | Rango |
| Ley |
| Ley Orgánica |
| Real Decreto |
| Real Decreto-ley |
| Orden ministerial |
⚙️ Variables de entorno
Variable | Descripción | Valor por defecto |
| Timeout en segundos para peticiones HTTP |
|
| Número máximo de reintentos ante errores de red o 5xx |
|
| Segundos de espera base entre reintentos (backoff lineal) |
|
| Nivel de logging ( |
|
Ejemplo de configuración en Claude Desktop:
{
"mcpServers": {
"mcp-boe": {
"command": "uv",
"args": ["run", "--project", "/ruta/a/MCP-BOE", "python", "-m", "mcp_boe.server"],
"env": {
"BOE_HTTP_TIMEOUT": "60",
"LOG_LEVEL": "WARNING"
}
}
}
}💡 Ejemplos de uso
Buscar legislación desde Python
import asyncio
from mcp_boe.utils.http_client import BOEHTTPClient
from mcp_boe.tools.legislation import LegislationTools
async def main():
async with BOEHTTPClient() as client:
tools = LegislationTools(client)
resultados = await tools.search_consolidated_legislation({
"query": "Ley 40/2015",
"limit": 3
})
for r in resultados:
print(r.text)
asyncio.run(main())Obtener sumario del BOE
import asyncio
from datetime import datetime, timedelta
from mcp_boe.utils.http_client import BOEHTTPClient
from mcp_boe.tools.summaries import SummaryTools
async def main():
async with BOEHTTPClient() as client:
tools = SummaryTools(client)
fecha = (datetime.now() - timedelta(days=2)).strftime("%Y%m%d")
resultados = await tools.get_boe_summary({
"date": fecha,
"section_filter": "1",
"max_items": 10
})
for r in resultados:
print(r.text)
asyncio.run(main())Diagnóstico de conectividad
# Verificar que la API del BOE es accesible
python -m mcp_boe.server --mode diagnose🐛 Solución de problemas
El servidor no aparece en Claude Desktop
Verifica que Python 3.10+ está disponible:
python3 --versionComprueba la ruta en el config: debe ser absoluta, no relativa
Reinicia completamente Claude Desktop (no solo la ventana)
Revisa los logs en Claude Desktop → Ayuda → Abrir carpeta de logs
Error: requires-python / incompatibilidad de versión
La librería mcp requiere Python 3.10 o superior. Fuerza la versión con uv:
"args": ["run", "--python", "3.12", "--project", "/ruta/MCP-BOE", "python", "-m", "mcp_boe.server"]Error: No module named 'mcp_boe'
Asegúrate de pasar --project al directorio raíz del repositorio (donde está pyproject.toml), no al directorio src/.
La API del BOE no responde
python -m mcp_boe.server --mode diagnoseLa API del BOE no publica horarios de mantenimiento. Los errores 5xx se reintentan automáticamente hasta 3 veces.
📊 Estructura del proyecto
MCP-BOE/
├── src/mcp_boe/
│ ├── __init__.py
│ ├── __main__.py
│ ├── server.py # Servidor MCP: tools, prompts, resources
│ ├── models/
│ │ └── boe_models.py # Modelos Pydantic y validadores
│ ├── tools/
│ │ ├── legislation.py # 9 herramientas de legislación consolidada
│ │ ├── summaries.py # 7 herramientas de sumarios BOE/BORME
│ │ ├── auxiliary.py # 10 herramientas de tablas auxiliares
│ │ ├── analysis.py # 4 herramientas de calidad de vida para LLMs
│ │ └── documents.py # 1 herramienta de lectura de PDFs
│ └── utils/
│ └── http_client.py # Cliente HTTP asíncrono con reintentos
├── examples/
│ └── basic_usage.py
├── tests/
├── pyproject.toml
├── claude_mcp_config.json # Config de ejemplo para instalación local
├── claude_mcp_config_uvx.json # Config de ejemplo con uvx
└── rest_api_wrapper.py # API REST opcional (FastAPI)🤝 Contribuir
Fork del proyecto
Crea una rama (
git checkout -b feature/nueva-funcionalidad)Haz commit de los cambios (
git commit -m 'Agregar nueva funcionalidad')Push a la rama (
git push origin feature/nueva-funcionalidad)Abre un Pull Request
Desarrollo local
git clone https://github.com/ComputingVictor/MCP-BOE.git
cd MCP-BOE
uv sync --extra dev
uv run python -m pytest tests/
uv run black src/📝 Changelog
v0.1.0
Implementación inicial del servidor MCP
31 herramientas: 9 de legislación, 7 de sumarios, 10 de tablas auxiliares, 4 de calidad de vida para LLMs, 1 de lectura de PDFs
Herramienta
read_boe_pdf: descarga y extrae texto de PDFs del BOE por URL o por ID de norma4 prompts integrados:
buscar_legislacion,analizar_norma,resumen_boe_dia,comparar_normas2 recursos MCP:
boe://helpyboe://statusCliente HTTP asíncrono con reintentos en errores de red y 5xx
Configurable via variables de entorno
Soporte para Python 3.10+
🔒 Seguridad
La API del BOE es pública y no requiere autenticación
No se almacenan datos localmente
El servidor respeta automáticamente los límites de la API mediante reintentos con backoff
📚 Referencias
📄 Licencia
MIT — ver LICENSE para más detalles.
👤 Autor
Víctor Viloria
Email: vvictor.97@gmail.com
GitHub: @ComputingVictor
¿Tienes preguntas? Abre un issue.
¿Te gusta el proyecto? ¡Dale una ⭐ en GitHub!
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
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/ComputingVictor/MCP-BOE'
If you have feedback or need assistance with the MCP directory API, please join our Discord server