MCP server para Presto (RIB) — automatizacion COM local (Presto.App.25) + BC3 (FIEBDC-3). NeoNexAI.
Project description
presto-mcp-server
MCP server que conecta Claude con Presto (software de presupuestos y mediciones de RIB Software) — versión 2025.
Por NeoNexAI Agency (para Cota Zero y clientes de consultoría IA).
Dos vías complementarias:
- COM en vivo (
Presto.App.25) — controla la obra abierta en Presto: leer/escribir conceptos, precios y cualquier campo, e invocar opciones internas del programa. Requiere Presto instalado y ejecutándose en el mismo equipo. - BC3 (FIEBDC-3) — lee y analiza ficheros de presupuesto sin abrir Presto (multiplataforma; ideal para auditoría rápida).
Presto de escritorio no tiene API REST (eso es solo Presto ServerCloud). La integración local correcta es COM, que la documentación oficial de RIB soporta para VBScript, VB.NET y Python (
win32com) — que es lo que usa este server.
Requisitos en el PC
- Windows (la vía COM es Windows-only).
- Python ≥ 3.10 + uv (
pip install uv). - Presto 2025 instalado Y ABIERTO para la vía COM (control de la obra en vivo).
El MCP se conecta a la instancia de Presto en ejecución; para operar sobre una
obra concreta, ábrela en Presto antes. Si tu versión no es la 25, fija el
ProgID con
PRESTO_PROGID(p. ej.Presto.App.26). - La vía BC3 NO necesita Presto (ni instalado ni abierto): solo lee/analiza
ficheros
.bc3. - Comprueba la conexión en cualquier momento con la tool
presto_status.
Resumen rápido: tools
presto_bc3_*→ funcionan siempre (solo ficheros). El resto (COM) → requieren Presto 2025 abierto en este mismo equipo.
Instalación
Publicado en PyPI como presto-mcp-server.
uvx lo instala y ejecuta sin dejar nada que mantener; @latest trae siempre la última versión.
Opción 1 — con el comando de Claude Code (si tienes el CLI claude)
claude mcp add presto -s user -- uvx presto-mcp-server@latest
-s user lo deja disponible en todos los proyectos de ese PC. Para una versión
de Presto distinta de la 2025: --env PRESTO_PROGID=Presto.App.26.
Opción 2 — sin CLI, editando la configuración a mano
Útil con Claude Desktop o si el comando claude no existe en el equipo. Añade
el bloque "presto" dentro de mcpServers y reinicia la app:
- Claude Desktop →
C:\Users\<usuario>\AppData\Roaming\Claude\claude_desktop_config.json(en la app: Settings → Developer → Edit Config). - Claude Code (config global de usuario) →
C:\Users\<usuario>\.claude.json, bajo la clave raízmcpServers.
{
"mcpServers": {
"presto": {
"command": "uvx",
"args": ["presto-mcp-server@latest"],
"env": { "PRESTO_PROGID": "Presto.App.25" }
}
}
}
Reinicia la app del todo (en Claude Desktop, ciérrala también desde el icono de la bandeja del sistema → Quit).
Si la app no encuentra
uvx(PATH), pon la ruta absoluta comocommand(en PowerShell:where.exe uvx), con barras dobles\\en el JSON.
Alternativas:
# con pip en vez de uv
pip install presto-mcp-server # luego command="python", args=["-m","presto_mcp"]
# sin PyPI, directo de GitHub (no autoactualiza salvo --refresh)
uvx --from git+https://github.com/NeoNexAI/presto-mcp-server presto-mcp
Para la vía COM: abre Presto (y la obra, si la operación la necesita) antes de
usar las herramientas. Comprueba la conexión con presto_status.
Herramientas
Conexión y obra
| Tool | Qué hace |
|---|---|
presto_status |
Comprueba la conexión COM y devuelve el ProgID activo |
presto_open_obra |
Abre una obra .Presto en la instancia en ejecución |
presto_close_obra |
Cierra la obra abierta |
Genéricas — cobertura del 100% del modelo de datos
| Tool | Qué hace |
|---|---|
presto_read_records |
Lee cualquier tabla/campos filtrando por máscara |
presto_get_field |
Lee un campo de un registro por su código |
presto_set_field |
Escribe un campo (transaccional, deshacible) |
presto_execute_option |
Ejecuta cualquier opción interna de Presto (DLG_*) con JSON |
Curadas — conceptos y precios
| Tool | Qué hace |
|---|---|
presto_get_concepto |
Código, unidad, resumen y precios de un concepto |
presto_search_conceptos |
Busca conceptos por resumen o código |
presto_get_precios |
Precios en todos los esquemas (presupuesto, certificación, real, objetivo, planificado) |
presto_set_precio |
Fija el precio de un concepto en un esquema |
BC3 (FIEBDC-3) — sin Presto
| Tool | Qué hace |
|---|---|
presto_bc3_resumen |
Resumen de un fichero BC3 (conceptos, capítulos, emisor) |
presto_bc3_buscar |
Busca conceptos por texto en un BC3 |
presto_bc3_concepto |
Concepto del BC3 con texto y descomposición |
presto_bc3_anomalias |
Precios a 0/ausentes, sin resumen, partidas sin descomposición |
Modelo de datos de Presto (referencia rápida)
La automatización trabaja sobre tablas.campo. Los nombres exactos se ven en
Presto con Ver: Lista de campos. Los más usados:
- Tabla
Conceptos:Conceptos.Código(clave única),Conceptos.Resumen,Conceptos.Ud, y preciosConceptos.PrPres(presupuesto),PrCert(certificación),PrReal,PrObj(objetivo),PrPlan(planificado). - Filtrado por máscara con comodines de Presto:
"E04*","*hormigón*","*".
Operaciones masivas (multiplicar precios, reducir niveles, generar objetivo,
exportar/importar formatos…) → presto_execute_option con el código del diálogo.
¿Y Presto ServerCloud (WebAPI REST)?
Presto de escritorio no expone API REST. La WebAPI (REST sobre HTTP) solo existe con la licencia Presto ServerCloud (suscripción aparte + IIS). Por eso este MCP usa COM local (la vía correcta para escritorio + dongle/pincho).
Si algún día se contrata ServerCloud, no hace falta un MCP aparte: se añade a
este mismo paquete una capa presto_webapi_* que se activa por variables de
entorno (PRESTO_WEBAPI_URL / PRESTO_WEBAPI_USER / PRESTO_WEBAPI_PASS).
Mientras no estén configuradas, el MCP funciona con COM + BC3 como siempre.
→ Un solo MCP, tres backends: COM (obra en vivo) · BC3 (ficheros) ·
WebAPI (solo si hay ServerCloud).
Desarrollo
python -m py_compile src/presto_mcp/*.py # comprobar sintaxis
python tests/test_bc3.py # tests del parser BC3 (sin Presto)
Estado de validación: el parser BC3 está verificado (6/6 tests) y el
servidor MCP carga y registra las 15 tools. La vía COM solo puede probarse
e2e en un equipo con Presto 2025 abierto → se valida en sesión presencial con
el cliente. Si algún nombre de campo difiere en una instalación concreta, se ajusta
con Ver: Lista de campos (las tools genéricas aceptan cualquier tabla.campo).
Licencia
MIT · NeoNexAI Agency
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file presto_mcp_server-2.0.1.tar.gz.
File metadata
- Download URL: presto_mcp_server-2.0.1.tar.gz
- Upload date:
- Size: 5.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
feaaef20f38f307c49386e76e9c58914640faf87e3e0f8470c4982a3d3870a59
|
|
| MD5 |
07840b67ff02b822a874c697e30a2870
|
|
| BLAKE2b-256 |
8437310ad08186dcfcba13e6ef6db29e684ea1f74cc0f3fcb129249317f11632
|
File details
Details for the file presto_mcp_server-2.0.1-py3-none-any.whl.
File metadata
- Download URL: presto_mcp_server-2.0.1-py3-none-any.whl
- Upload date:
- Size: 14.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
54c28c4b3e8daf118caf4f92972fcb0dd7952b898daae63130b7315d13202f21
|
|
| MD5 |
1ee5326739c3153a1818830cb55e9598
|
|
| BLAKE2b-256 |
1504952b431a20aea0b983ceddf5ec34d4ad0e3eea64a1c0b505a9828678245b
|