AgentFlow
Arquitectura

Resumen de arquitectura

Módulos Go bajo application/internal y pipeline de ejecución.

Resumen de arquitectura

AgentFlow es una CLI Go (application/cmd/agentflow) con la mayor parte del comportamiento en application/internal/ y contratos compartidos en application/pkg/agentflow. Esta división mantiene el binario fino mientras aísla parsing, planificación, investigación, coste y almacenamiento tras paquetes explícitos que puedes razonar solo con el layout del árbol.

Pipeline de ejecución

La ruta de extremo a extremo empieza en la CLI, resuelve intención, ejecuta el pipeline V3 (investigación, optimización de contexto, coste y presupuestos, enrutamiento), luego etapas de workflow — plan, enrich, dev — en un worktree antes de validación, revisión opcional e informe.

flowchart TD
  A[User intent / CLI] --> B[intent resolver + planner]
  B --> C[pipeline V3]
  C --> D[investigation]
  D --> E[contextopt]
  E --> F[cost estimate + budgets]
  F --> G[routing]
  G --> H[workflow: plan enrich dev]
  H --> I[worktree + agent exec]
  I --> J[validation]
  J --> K[review + report]

Módulos internos

PaqueteRol
cliComandos Cobra, docgen, contexto app
configCarga YAML, valores por defecto, rutas
intentNL work/continue, resolvedor híbrido, ejecutor
workflowMáquina de estados, plan/dev/verify/review, worktrees
worktreeCiclo de vida git worktree
agent / agent/execContratos de subproceso
source / source/notionIngesta de specs
contextoptRecoger/reducir/pack de contexto
investigationgrep/escaneo local
costTokens, precios, presupuestos
routingClase de paso → agente/modelo
mcpHerramientas MCP stdio (opcional)
store/sqliteRuns, tareas, métricas
reportInformes de run
tuiUI rich/plain/json
ragÍndice de chunks (SQLite, no vectorial)
bootstrapinit, doctor
redactEnmascarado de secretos en logs
validationEjecutor de comandos externos

Almacenamiento de estado

Runs y tareas persisten en SQLite en state.path (por defecto .agentflow/state.sqlite). Los artefactos de cada run van bajo .agentflow/runs/<run-id>/, manteniendo prompts, logs y salidas intermedias localizables sin releer la base.

Puntos de extensión

Nuevos agentes solo con config; quality gates vía validation.commands; estrategias de enrutamiento bajo routing.strategies; herramientas MCP opcionales con mcp.enabled: true. Costuras intencionales: la mayoría de equipos extienden AgentFlow sin bifurcar el entrypoint Go.

Relacionado