Skip to main content

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 DesktopC:\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íz mcpServers.
{
  "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 como command (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 precios Conceptos.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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

presto_mcp_server-2.0.1.tar.gz (5.8 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

presto_mcp_server-2.0.1-py3-none-any.whl (14.8 kB view details)

Uploaded Python 3

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

Hashes for presto_mcp_server-2.0.1.tar.gz
Algorithm Hash digest
SHA256 feaaef20f38f307c49386e76e9c58914640faf87e3e0f8470c4982a3d3870a59
MD5 07840b67ff02b822a874c697e30a2870
BLAKE2b-256 8437310ad08186dcfcba13e6ef6db29e684ea1f74cc0f3fcb129249317f11632

See more details on using hashes here.

File details

Details for the file presto_mcp_server-2.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for presto_mcp_server-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 54c28c4b3e8daf118caf4f92972fcb0dd7952b898daae63130b7315d13202f21
MD5 1ee5326739c3153a1818830cb55e9598
BLAKE2b-256 1504952b431a20aea0b983ceddf5ec34d4ad0e3eea64a1c0b505a9828678245b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page