Ir al contenido

Conjunto de herramientas dinámico

El conjunto de herramientas dinámico es el modo de bajo consumo de tokens de GitLab MCP Server. Mantiene disponible todo el catálogo de acciones de GitLab, pero muestra a tu cliente de IA solo dos herramientas públicas:

HerramientaQué hace
gitlab_find_actionEncuentra la acción correcta de GitLab y devuelve parámetros exactos, ejemplos y metadatos de seguridad
gitlab_execute_actionEjecuta la acción elegida tras validar el ID de acción y los parámetros

El modo dinámico de find/execute es la superficie predeterminada. Las meta-herramientas siguen disponibles con TOOL_SURFACE=meta para clientes que prefieren despachadores consolidados por dominio.

Los servidores MCP grandes pueden gastar mucho contexto solo en descubrimiento de herramientas antes de que el usuario pida nada. GitLab MCP Server puede exponer hasta 1045 operaciones individuales en GitLab.com Enterprise/Premium con Orbit, y el catálogo opcional de meta-herramientas anuncia entre 33 y 50 herramientas de dominio.

El modo dinámico expone ese catálogo canónico mediante dos herramientas visibles. El modelo descubre solo lo que necesita para la tarea actual.

flowchart LR
	A[tools/list] --> B[2 herramientas dinámicas públicas]
	B --> C[Encontrar acción y schema]
	C --> E[Ejecutar una acción canónica]
    E --> F[GitLab REST v4 o GraphQL]

Esto suele añadir una llamada de descubrimiento por tarea, pero mantiene muy pequeño el contexto inicial de herramientas MCP. El catálogo se comparte con las meta-herramientas, así que el modo dinámico reutiliza los mismos schemas, protecciones de acciones destructivas, filtrado de solo lectura, previsualizaciones de safe mode, filtrado por scopes del token y formato de resultados.

Añade TOOL_SURFACE=dynamic al entorno del servidor:

{
"servers": {
"gitlab": {
"type": "stdio",
"command": "/path/to/gitlab-mcp-server",
"env": {
"GITLAB_TOKEN": "glpat-xxxxxxxxxxxxxxxxxxxx",
"TOOL_SURFACE": "dynamic"
}
}
}
}
Ventana de terminal
gitlab-mcp-server --http \
--gitlab-url=https://gitlab.com \
--tool-surface=dynamic

Para el contexto inicial más pequeño, usa también la superficie mínima de capacidades:

Ventana de terminal
gitlab-mcp-server --http \
--gitlab-url=https://gitlab.com \
--tool-surface=dynamic \
--capability-surface=minimal

CAPABILITY_SURFACE=minimal mantiene gitlab://workspace/roots y los recursos de manifiesto de herramientas (gitlab://tools y gitlab://tools/{id}), y omite recursos opcionales, prompts y guías de flujo. Dynamic conserva el descubrimiento de schemas porque gitlab_find_action devuelve los schemas exactos inline. META_PARAM_SCHEMA solo afecta los schemas de las meta-herramientas, así que deja el valor predeterminado opaque en despliegues dinámicos.

El modo dinámico funciona mejor cuando el asistente sigue un ritmo simple: encontrar, ejecutar.

sequenceDiagram
    participant User as Usuario
    participant AI as Asistente IA
	participant Find as gitlab_find_action
    participant Execute as gitlab_execute_action
    participant GitLab

    User->>AI: Lista merge requests abiertas creadas por mí
	AI->>Find: merge request list open authored by me
	Find-->>AI: merge_request.list con schema de parámetros y ejemplos
    AI->>Execute: merge_request.list con parámetros validados
    Execute->>GitLab: Petición API
    GitLab-->>Execute: Datos de GitLab
    Execute-->>AI: Markdown y JSON estructurado
    AI-->>User: Respuesta formateada

