MCP-BOE

MCP-BOE

Enables LLMs like Claude to query the official Spanish BOE API for consolidated legislation, daily summaries, and auxiliary government tables.

Category
Visit Server

README

MCP BOE 🇪🇸

Model Context Protocol para el Boletín Oficial del Estado español

<img width="512" height="512" alt="image" src="https://github.com/user-attachments/assets/cd1c5e79-add7-466c-bcbd-554b81a2fef9" />

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.

Python MCP License

🚀 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-boe

Opció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.server

Opció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.json
  • Windows: %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-BOE por 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
tema Texto o nombre de la norma a buscar
departamento Ministerio u organismo emisor

Ejemplos:

  • tema: protección de datos → encuentra RGPD y LOPDGDD
  • tema: Ley 40/2015 → Ley de Régimen Jurídico del Sector Público
  • tema: 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
id_norma Identificador BOE (ej: BOE-A-2015-10566)

Ejemplos:

  • BOE-A-1978-31229 → Constitución Española
  • BOE-A-2015-10566 → Ley 40/2015 de Régimen Jurídico del Sector Público
  • BOE-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 Fecha en formato AAAAMMDD
seccion Sección del BOE: 1, 2A, 2B, 3, 4, 5

Ejemplos:

  • fecha: 20250101 → publicaciones del 1 de enero de 2025
  • fecha: 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
id_norma_1 Identificador de la primera norma
id_norma_2 Identificador de la segunda norma

Ejemplo:

  • BOE-A-2015-10566 y BOE-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
search_consolidated_legislation Busca en más de 50.000 normas consolidadas query, title, department_code, legal_range_code, matter_code, from_date, to_date, limit, include_derogated
get_consolidated_law Obtiene metadatos, análisis jurídico y texto de una norma law_id, include_metadata, include_analysis, include_full_text, include_eli_metadata
get_law_structure Índice completo de una norma (artículos, disposiciones, anexos) law_id
get_law_text_block Texto de un artículo o disposición específica law_id, block_id
find_related_laws Normas que modifican, derogan o son modificadas por una norma law_id, relation_type
compare_law_versions Compara el texto de una norma entre dos fechas, detectando artículos añadidos, modificados o eliminados law_id, from_date, to_date, granularity
search_law_articles Busca artículos concretos dentro de una norma sin descargar el texto completo law_id, query, search_in, limit
get_law_metadata Obtiene solo los metadatos de una norma (rango, fecha, órgano, estado, enlaces) sin cargar el texto law_id
list_related_laws Lista normas relacionadas con control granular sobre qué tipos de relación incluir law_id, include_derogating, include_development, include_references

📰 Sumarios BOE/BORME (7 herramientas)

Herramienta Descripción Parámetros clave
get_boe_summary Sumario completo del BOE para una fecha date, section_filter, department_filter, max_items
get_borme_summary Sumario del BORME (Registro Mercantil) date, province_filter, max_items
search_recent_boe Busca documentos en los últimos N días days_back, search_terms, section_filter
get_weekly_summary Estadísticas y resumen de una semana completa start_date, include_statistics
get_boe_summary_range Agrega los sumarios de un rango de fechas (máx. 31 días) con filtro de sección from_date, to_date, section, max_items
watch_boe_changes Radar normativo: busca publicaciones recientes por palabras clave days_back, keywords, sections, max_items
group_summary_by_department Agrupa las publicaciones de un rango de fechas por departamento emisor from_date, to_date, sections, max_items_per_dept

🏛️ Tablas Auxiliares (10 herramientas)

Herramienta Descripción
get_departments_table Lista de departamentos oficiales con sus códigos
get_legal_ranges_table Rangos normativos (Ley, Real Decreto, Orden, etc.)
get_matters_table Vocabulario controlado de materias temáticas
get_scopes_table Ámbitos normativos (estatal, autonómico)
get_consolidation_states_table Estados de consolidación
search_auxiliary_data Búsqueda en todas las tablas a la vez
get_code_description Descripción de un código específico
search_departments_advanced Búsqueda avanzada de departamentos con filtro por código padre (jerarquía)
list_topics_for_law Lista las materias del vocabulario controlado de una norma concreta
suggest_auxiliary_filters 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
summarize_law_sections Resumen estructurado de una norma con el primer párrafo de cada artículo law_id
paginate_law_text Devuelve el texto de una norma por páginas usando un cursor opaco law_id, cursor, max_chars
explain_law_structure Describe la estructura jerárquica de una norma con recuento de elementos por nivel law_id
normalize_boe_reference Normaliza una referencia textual a una norma o sumario en campos estructurados reference_text

📄 Lectura de PDFs (1 herramienta)

Herramienta Descripción Parámetros clave
read_boe_pdf Descarga y extrae el texto de un PDF del BOE source, max_pages

source acepta dos formatos:

  • URL directa: la que aparece en el campo url_pdf de los sumarios
    https://www.boe.es/boe/dias/2025/03/28/pdfs/BOE-A-2025-6192.pdf
  • Identificador BOE: el servidor consulta la API para obtener la fecha y construye la URL
    BOE-A-2025-6192 o BOE-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/2015
Descarga https://www.boe.es/boe/dias/2025/03/28/pdfs/BOE-A-2025-6192.pdf y resume su contenido
Busca 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
1 Disposiciones generales
2A Autoridades y personal — Nombramientos
2B Autoridades y personal — Oposiciones
3 Otras disposiciones
4 Administración de Justicia
5 Anuncios

Departamentos frecuentes:

Código Departamento
7723 Jefatura del Estado
1430 Ministerio de Justicia
1470 Ministerio del Interior

Rangos normativos frecuentes:

Código Rango
1300 Ley
1250 Ley Orgánica
1200 Real Decreto
1100 Real Decreto-ley
800 Orden ministerial

⚙️ Variables de entorno

Variable Descripción Valor por defecto
BOE_HTTP_TIMEOUT Timeout en segundos para peticiones HTTP 30.0
BOE_MAX_RETRIES Número máximo de reintentos ante errores de red o 5xx 3
BOE_RETRY_DELAY Segundos de espera base entre reintentos (backoff lineal) 1.0
LOG_LEVEL Nivel de logging (DEBUG, INFO, WARNING, ERROR) INFO

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

  1. Verifica que Python 3.10+ está disponible: python3 --version
  2. Comprueba la ruta en el config: debe ser absoluta, no relativa
  3. Reinicia completamente Claude Desktop (no solo la ventana)
  4. 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 diagnose

La 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

  1. Fork del proyecto
  2. Crea una rama (git checkout -b feature/nueva-funcionalidad)
  3. Haz commit de los cambios (git commit -m 'Agregar nueva funcionalidad')
  4. Push a la rama (git push origin feature/nueva-funcionalidad)
  5. 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 norma
  • 4 prompts integrados: buscar_legislacion, analizar_norma, resumen_boe_dia, comparar_normas
  • 2 recursos MCP: boe://help y boe://status
  • Cliente 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


¿Tienes preguntas? Abre un issue.
¿Te gusta el proyecto? ¡Dale una ⭐ en GitHub!

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured