Syncanix con Laravel
Convierte una API Laravel en preparada para agentes: qué lee el descubrimiento, cómo ejecutarlo y cómo publicar la superficie de chat y el servidor MCP.
Los archivos de rutas de Laravel parecen planos, pero el prefijo /api se aplica en otro lugar: en el route service provider o en la configuración de bootstrap. El descubrimiento lo compone desde todo el código.
Qué lee el descubrimiento
El descubrimiento es estático: lee tu código fuente, no tu tráfico. Compone las rutas de petición completas a través de archivos, de modo que los prefijos montados forman parte de cada ruta extraída:
// routes/api.php (the /api prefix comes from the route service provider)
Route::get('/orders/{order}', [OrderController::class, 'show']);
Route::post('/orders/{order}/refund', [OrderController::class, 'refund']);
// → GET /api/orders/{order} · POST /api/orders/{order}/refundEl extractor lee las declaraciones Route:: y los registros resource, compone el prefijo de grupo desde el RouteServiceProvider (o el apiPrefix de withRouting en Laravel 11) entre archivos, y enmascara los comentarios para que las rutas comentadas nunca se extraigan.
Ejecuta el descubrimiento
Desde la raíz del repositorio, ejecuta el comando init. Detecta el framework automáticamente, pide tu consentimiento antes de cualquier enriquecimiento con LLM y escribe un catálogo determinista:
$ npx syncanix init
✓ detected framework
✓ scanned routes
✓ wrote .syncanix/catalog.json
→ review your capabilities in the dashboardRevisa el catálogo
El catálogo en .syncanix/catalog.json lista cada capacidad que encontró el descubrimiento: método, ruta y la descripción enriquecida que verán tus usuarios. Revísalo como si fuera código antes de subirlo: es el contrato que exponen tu superficie de chat y tu servidor MCP.
Publica la superficie
Con el catálogo subido, incrusta el widget para el chat dentro de tu app y conecta el servidor MCP por tenant para Claude, ChatGPT y Cursor. Cada acción de escritura sigue protegida por permisos, confirmada y auditada.