Cada herramienta dinámica devuelve un resultado MCP normal: Markdown en content, datos JSON en structuredContent e isError en el envoltorio del resultado cuando el servidor devuelve una guía de reparación. gitlab_execute_action no usa un camino especial hacia GitLab. Despacha al mismo handler de acción que usan las meta-herramientas, así que los schemas, las comprobaciones de política, las previsualizaciones de safe mode, las confirmaciones destructivas y el formato de resultados siguen siendo coherentes.

LlamadaQué recibe el asistenteCómo debe usarlo el asistente
gitlab_find_actionIDs de acción canónicos ordenados con input_schema exacto, meta-herramienta base, dominio, acción, URI de schema, indicador destructivo, parámetros requeridos, pistas de uso, ejemplos, explicaciones opcionales y puntuaciónElegir el mejor candidato domain.action y construir params desde el schema
gitlab_execute_actionLa respuesta existente de la acción desde el handler base, normalmente Markdown y JSON estructuradoUsar los datos devueltos para responder al usuario, o reparar a partir de errores isError: true

Encontrar acciones es deliberadamente barato comparado con anunciar todas las operaciones de GitLab en tools/list. El modelo solo paga por schemas detallados cuando necesita una acción concreta.

gitlab_find_action es más que una búsqueda de subcadenas. Indexa IDs canónicos, palabras del ID separadas, nombres de meta-herramientas base, dominios, nombres de acción, alias, etiquetas, parámetros requeridos, parámetros opcionales, nombres de propiedades del schema, valores enum, descripciones compactas del schema y metadatos internos de backend.

El pipeline de ranking:

  1. Normaliza la consulta en minúsculas y separa espacios, puntos, guiones bajos y guiones.
  2. Elimina palabras frecuentes como the, to, with y please.
  3. Expande sinónimos como mr → merge request, secret → variable/token de CI, show → get y remove → delete. Palabras de backend como github pr o jira ticket se normalizan a conceptos GitLab de merge request o issue sin exponer IDs de acción no GitLab.
  4. Puntúa primero IDs canónicos exactos, después alias, etiquetas, nombres de dominio/acción, parámetros requeridos, valores enum del schema, campos del schema y metadatos más amplios.
  5. Ejecuta recuperación fuzzy de errores tipográficos solo cuando la búsqueda léxica no devuelve resultados o solo devuelve resultados de baja confianza.
  6. Busca prompts largos en ventanas de tres a seis términos para que prompts de varios pasos puedan sacar varias acciones relevantes.

La recuperación fuzzy está limitada a propósito: permite hasta dos errores de edición en tokens de al menos tres caracteres y suprime coincidencias tipográficas débiles para acciones destructivas. Eso ayuda con prompts como merje requesy list, mientras que términos cortos como mr siguen apoyándose en alias y sinónimos en lugar de coincidencias tipográficas demasiado permisivas.

Find acepta explain: true cuando el asistente necesita razones deterministas de puntuación. La respuesta por defecto sigue siendo compacta. Activar explain no cambia el ranking; solo añade metadatos de razonamiento. Las búsquedas sin coincidencias devuelven una lista pequeña de sugerencias, y los flujos curados pueden devolver related_actions, como repository.compare antes de analyze.release_notes.

Algunos límites útiles están fijados dentro del servidor en vez de configurarse por entorno:

ComportamientoValor actual
Resultados devueltos por findPor defecto 20 y máximo 50
Resultado de alta confianzaPuntuación mínima 80 y al menos 15 puntos de margen sobre el siguiente resultado
Manejo de prompts largosBusca ventanas solapadas de tres a seis términos para que un prompt pueda sacar varias acciones
Recuperación fuzzy de typosMáximo dos ediciones y solo para términos de al menos tres caracteres
Sugerencias sin coincidenciasHasta seis tokens cercanos del catálogo, luego áreas comunes como project, issue, merge request, pipeline, branch y user

Estos números son constantes internas de ajuste. No son variables de entorno. Existen para mantener el descubrimiento predecible sin perder recuperación ante redacciones y errores tipográficos comunes de los modelos.

Primero, encuentra la acción:

{
"tool": "gitlab_find_action",
"arguments": {
"query": "merge request list open authored by me project",
"limit": 5
}
}

Después, ejecútala:

{
"tool": "gitlab_execute_action",
"arguments": {
"action": "merge_request.list",
"params": {
"project_id": "my-group/my-project",
"state": "opened",
"scope": "created_by_me",
"per_page": 20
}
}
}

El asistente debe ejecutar el ID de acción canónico devuelto por find. Los alias ayudan al descubrimiento, pero los IDs canónicos son el contrato estable de ejecución.

El modo dinámico está diseñado para poder repararse. Si una llamada devuelve isError: true, el asistente debe usar el mensaje como feedback y repetir el paso correcto.

FalloRecuperación
La consulta de find está vacíaReintentar find con dominio, recurso, verbo y filtros útiles
El ID de acción es desconocidoBuscar de nuevo o usar los IDs canónicos sugeridos por el mensaje de error
Alias ambiguoElegir uno de los IDs domain.action listados por find
Los parámetros son rechazadosEncontrar la acción y reconstruir params desde input_schema
Una acción destructiva queda bloqueadaPedir aprobación explícita al usuario antes de reintentar con confirm: true a nivel superior

El modo dinámico reutiliza el mismo modelo de seguridad que las meta-herramientas. Las acciones destructivas siguen requiriendo confirmación explícita salvo que el despliegue haya desactivado intencionadamente las confirmaciones con YOLO_MODE o AUTOPILOT.

{
"tool": "gitlab_execute_action",
"arguments": {
"action": "project.delete",
"params": {
"project_id": "my-group/my-project"
}
}
}

Sin confirmación, el servidor devuelve un resultado de error en lugar de eliminar el proyecto. Para ejecutar la acción intencionadamente, pasa confirm: true a nivel superior en los argumentos de gitlab_execute_action:

{
"tool": "gitlab_execute_action",
"arguments": {
"action": "project.delete",
"confirm": true,
"params": {
"project_id": "my-group/my-project"
}
}
}

La ejecución dinámica valida los parámetros antes de despachar. Los campos desconocidos, incluidos campos sensibles no soportados como masked o protected en variables de pipeline schedules, se rechazan con guía de reparación en lugar de eliminarse silenciosamente.

Para despliegues más seguros, usa GITLAB_READ_ONLY=true para eliminar acciones mutantes o GITLAB_SAFE_MODE=true para previsualizar mutaciones sin aplicarlas.

PreguntaMeta-herramientasConjunto dinámico
Qué aparece en tools/list33 a 50 herramientas de dominio2 herramientas públicas de descubrimiento y ejecución
Cómo elige el modeloEscoge una herramienta de dominio y una acciónEncuentra una acción con schema y luego la ejecuta
Dónde están los schemasSchema de herramienta o gitlab://tools/{id}gitlab_find_action o gitlab://tools/{id}
Mejor uso actualModo explícito de compatibilidadDescubrimiento de acciones predeterminado de bajo consumo
Vuelta atrásUsa TOOL_SURFACE=metaRuta predeterminada
SíntomaQué hacer
Solo ves dos herramientasEs lo esperado en modo dinámico. Pide al asistente que encuentre acciones antes de ejecutar
La búsqueda devuelve resultados demasiado ampliosIncluye dominio, recurso, acción y filtros, por ejemplo merge request list open authored by me
Execute rechaza una acciónBusca de nuevo y usa el ID canónico domain.action del resultado
Execute rechaza parámetrosEncuentra la acción y reintenta con los nombres y tipos exactos
Recursos y prompts siguen consumiendo contextoAñade CAPABILITY_SURFACE=minimal o --capability-surface=minimal